對于本次更新,我想說:
本框架由本人挑時間完善,而我還不是PHP大神級的人物,所以框架漏洞難免,求大神們指出。 本框架的知識點應(yīng)用都會寫在博客里,大家有什么異議的可以一起討論,也希望看博客的也能學(xué)習(xí)到它們。 本次更新,更新了函數(shù)規(guī)范上的一些問題,如將函數(shù)盡量的獨立化,每一個函數(shù)盡量只單獨做好一件事情,盡量減少函數(shù)依賴。還對框架的整體優(yōu)化了一下,添加了SQ全局類,用以處理全局函數(shù),變量。再次貼出GITHUB地址:Sqier框架GITHUB地址
替換了很low的類名拼裝實例化,然后拼裝方法名的用法,使用PHP的回調(diào)函數(shù)方式:
原代碼:
$controller_name = 'Controller/' . self::$c_name;$action_name = self::$a_name . 'Action';$controller = new $controller_name();$controller->$action_name();
修改后代碼
$controller_name = 'Controller/' . self::$c_name; $controller = new $controller_name(); call_user_func([ $controller, self::$a_name . 'Action' ]);
這里介紹一下PHP的函數(shù)回調(diào)應(yīng)用方式:call_user_func和call_user_func_array:
call_user_func ( callback $function [, mixed $parameter [, mixed $... ]] )
調(diào)用第一個參數(shù)所提供的用戶自定義的函數(shù)。
返回值:返回調(diào)用函數(shù)的結(jié)果,或FALSE。
call_user_func_array()的用法跟call_user_func類似,只不過傳入的參數(shù)params整體為一個數(shù)組。
另外,call_user_func系列函數(shù)還可以傳入在第一個參數(shù)里傳入匿名參數(shù),可以很方便的回調(diào)某些事件,這些特性在復(fù)雜的框架里應(yīng)用也十分廣泛,如yii2的事件機制里回調(diào)函數(shù)的使用就是基于此。
框架在controller的基類中定義了render方法來渲染頁面,它會調(diào)用類VIEW的靜態(tài)函數(shù)來分析加載對應(yīng)頁面的模板。
html' target='_blank'>public static function display($data, $view_file) { if(is_array($data)) { extract($data);//extract函數(shù)解析$data數(shù)組中的變量 }else { //拋出變量類型異常 } ob_start(); ob_implicit_flush(0); include self::checkTemplate($view_file);//自定義checkTemplate函數(shù),分析檢查對應(yīng)的函數(shù)模板,正常返回路徑 $content = ob_get_clean(); echo $content;}
這里重點說一下ob(output buffering)系列函數(shù),其作用引用簡明代魔法的ob作用介紹:
防止在瀏覽器有輸出之后再使用setcookie,或者h(yuǎn)eader,session_start函數(shù)造成的錯誤。其實這樣的用法少用為好,養(yǎng)成良好的代碼習(xí)慣。 捕捉對一些不可獲取的函數(shù)的輸出,比如phpinfo會輸出一大堆的HTML,但是我們無法用一個變量例如$info=phpinfo();來捕捉,這時候ob就管用了。 對輸出的內(nèi)容進(jìn)行處理,例如進(jìn)行g(shù)zip壓縮,例如進(jìn)行簡繁轉(zhuǎn)換,例如進(jìn)行一些字符串替換。 生成靜態(tài)文件,其實就是捕捉整頁的輸出,然后存成文件,經(jīng)常在生成HTML,或者整頁緩存中使用。它在ob_start()函數(shù)執(zhí)行后,打開緩沖區(qū),將后面的輸出內(nèi)容裝進(jìn)系統(tǒng)的緩沖區(qū),ob_implicit_flush(0)函數(shù)來關(guān)閉絕對刷送(echo等),最后使用ob_get_clean()函數(shù)將緩沖區(qū)的內(nèi)容取出來。
TP里的__URL__等全局常量用著很方便,可以很簡單的實現(xiàn)跳轉(zhuǎn)等操作,而定義它的函數(shù)createUrl函數(shù)我又想重用,于是借鑒YII的全局類定義方法:
定義基類及詳細(xì)方法(以后的全局方法會寫在這里)
class BaseSqier{ //方法根據(jù)傳入的$info信息,和當(dāng)前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{}在全局內(nèi)都可以直接使用SQ::createUrl()方法來創(chuàng)建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('連接數(shù)據(jù)庫失敗,請檢查數(shù)據(jù)庫配置信息!'); $link->query('set names utf8'); } public function __clone() { return self::getInstance(); }}使用單例模式的核心是:
私有化構(gòu)造函數(shù),使無法用new來創(chuàng)建對象,也防止子類繼承它并改寫其構(gòu)造函數(shù); 用靜態(tài)變量存放當(dāng)前對象,定義靜態(tài)方法來返回對象,如對象還未實例化,實例化一個,存入靜態(tài)變量并返回。 構(gòu)造其__clone魔術(shù)方法,防止clone出一個新的對象;DB查詢函數(shù)是一個很復(fù)雜的部分,它是一個自成體系的東西,像TP和YII的查詢方法都有其獨特的地方。我這里暫時先借用TP的MODEL基類,有時間再慢慢補這個。
嗯,介紹一下像TP的查詢里的方法聯(lián)查的實現(xiàn),其訣竅在于,在每個聯(lián)查方法的最后都用 return this 來返回已處理過的查詢對象。
yii2里的數(shù)據(jù)表和model類屬性之間的映射很酷(雖然被深坑過), 前面一直避開的模塊(module,我可以想像得到把它也添加到URI時解析的麻煩)有時間考慮一下。
邊寫邊優(yōu)化。
嗯,待續(xù)... 對了,宣傳一下自己的個人站:www.alwayscoding.cn 我的聯(lián)系方式在留言板頁面的右側(cè),有問題可以在那里交流。
PHP編程鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。
新聞熱點
疑難解答
圖片精選