马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
学校并没有那么多的时间可以让我们在实际开发上面。
之前咱们在进口文件就直接挪用了Route::run(),如许做有不有甚么成绩呢?
谜底是有的!
有时分在停止路由之前和以后需求停止一些额定的处置,假如依照之前在进口文件直接挪用Route::run()的话,那末这些处置进程只能写在进口文件中,然而进口文件本不该该做如许的工作,那末咱们该怎样来处理这个成绩呢?
咱们引入一个前端掌握器的概念,它相当于一个总控,一切内部的恳求都在它的掌握局限内,那末这些额定的处置是否是就能够放在这个掌握器中了呢!!
好,咱们如今先修正一下进口文件:
01 <?php 02 defined('APP_PATH') define('APP_PATH',dirname(__FILE__) . '/..'); 03 defined('FRAMEWORK_PATH') define('FRAMEWORK_PATH',APP_PATH . '/Library/Test'); 04 defined('MODULES_PATH') define('MODULES_PATH',APP_PATH . '/UserApps/Modules'); 05 defined('CONFIGS_PATH') define('CONFIGS_PATH',APP_PATH . '/UserApps/Configs'); 06 include FRAMEWORK_PATH . '/function.php'; 07 C(Config::factory(Config::PHP)); //写入设置装备摆设信息 08 include FRAMEWORK_PATH . '/FrontController.php'; 09 $frontController = FrontController::getInstance(); 10 $frontController->run();
这段代码实践上修正的内容不多,也就修正了:
1 include FRAMEWORK_PATH . '/FrontController.php'; 2 $frontController = FrontController::getInstance(); 3 $frontController->run(); 这段代码起首include了前端掌握器这个文件,然后实例化了前端掌握器,然后挪用前端掌握器这个类的run办法。
为何不直接利用$frontController = new FrontController()?
假如你掌控前面的代码下载后运转会发明,如许会报错,为何呢?
这儿我需求引见别的一个概念:单例形式。
单例形式就是在全部法式运转过程当中只要一个实例,好比数据库的毗连,即便有良多类,然而能够这些类都公用数据库的毗连,那末数据库的毗连就是单例的。
为何要利用单例呢?
人人可以想一下,前端掌握器掌握全部法式的运转,那末它切实其实是不该该有多份的,是否是?
为了包管是单例的,所以咱们普通利用一个静态办法(getInstance)来实例化它,为了避免用户直接new和克隆一个对象,咱们需求将__construct和__clone设置为公有。
01 <?php 02 class Test { 03 private static $_instance = null; 04 private function __construct() {} 05 private function __clone() {} 06 public static function getInstance() { 07 if(null === self::$_instance) { 08 self::$_instance = new Test(); 09 echo '1'; 10 } 11 return self::$_instance; 12 } 13 } 14 15 $test = Test::getInstance(); 16 $test2 = Test::getInstance();
假如履行这段代码,会发明只输入了一个1,申明实例化只履行了一次。
说了这么多,人人应当都应当懂了吧,那就直接贴出前端掌握器的代码吧:
01 <?php 02 class FrontController { 03 private static $_instance = null; 04 private function __construct() {} 05 private function __clone() {} 06 public static function getInstance() { 07 if(!(self::$_instance instanceof self)) { 08 self::$_instance = new FrontController(); 09 } 10 return self::$_instance; 11 } 12 public function run() { 13 Route::run(); 14 } 15 } 固然,前端掌握器中我是利用了instanceof来剖断的,其实也能够直接用null === self::$_instance来剖断。
这段代码很复杂,实践上就把Route::run()转移到FrontController了,其他的都没有甚么变更。
人人能够注重到了,进口文件的内容仍是太多了,为何不克不及把进口文件的器材迁徙到FrontController呢,那末那些可以迁徙到FrontController呢,起首是界说的常量,其实只需用户界说APP_PATH便可,其他的常量都可以由框架默许,其次是设置装备摆设文件的写入,这类内容框架完整可以本人弄定,所以,进口文件的代码酿成了如许:
1 <?php 2 defined('APP_PATH') define('APP_PATH',dirname(__FILE__) . '/..'); 3 defined('FRAMEWORK_PATH') define('FRAMEWORK_PATH',APP_PATH . '/Library/Test'); 4 include FRAMEWORK_PATH . '/FrontController.php'; 5 $frontController = FrontController::getInstance(); 6 $frontController->run(); 我在此处留下了FRAMEWORK_PATH,是由于我要援用框架的文件,其实也不界说FRMAEWORK_PATH,而改用include APP_PATH . '/Library/Test/FrontController.php'。
一样,FrontController的代码也产生了变更:
01 <?php 02 defined('APP_PATH') exit('不决义APP_PATH'); 03 defined('FRAMEWORK_PATH') define('FRAMEWORK_PATH',APP_PATH . '/Library/Test'); 04 defined('MODULES_PATH') define('MODULES_PATH',APP_PATH . '/UserApps/Modules'); 05 defined('CONFIGS_PATH') define('CONFIGS_PATH',APP_PATH . '/UserApps/Configs'); 06 include FRAMEWORK_PATH . '/function.php'; 07 class FrontController { 08 private static $_instance = null; 09 private function __construct() { 10 C(Config::factory(Config::PHP)); //写入设置装备摆设信息 11 } 12 private function __clone() {} 13 public static function getInstance() { 14 if(!(self::$_instance instanceof self)) { 15 self::$_instance = new FrontController(); 16 } 17 return self::$_instance; 18 } 19 public function run() { 20 Route::run(); 21 } 22 } 起首,这个文件剖断是不是界说了APP_PATH,因为这个常量十分主要,其他途径都依托它,所以用户假如不指定,法式就需求中断。其他的常量假如没有界说,那末就界说它,这个很复杂。
设置装备摆设文件写到了机关函数中了,由于不论getInstance挪用几何次,机关函数只会被挪用1次,而设置装备摆设文件恰好也只需求写入一次。
兴趣可能会慢慢消亡,所以适当培养兴趣会激发自己无线的乐趣,有了乐趣,编程有啥难的。 |