Yii核心組件AssetManager原理分析
本文我們通過yii自帶的demo-blog程序來分析Yii核心組件AssetManager,他可以自動加載css和javascript,并且只需要一句代碼即可。具體分析如下:
打開blog的首頁,會看到如下的引入js的html代碼:
<link rel="stylesheet" type="text/css" href="/yii/demos/blog/assets/c2e28f0f/pager.css" />
<script type="text/javascript" src="/yii/demos/blog/assets/d6112c6a/jquery.min.js"></script>
<script type="text/javascript" src="/yii/demos/blog/assets/d6112c6a/jquery.ba-bbq.js"></script>
這些js文件的路徑都在assets文件夾下,assets后面跟著一個顯然經(jīng)過hash的文件夾路徑,同屬于jq的js代碼的路徑相同,這段代碼從何而來呢?
直接看view文件看不到任何引入js的代碼,因此應(yīng)該是使用widget引入的:
$this->widget('zii.widgets.CListView', array(
'dataProvider'=>$dataProvider,
'itemView'=>'_view',
'template'=>"{items}n{pager}",
));
?>
這個widget也是yii自帶的zii擴(kuò)展,于是乎我們可以找到zii的CListView代碼,而CListView又是繼承CBaseListView,因此先看CBaseListView的run方法:
{
$this->registerClientScript();
echo CHtml::openTag($this->tagName,$this->htmlOptions)."n";
$this->renderKeys();
$this->renderContent();
echo CHtml::closeTag($this->tagName);
}
請注意第一個方法registerClientScript,這個方法是在CListView中實(shí)現(xiàn)的:
{
……
$cs=Yii::app()->getClientScript();
$cs->registerCoreScript('jquery');
$cs->registerCoreScript('bbq');
……
}
看到j(luò)query和bbp似乎離真相近了些,接下來我們看CClientScript::registerCoreScript方法:
{
$this->_hasScripts=true;
$this->_coreScripts[$name]=$name;
$params=func_get_args();
$this->recordCachingAction('clientScript','registerCoreScript',$params);
}
這里其實(shí)主要是記錄了最終頁面要render的js,而實(shí)際生成render的url是通過getCoreScriptUrl方法:
{
if($this->_baseUrl!==null)
return $this->_baseUrl;
else
return $this->_baseUrl=Yii::app()->getAssetManager()->publish(YII_PATH.'/web/js/source');
}
接下來我們看看publish的具體過程:
{
if(is_file($src))
{
$dir=$this->hash($hashByName ? basename($src) : dirname($src));
$fileName=basename($src);
……
else if(is_dir($src))
{
$dir=$this->hash($hashByName ? basename($src) : $src);
$dstDir=$this->getBasePath().DIRECTORY_SEPARATOR.$dir;
……
}
這里通過對路徑做了hash處理,因此我們看到的路徑是不規(guī)則的,而由于jq系列的js代碼均在同一路徑下(都在framework/web/js/source下),所以hash值是相同的。
另外,除了如上所述,CAssetManager使得多個模塊可以復(fù)用相同的代碼制外,使用CAssetManager的另外一個好處是安全隔離,將真實(shí)的代碼放在受保護(hù)的路徑下,按需加載。
希望本文所述對大家基于yii框架的PHP程序設(shè)計有所幫助。
相關(guān)文章
tp5(thinkPHP5框架)captcha驗(yàn)證碼配置及驗(yàn)證操作示例
這篇文章主要介紹了tp5(thinkPHP5框架)captcha驗(yàn)證碼配置及驗(yàn)證操作,結(jié)合實(shí)例形式分析了基于thinkPHP5框架的captcha驗(yàn)證碼配置及驗(yàn)證操作具體步驟與相關(guān)注意事項(xiàng),需要的朋友可以參考下2019-05-05
joomla實(shí)現(xiàn)注冊用戶添加新字段的方法
這篇文章主要介紹了joomla實(shí)現(xiàn)注冊用戶添加新字段的方法,實(shí)例分析了Joomla注冊用戶添加新字段的步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-05-05
PHP實(shí)現(xiàn)WebSocket實(shí)例詳解
這篇文章主要介紹了PHP實(shí)現(xiàn)WebSocket實(shí)例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
destoon整合ucenter后注冊頁面不跳轉(zhuǎn)的解決方法
這篇文章主要介紹了destoon整合ucenter后注冊頁面不跳轉(zhuǎn)的解決方法,需要的朋友可以參考下2014-06-06
php設(shè)計模式之單例模式用法經(jīng)典示例分析
這篇文章主要介紹了php設(shè)計模式之單例模式用法,結(jié)合具體實(shí)例形式分析了php單例模式的概念、原理、定義及使用方法,需要的朋友可以參考下2019-09-09

