JS 动态加载js文件和css文件 同步/异步的两种简单
网络编程 2021-07-04 20:00www.168986.cn编程入门
狼蚁网站SEO优化长沙网络推广就为大家带来一篇JS 动态加载js文件和css文件 同步/异步的两种简单方式。长沙网络推广觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
/动态添加js或css,URL:文件路径,FileType文件类型(js/css)/ function AddJsFiles(URL,FileType){ var oHead = document.getElementsByTagName('HEAD').item(0); var addheadfile; if(FileType=="js"){ addheadfile= document.createElement("script"); addheadfile.type = "text/javascript"; addheadfile.src=URL; }else{ addheadfile= document.createElement("link"); addheadfile.type = "text/css"; addheadfile.rel="stylesheet"; addheadfile.rev = "stylesheet"; addheadfile.media = "screen"; addheadfile.href=URL; } oHead.appendChild( addheadfile); }
/方法调用/ AddJsFiles("js/index.js","js"); AddJsFiles("css/index.css","css");
经测试发现以上方法进行文件加载时,文件是异步加载的,这样就可能导致加载文件后立即使用文件中的方法或变量会产生错误的情况,
所以以下采用同步加载的方法,当文件加载完成后再去执行相应的代码或方法
/5.加载文件/ / 已加载文件缓存列表,用于判断文件是否已加载过,若已加载则不加载/ var classcodes =[]; window.Import={ /加载一批文件,_files:文件路径数组,可包括js,css,less文件,sues:加载成功回调函数/ LoadFileList:function(_files,sues){ var FileArray=[]; if(typeof _files==="object"){ FileArray=_files; }else{ /如果文件列表是字符串,则用,切分成数组/ if(typeof _files==="string"){ FileArray=_files.split(","); } } if(FileArray!=null && FileArray.length>0){ var LoadedCount=0; for(var i=0;i< FileArray.length;i++){ loadFile(FileArray[i],function(){ LoadedCount++; if(LoadedCount==FileArray.length){ sues(); } }) } } /加载JS文件,url:文件路径,suess:加载成功回调函数/ function loadFile(url, suess) { if (!FileIsExt(classcodes,url)) { var ThisType=GetFileType(url); var fileObj=null; if(ThisType==".js"){ fileObj=document.createElement('script'); fileObj.src = url; }else if(ThisType==".css"){ fileObj=document.createElement('link'); fileObj.href = url; fileObj.type = "text/css"; fileObj.rel="stylesheet"; }else if(ThisType==".less"){ fileObj=document.createElement('link'); fileObj.href = url; fileObj.type = "text/css"; fileObj.rel="stylesheet/less"; } suess = suess || function(){}; fileObj.onload = fileObj.onreadystatechange = function() { if (!this.readyState || 'loaded' === this.readyState || 'plete' === this.readyState) { suess(); classcodes.push(url) } } document.getElementsByTagName('head')[0].appendChild(fileObj); }else{ suess(); } } /获取文件类型,后缀名,小写/ function GetFileType(url){ if(url!=null && url.length>0){ return url.substr(url.lastIndexOf(".")).toLowerCase(); } return ""; } /文件是否已加载/ function FileIsExt(FileArray,_url){ if(FileArray!=null && FileArray.length>0){ var len =FileArray.length; for (var i = 0; i < len; i++) { if (FileArray[i] ==_url) { return true; } } } return false; } } } var FilesArray=["js/index.js","js/ClassInherit1.js","js/highcharts_2.21.js","css/index.css"]; Import.LoadFileList(FilesArray,function(){ /这里写加载完成后需要执行的代码或方法/ });
以上就是长沙网络推广为大家带来的JS 动态加载js文件和css文件 同步/异步的两种简单方式的全部内容了,希望对大家有所帮助,多多支持狼蚁SEO~
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程