找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 773|回复: 0
打印 上一主题 下一主题

Yii2 加载css、js 载静态资源的方法

[复制链接]

2560

主题

2560

帖子

7622

积分

论坛元老

Rank: 8Rank: 8

积分
7622
跳转到指定楼层
楼主
发表于 2018-2-14 05:27:34 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            应用场景
Yii2提供了AppAsset类管理静态资源,在使用Yii2 布局模板时,如果想在某个页面内部写一段js 并且在页面底部,如果直接使用 script 标签是不可以的。
使用AppAsset类管理静态资源
打开assetsAppAsset.php,定义 addJs(),addCss() 分别用于在静态页面引入外部js、css 文件
1、修改AppAsset.php文件代码
namespace backend\assets;
use yii\web\AssetBundle;
/**
* @author Qiang Xue
* @since 2.0
*/
class AppAsset extends AssetBundle
{
  public $basePath = "@webroot";
  public $baseUrl = "@web";
  //默认自动加载样式
  public $css = [
    "css/site.css",
  ];
  //默认自动加载js
  public $js = [
  ];
  //依赖关系管理
  public $depends = [
    "yii\web\YiiAsset",
    "yii\bootstrap\BootstrapAsset",
  ];  
  //定义按需加载JS方法,注意加载顺序在最后
  public static function addJs($view, $jsfile) {
    $view->registerJsFile(
      $jsfile,
      [
        AppAsset::className(),
        "depends" => "backend\assets\AppAsset"
      ]
    );
  }
  //定义按需加载css方法,注意加载顺序在最后
  public static function addCss($view, $cssfile) {
    $view->registerCssFile(
      $cssfile,
      [
       AppAsset::className(),
       "depends" => "backend\assets\AppAsset"
      ]
    );
  }
}
2、在静态页面调用AppAsset.php
request->baseUrl."/js/a.js");
AppAsset::addCss($this,Yii:app->request->baseUrl."/css/b.css");
?>
在网站页面底部加载javascript代码
网页内部的js文件或代码,根据页面加载顺序,避免执行js时间过程导致页面空白,导致用户体验不好问题。一般放置在网页底部的后面。
方案一
registerJs("
  $(function () {
  //为所欲为的写你想要写的js代码吧
  
  });
", \yii\web\View:OS_END);
方案二
beginBlock('js') ?>
  //js代码
  
endBlock() ?>
registerJs($this->blocks['js'], \yii\web\View:OS_END); ?>
解决Yii2在页面底部加载JS,语法提示失效
加入script 标签即可,注意只有 方案二有效,知道有其他方法的 ,望告知,谢谢!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
            
            
您可能感兴趣的文章:
  • yii2 页面底部加载css和js的技巧
  • Yii安装EClientScript插件扩展实现css,js文件代码压缩合并加载功能
  • Yii2中使用asset压缩js,css文件的方法
  • yii2简单使用less代替css示例
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端