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

2025-05-29 0 92

应用场景

Yii2提供了AppAsset类管理静态资源,在使用Yii2 布局模板时,如果想在某个页面内部写一段js 并且在页面底部,如果直接使用 script 标签是不可以的。

使用AppAsset类管理静态资源

打开assetsAppAsset.php,定义 addJs(),addCss() 分别用于在静态页面引入外部js、css 文件

1、修改AppAsset.php文件代码

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43
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

?

1

2

3

4

5

6

7
<?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>的后面。

方案一

?

1

2

3

4

5

6

7
<?php

$this->registerJs("

$(function () {

//为所欲为的写你想要写的js代码吧

});

", \\yii\\web\\View::POS_END);

方案二

?

1

2

3

4

5

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

//js代码

<?php $this->endBlock() ?>

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

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

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

?

1

2

3

4

5

6

7

8
<script type="text/javascript">

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

//js代码

<?php $this->endBlock() ?>

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

</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持快网idc。

原文链接:https://segmentfault.com/a/1190000005893471

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 Yii2 加载css、js 载静态资源的方法 https://www.kuaiidc.com/95215.html

相关文章

发表评论
暂无评论