100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > js怎么动态加载js文件(JavaScript性能优化篇)

js怎么动态加载js文件(JavaScript性能优化篇)

时间:2022-10-25 14:26:59

相关推荐

js怎么动态加载js文件(JavaScript性能优化篇)

下面介绍一种JS代码优化的一个小技巧,通过动态加载引入js外部文件来提高网页加载速度

【基本优化】

将所有需要的<script>标签都放在</body>之前,确保脚本执行之前完成页面渲染而不会造成页面堵塞问题,这个大家都懂的。

【合并JS代码,尽可能少的使用script标签】

最常见的方式就是带代码写入一个js文件中,让页面只使用一次<script></script>标签来引入

【无堵塞加载JS】

通过给script标签增加 defer属性或者是 async 属性来实现

<script src="file.js"defer></script>

注解:

asyncdefer不同之处是async加载完成后会自动执行脚本,defer加载完成后需要等待页面也加载完成才会执行代码

【动态创建script来加载-推荐】

function loadJS( url, callback ){

var script = document.createElement('script'),

fn = callback || function(){};

script.type = 'text/javascript';

//IE

if(script.readyState){

script.onreadystatechange = function(){

if( script.readyState == 'loaded' || script.readyState == 'complete' ){

script.onreadystatechange = null;

fn();

}

};

}else{

//其他浏览器

script.onload = function(){

fn();

};

}

script.src = url;

document.getElementsByTagName('head')[0].appendChild(script);

}

//用法

loadJS('file.js',function(){

alert(1);

});

谷歌浏览器运行效果,script被动态创建在head中

建议大家可以封装成类库,单独引入。

该原理实现的也有很多不错的js类库可以使用,如LazyLoad.js,支持数组的形式引入,打开浏览器在network中可看到js是同步加载的

【XHR加载】

使用ajax方式加载

代码:

var xhr = new XMLHttpRequest;

xhr.open('get','file.js',true);

xhr.onreadystatechange = function(){

if( xhr.readyState == 4 ){

if( xhr.status >=200 && xhr.status < 300 || xhr.status == 304 ){

var script = document.createElement('script');

script.type = 'text/javascript';

script.text = xhr.responseText;

document.body.appendChild(script);

}

}

};

xhr.send(null);

8

【总结】

最好的方式还是使用动态创建script的方式加载,当动态创建script,浏览器会分配一个线程去下载src指向的资源,多个script也是同步下载的

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。