博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于动态加载js
阅读量:6412 次
发布时间:2019-06-23

本文共 1595 字,大约阅读时间需要 5 分钟。

已知一个需要动态加载的js的文件路径数组,动态加载数组里面所有的js文件。

加载分两种情况:

1. 并行加载,不管js的执行顺序。

2. 串行加载,即一个一个加载,上一个加载完再加载下一个,直到最后。

 

动态加载js一般都是动态创建一个script,

解决第一种情况:

function loadExternalFile(src,parentElement,tagName){        var elem = document.createElement(tagName);        if(tagName==='link'){            elem.setAttribute('href',src);            elem.setAttribute('rel','stylesheet');        }else if(tagName==='script'){            elem.setAttribute('src',src);            elem.setAttribute('type','text/javascript');        }        parentElement.appendChild(elem);    }

解决第二种情况:

function loadScript(url, parentEle, tagName, callback){        var ele = document.createElement(tagName);        var typeProp = tagName==='script'?'type':'rel';        ele[typeProp] = tagName==='script'?'text/javascript':'stylesheet';        if (ele.readyState){  //IE            ele.onreadystatechange = function(){                if (ele.readyState == "loaded" ||                        ele.readyState == "complete"){                    ele.onreadystatechange = null;                    callback();                }            };        } else {  //Others            ele.onload = function(){                callback();            };        }        typeProp = tagName==='script'?'src':'href';        ele[typeProp] = url;        parentEle.appendChild(ele);    }

第一种情况用法非常简单就不说了。

第二种用法其实也不难:

假设:scripts数组:['a.js','b.js','c.js']

var i=0;var n=scripts.length;loadScript(scripts[i],parentEle,'script',loadScriptComplete);function loadScriptComplete(){     i++;     if(i

上面的两种方法其实也适用于加载css文件。

 

转载于:https://www.cnblogs.com/ywxgod/p/4196896.html

你可能感兴趣的文章
【Vue】vue.js常用指令
查看>>
NFS学习
查看>>
MySql常用命令总结
查看>>
又一年...
查看>>
Linux VFS
查看>>
ext不能选中复制属性_如何实现Extjs的grid单元格只让选择(即可以复制单元格内容)但是不让修改?...
查看>>
python中print的作用*8、不能+8_在 Python 3.x 中语句 print(*[1,2,3]) 不能正确执行。 (1.0分)_学小易找答案...
查看>>
python 生成html代码_使用Python Markdown 生成 html
查看>>
axure如何导出原件_Axure 教程:轻松导出图标字体所有图标
查看>>
laravel input值必须不等于0_框架不提供,动手造一个:Laravel表单验证自定义用法...
查看>>
cad填充图案乱理石_太快了吧!原来大神是这样用CAD图案填充的
查看>>
activator.createinstance 需要垃圾回收么_在垃圾回收器中有哪几种判断是否需要被回收的方法...
查看>>
rocketmq 消息指定_RocketMQ入坑系列(一)角色介绍及基本使用
查看>>
redis zset转set 反序列化失败_掌握好Redis的数据类型,面试心里有底了
查看>>
p图软件pⅰc_娱乐圈最塑料的夫妻,P图永远只P自己,太精彩了吧!
查看>>
怎么判断冠词用a还是an_葡语干货 | 葡萄牙语冠词用法整理大全
查看>>
js传参不是数字_JS的Reflect学习和应用
查看>>
三个不等_数学一轮复习05,从函数观点看方程与不等式,记住口诀与联系
查看>>
卡尺测量的最小范围_汽车维修工具-测量用具
查看>>
网优5g前景_5G网络优化师前景怎么样?
查看>>