對於本次更新,我想說:php
再次貼出GITHUB地址:Sqier框架GITHUB地址html
替換了很low的類名拼裝實例化,而後拼裝方法名的用法,使用PHP的回調函數方式:mysql
原代碼:git
$controller_name = 'Controller\\' . self::$c_name; $action_name = self::$a_name . 'Action'; $controller = new $controller_name(); $controller->$action_name();
修改後代碼github
$controller_name = 'Controller\\' . self::$c_name; $controller = new $controller_name(); call_user_func([ $controller, self::$a_name . 'Action' ]);
這裏介紹一下PHP的函數回調應用方式:call_user_func和call_user_func_array:web
call_user_func ( callback $function [, mixed $parameter [, mixed $... ]] )sql
調用第一個參數所提供的用戶自定義的函數。數據庫
返回值:返回調用函數的結果,或FALSE。canvas
call_user_func_array()的用法跟call_user_func相似,只不過傳入的參數params總體爲一個數組。數組
另外,call_user_func系列函數還能夠傳入在第一個參數裏傳入匿名參數,能夠很方便的回調某些事件,這些特性在複雜的框架裏應用也十分普遍,如yii2的事件機制裏回調函數的使用就是基於此。
框架在controller的基類中定義了render方法來渲染頁面,它會調用類VIEW的靜態函數來分析加載對應頁面的模板。
public static function display($data, $view_file) { if(is_array($data)) { extract($data);//extract函數解析$data數組中的變量 }else { //拋出變量類型異常 } ob_start(); ob_implicit_flush(0); include self::checkTemplate($view_file);//自定義checkTemplate函數,分析檢查對應的函數模板,正常返回路徑 $content = ob_get_clean(); echo $content; }
這裏重點說一下ob(output buffering)系列函數,其做用引用簡明代魔法的ob做用介紹:
它在ob_start()函數執行後,打開緩衝區,將後面的輸出內容裝進系統的緩衝區,ob_implicit_flush(0)函數來關閉絕對刷送(echo等),最後使用ob_get_clean()函數將緩衝區的內容取出來。
TP裏的__URL__等全局常量用着很方便,能夠很簡單的實現跳轉等操做,而定義它的函數createUrl函數我又想重用,因而借鑑YII的全局類定義方法:
定義基類及詳細方法(之後的全局方法會寫在這裏)
class BaseSqier{ //方法根據傳入的$info信息,和當前URL_MODE解析返回URL字符串 public static function createUrl($info = '') { $url_info = explode('/', strtolower($info)); $controller = isset($url_info[1]) ? $url_info[0] : strtolower(CONTROLLER); $action = isset($url_info[1]) ? $url_info[1] : $url_info[0]; switch(URL_MODE){ case URL_COMMON: return "/index.php?r=" . $controller . '/' . $action; case URL_REWRITE: return '/' .$controller . '/' . $action; } } }
在啓動文件中定義類並繼承基類;
require_once SQ_PATH.'BaseSqier.php'; class SQ extends BaseSqier{ }
在全局內均可以直接使用SQ::createUrl()方法來建立URL了。這樣,定義__URL__常量就很輕鬆了。
class Db { protected static $_instance; public static function getInstance() { if(!(self::$_instance instanceof self)) { self::$_instance = new self(); } return self::$_instance; } private function __construct() { $link = new \mysqli(DB_HOST, DB_USER, DB_PWD, DB_NAME) or die("鏈接數據庫失敗,請檢查數據庫配置信息!"); $link->query('set names utf8'); } public function __clone() { return self::getInstance(); } }
使用單例模式的核心是:
DB查詢函數是一個很複雜的部分,它是一個自成體系的東西,像TP和YII的查詢方法都有其獨特的地方。我這裏暫時先借用TP的MODEL基類,有時間再慢慢補這個。
嗯,介紹一下像TP的查詢裏的方法聯查的實現,其訣竅在於,在每一個聯查方法的最後都用 return this
來返回已處理過的查詢對象。
yii2裏的數據表和model類屬性之間的映射很酷(雖然被深坑過), 前面一直避開的模塊(module,我能夠想像獲得把它也添加到URI時解析的麻煩)有時間考慮一下。
邊寫邊優化。
嗯,待續... 對了,宣傳一下本身的我的站:www.alwayscoding.cn 個人聯繫方式在留言板頁面的右側,有問題能夠在那裏交流。