yii怎么引用assets?

广告:宝塔Linux面板高效运维的服务器管理软件 点击【 https://www.bt.cn/p/uNLv1L 】立即购买

yii怎么引用assets?

yii引用assets的方法:首先将需要用到的资源放在【modules/admin/assets】下;然后将私有资源publish到公共目录下;接着在网站目录的【/assets】下创建一个随机不冲突的文件夹;最后复制文件即可。

yii引用assets的方法:

为什么用YII assets

1.assets的作用是方便模块化,插件化的,一般来说出于安全原因不允许通过url访问protected下面的文件 ,但是我们又希望将module单独出来,所以需要使用发布,即将一个目录下的文件复制一份到assets下面方便通过url访问

$assets = Yii::getPathOfAlias('ext').'/css'; //$baseUrl = Yii::app()->getAssetManager()->publish($assets); $baseUrl = Yii::app()->assetManager->publish($assets);  //extensions/css发布到assets的创建一个随机不冲突的文件夹下 Yii::app()->clientScript->registerCssFile($baseUrl.'/main.css');//引用assets下面的main.css
登录后复制

2.如果一个模块需要添加使用资源,直接从webroot中引用添加即可。

但是试图创建一个模块能够在任何地方引用,且资源独立并能够避免命名冲突 。

你如何保证你的文件名不会与一些零散的应用程序的尝试使用相同名称的文件冲突,对于js,images,css也一样。

通过CAssetManager,Yii::app()->assetManager能够自动的将私有资源publish到公共目录下webroot/assets

相关学习推荐:yii教程

下面以admin module为例

1、把需要用到的资源放在modules/admin/assets下。

2、然后通过 CAssetManager,Yii::app()->assetManager能够自动的将私有资源publish到公共目录下,网站目录/assets

3、Yii会自动在网站目录的/assets下创建一个随机不冲突的文件夹,如2b31b42b,并把你的modules/admin/assets目录下的文件拷贝过去。

通过如下代码获得,修改protected\modules\admin\AdminModule.php文件,

<?php class AdminModule extends CWebModule {     private $_assetsUrl;        public function getAssetsUrl()     {         if($this->_assetsUrl===null)             $this->_assetsUrl=Yii::app()->getAssetManager()->publish(Yii::getPathOfAlias('application.modules.admin.assets'));         return $this->_assetsUrl;     }        public function setAssetsUrl($value)     {         $this->_assetsUrl=$value;     } }
登录后复制

然后,在/protected/modules/admin/views/layouts/main.php中 使用$this->module->assetsUrl就可以调用你的css等文件了。

<link rel="stylesheet" type="text/css" href="<?php echo $this->module->assetsUrl; ?>/css/screen.css"/>
登录后复制

使用前强制更新asset

 $baseJsUrl = Yii::app()->getAssetManager()->publish($baseJsPath, false, -1, YII_DEBUG);
登录后复制

以上就是yii怎么引用assets?的详细内容,更多请关注9543建站博客其它相关文章!

广告:SSL证书一年128.66元起,点击购买~~~

9543建站博客
一个专注于网站开发、微信开发的技术类纯净博客。
作者头像
admin创始人

肥猫,知名SEO博客站长,14年SEO经验。

上一篇:ThinkPHP5框架中如何查询并处理数据
下一篇:手把手教你在小程序中实现内容搜索功能

发表评论

关闭广告
关闭广告