最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

javascript按顺序加载运行js方法_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 20:10:45
文档

javascript按顺序加载运行js方法_javascript技巧

javascript按顺序加载运行js方法_javascript技巧:本篇文章主要教给大家如何在javascript中动态加载按顺序加载运行javascript的方法以及实现代码,对javascript感兴趣的朋友参考学习下吧。如何你的 script 上没有任何 异步,阻塞 等标注:浏览器会异步加载 javascript 文件,但是会按照引用文件中的书写
推荐度:
导读javascript按顺序加载运行js方法_javascript技巧:本篇文章主要教给大家如何在javascript中动态加载按顺序加载运行javascript的方法以及实现代码,对javascript感兴趣的朋友参考学习下吧。如何你的 script 上没有任何 异步,阻塞 等标注:浏览器会异步加载 javascript 文件,但是会按照引用文件中的书写

本篇文章主要教给大家如何在javascript中动态加载按顺序加载运行javascript的方法以及实现代码,对javascript感兴趣的朋友参考学习下吧。

如何你的 script 上没有任何 异步,阻塞 等标注:

浏览器会异步加载 javascript 文件,但是会按照引用文件中的书写顺序从上到下执行解析 javascript

Defer属性标记

defer是html4.0中定义的,该属性使得浏览器能延迟脚本的执行,等文档完成解析完成后会按照他们在文档出现顺序再去下载解析。

也就是说defer属性的 script 就类似于将 script 放在body中的加载 效果一致.

但是defer属性在各个浏览器中支持程度有点不同,就是说,有的浏览器不完全支持.

Async属性标注

async是HTML5新增的属性, 大部分先进支持该属性的.
该属性的作用是让脚本能异步加载,也就是说当浏览器遇到async属性的 script 时浏览器加载css一样是异步加载的

javascript 动态加载js文件

原理很简单,创建一个 script 节点,给节点赋予 script 的属性,然后 append 到 dom 的 head 标签中.

function loadJS(url){
 var Script = document.createElement('script');
 Script.setAttribute('src', url);
 Script.setAttribute('type', 'text/javascript');
 document.body.appendChild(Script);
 return Script;
}

如果我们同时加载多个 javascript 文件

loadJS('a.js');
loadJS('b.js');

上面的效果是,a.js 和 b.js 文件会被异步同时加载,如果 b.js 文件比 a.js 文件小的话,很可能先加载执行 b.js ,完全不会按照书写结果加载执行

所以,如果你的 b.js 文件有依赖 a.js 的东西,那么就会报错,因为解释执行b.js 的时候,a.js 还在加载中.

控制javascript 加载执行顺序

我们对代码做如下改进

function loadJS(url, success) {
 var domScript = document.createElement('script');
 domScript.src = url;
 success = success || function () {
 };
 domScript.onload = domScript.onreadystatechange = function () {
 if (!this.readyState || 'loaded' === this.readyState || 'complete' === this.readyState) {
 success();
 this.onload = this.onreadystatechange = null;
 this.parentNode.removeChild(this);
 }
 }
 document.getElementsByTagName('head')[0].appendChild(domScript);
 }

通过script 节点上的 onload 和 onreadystatechange 属性来监听节点 src 是否加载完成

如果成功,调用回调函数 success();

我们在调用此方法的时候,可以通过 loadJS 回调函数来知道当前节点已经加载完成,然后在回调函数里继续加载其他 script 文件

loadJS(getUrl('a.js'), function () {
 loadJS(getUrl('b.js'), function () {
 console.log('a.js ,b.js 加载完成');
 });
});

通过上面的方法加载,是一种同步阻塞加载, a.js 加载完成后才会加载执行 b.js 文件.

如果你的 javascript 文件没有相互依赖关系,不要使用这种方法.

相关推荐:

html、css以及js文件加载顺序及执行情况

jquery popupDialog 使用 加载jsp页面的方法

动态加载js的几种方法_javascript技巧

文档

javascript按顺序加载运行js方法_javascript技巧

javascript按顺序加载运行js方法_javascript技巧:本篇文章主要教给大家如何在javascript中动态加载按顺序加载运行javascript的方法以及实现代码,对javascript感兴趣的朋友参考学习下吧。如何你的 script 上没有任何 异步,阻塞 等标注:浏览器会异步加载 javascript 文件,但是会按照引用文件中的书写
推荐度:
标签: 加载 方法 js
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top