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


Posted in PHP onMarch 10, 2017

应用场景

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

<?php

use backend\assets\AppAsset;
AppAsset::register($this);
AppAsset::addJs($this,Yii::$app->request->baseUrl."/js/a.js");
AppAsset::addCss($this,Yii::$app->request->baseUrl."/css/b.css");
?>

在网站页面底部加载javascript代码

网页内部的js文件或代码,根据页面加载顺序,避免执行js时间过程导致页面空白,导致用户体验不好问题。一般放置在网页底部</body>的后面。

方案一

<?php
$this->registerJs("
  $(function () {
  //为所欲为的写你想要写的js代码吧
  
  });
", \yii\web\View::POS_END);

方案二

<?php $this->beginBlock('js') ?> 

  //js代码
  
<?php $this->endBlock() ?> 
<?php $this->registerJs($this->blocks['js'], \yii\web\View::POS_END); ?>

解决Yii2在页面底部加载JS,语法提示失效

加入script 标签即可,注意只有 方案二有效,知道有其他方法的 ,望告知,谢谢!

<script type="text/javascript">
<?php $this->beginBlock('js') ?> 

  //js代码
  
<?php $this->endBlock() ?> 
<?php $this->registerJs($this->blocks['js'], \yii\web\View::POS_END); ?> 
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
用PHP生成自己的LOG文件
Oct 09 PHP
PHP 和 MySQL 基础教程(四)
Oct 09 PHP
php下载文件的代码示例
Jun 29 PHP
php中try catch捕获异常实例详解
Nov 21 PHP
php+ajax实现无刷新数据分页的办法
Nov 02 PHP
项目中应用Redis+Php的场景
May 22 PHP
PHP中explode函数和split函数的区别小结
Aug 24 PHP
浅谈PHP中静态方法和非静态方法的相互调用
Oct 04 PHP
PHP读取大文件的几种方法介绍
Oct 27 PHP
PDO::inTransaction讲解
Jan 28 PHP
Laravel5.4框架中视图共享数据的方法详解
Sep 05 PHP
php中pcntl_fork详解
Apr 01 PHP
php pdo操作数据库示例
Mar 10 #PHP
yii2简单使用less代替css示例
Mar 10 #PHP
在Mac OS下搭建LNMP开发环境的步骤详解
Mar 10 #PHP
Yii2.0中使用js异步删除示例
Mar 10 #PHP
php实现购物车功能(以大苹果购物网为例)
Mar 09 #PHP
PHP用户管理中常用接口调用实例及解析(含源码)
Mar 09 #PHP
php获取字符串前几位的实例(substr返回字符串的子串用法)
Mar 08 #PHP
You might like
PHP原理之异常机制深入分析
2010/08/08 PHP
linux使用crontab实现PHP执行计划定时任务
2014/05/10 PHP
YII框架关联查询操作示例
2019/04/29 PHP
Laravel框架验证码类用法实例分析
2019/09/11 PHP
PHP配合fiddler抓包抓取微信指数小程序数据的实现方法分析
2020/01/02 PHP
Javascript 的addEventListener()及attachEvent()区别分析
2009/05/21 Javascript
jQuery EasyUI 开源插件套装 完全替代ExtJS
2010/03/24 Javascript
JavaScript splice()方法详解
2020/09/22 Javascript
基于jQuery实现的向下滑动二级菜单效果代码
2015/08/31 Javascript
js表单提交和submit提交的区别实例分析
2015/12/10 Javascript
js数组常用操作方法小结(增加,删除,合并,分割等)
2016/08/02 Javascript
Jquery实现上下移动和排序代码
2016/10/17 Javascript
Vue计算属性的使用
2017/08/04 Javascript
浅谈在koa2中实现页面渲染的全局数据
2017/10/09 Javascript
vue图片上传本地预览组件使用详解
2019/02/20 Javascript
基于vue的tab-list类目切换商品列表组件的示例代码
2020/02/14 Javascript
js实现页面导航层级指示效果
2020/08/25 Javascript
[45:10]NB vs Liquid Supermajor小组赛 A组胜者组决赛 BO3 第二场 6.2
2018/06/04 DOTA
python使用append合并两个数组的方法
2015/04/28 Python
django开发教程之利用缓存文件进行页面缓存的方法
2017/11/10 Python
Python中Scrapy爬虫图片处理详解
2017/11/29 Python
python检索特定内容的文本文件实例
2018/06/05 Python
解决tensorflow测试模型时NotFoundError错误的问题
2018/07/27 Python
python使用threading.Condition交替打印两个字符
2019/05/07 Python
python使用 __init__初始化操作简单示例
2019/09/26 Python
Python 统计位数为偶数的数字代码详解
2020/03/15 Python
python实现文字版扫雷
2020/04/24 Python
Css3圆角边框制作代码
2015/11/18 HTML / CSS
英国和世界各地预订便宜的酒店:LateRooms.com
2019/05/05 全球购物
党校培训思想汇报
2013/12/30 职场文书
事业单位请假制度
2014/01/13 职场文书
商场周年庆活动方案
2014/08/19 职场文书
学校做一个有道德的人活动方案
2014/08/23 职场文书
政风行风评议工作总结
2014/10/21 职场文书
pandas进行数据输入和输出的方法详解
2022/03/23 Python
nginx lua 操作 mysql
2022/05/15 Servers