当前位置:首页 > 日记 > 正文

JS异步加载的三种实现方式

JS异步加载的三种实现方式

js加载的缺点:加载工具方法没必要阻塞文档,过多js加载会影响页面效率,一旦网速不好,那么整个网站将等待js加载而不进行后续渲染等工作。 有些工具方法需要按需加载,用到再加载,不用不加载,。

默认正常模式下下,JS是同步加载的,即优先加载JS,只有当JS文件下载完,dom和css才开始加载,当某些时候我们需要JS异步加载,我们可以通过以下方式来设置异步加载,不同情况下选取不同方式即可

1.defer:defer

  1. JS异步下载,dom结构解析完(标签 + 样式(内容不一定下载完))才异步执行 
  2. 仅IE能用
  3. 内部JS也能用该属性
  4. 异步加载js不允许使用document.write,因为document.write会清除文档流,js标签还未加载就会被清除
  5. document.write()可用于初始化页面

2.(h5)async:async(asynchronous) ajax(asynchronous javascript and XML)

  1. JS异步加载,加载完毕后立刻异步执行
  2. IE8及以下不兼容
  3. 内部JS不能用该属性

3.除了以上两种方法,还有一种兼容自己封装的异步加载方式,即动态添加script标签也能实现异步加载。

function asyncLoaded(url,callBack){/*url为js的链接,callBack为url的js中的函数(该函数调用应该写到匿名函数中,如function(){console.log(div.getScrollOffset())})*/  var script = document.createElement('script');  script.type = 'text/javascript';  /*if else 这几句话必须要写到这位置处,不能放最后,因为if中js加载中script.readyState存在好几种状态,  只有状态改变‘readystatechange'事件才会触发,但现在浏览器加载速度很快,当解析到该事件时JS有可能已经加载完,  所以事件根本不会触发,所以要写到前面*/  if(script.readystate){//兼容IE    script.onreadystatechange = function() {//状态改变事件才触发      if(script.readyState == 'loaded' || script.readyState == 'complete'){          callBack();        script.onreadystatechange = null;          }    }  }else{    script.onload = function(e){      callBack();    }  }      script.src = url;  document.body.appendChild(script);}

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

相关文章

JS鼠标滚动分页效果示例

JS鼠标滚动分页效果示例

鼠标,分页,示例,效果,电脑软件,首先先看问题:在开发的时候,看到这种现象 就会思考:为什么左边的数据出来比右边的慢呢?因为这里没有进行分页,左边的数据多,所以查询相对较慢。解决办法就是进行分页,但是在项目中用到的插件,不能控制样式,改变分页的…

excel函数值不可用错误怎么解决解

excel函数值不可用错误怎么解决解

函数,错误,方法,解决方法,不可用,  excel的使用过程中经常会出现一些错误,那么值不可用错误就是其中的一种,很常见,那怎么解决这个问题呢?一般情况下,一部分原因是引用的数据是错的,一部分是因为公式的问题,下面给大家分享excel函数值不可用错…

微信小程序实现倒计时60s获取验证

微信小程序实现倒计时60s获取验证

验证码,倒计时,程序,电脑软件,微信小,本文实例为大家分享了微信小程序倒计时获取验证码的具体代码,供大家参考,具体内容如下1、工具类(引用微信小程序提供的工具类)countdown.jsclass Countdown {constructor(options = {}) {Object.assign(thi…

YII2自动登录Cookie总是失效的解决

YII2自动登录Cookie总是失效的解决

失效,解决方法,自动登录,电脑软件,Cookie,前言最近做Yii2自动登录功能,发现即使开启了Yii2的自动登录配置功能,浏览器关闭后,再次打开浏览器还是处于非登录状态。网上查询资料基本没有相同情况。查询登录源码:protected function sendIdentityC…

PS怎么制作清明节字体海报?

PS怎么制作清明节字体海报?

字体,清明节,海报,电脑软件,PS,清明节到了,各路商家或宣传都想设计一个美美的清明节海报,本经验将介绍如何设计一个清明节海报,希望能够帮助读者。软件名称:Adobe Photoshop 8.0 中文完整绿色破解版软件大小:150.1MB更新时间:2015-11-041、【打开…

怎么去除PPT中单击此处添加文标题

怎么去除PPT中单击此处添加文标题

单击,方法,教程,步骤,标题,  对于一些经常用PPT做汇报或者开会的白领们,经常会遇到这样的问题,自己辛辛苦苦做好的PPT,却无端冒出了许多“单击此处添加标题”、“单击此处添加文本”等内容,那么下面小编就教你怎么去除这…

简单实现JavaScript弹幕效果

简单实现JavaScript弹幕效果

简单实现,效果,弹幕,电脑软件,JavaScript,不知大家有没有感受到,弹幕又是另一出好戏!! 不过我个人还是比较排斥看电视的时候被出来的弹幕打扰。今天我们来写一个简单的弹幕。简单到什么程度呢?看下效果: 由图可以看出,我们的呆毛html结构确实是非…

JS操作时间 - UNIX时间戳的简单介

JS操作时间 - UNIX时间戳的简单介

时间戳,操作,必看,简单,时间,准备知识GMT(Greenwich Mean Time) - 格林尼治时间。UTC(Universal Time Code) - 国际协调时间。PST(Pacific Standard Time,太平洋标准时间)。UTC出现的比GMT时间晚,可以认为UTC时间更加精确,不过它们之间只相差几…

ps怎么在岩石上刻文字? ps岩石刻字

ps怎么在岩石上刻文字? ps岩石刻字

教程,文字,岩石,上刻,电脑软件,ps中想要在岩石中雕刻文字,该怎么雕刻呢?下面我们就来看看详细的教程。软件名称:Adobe Photoshop 8.0 中文完整绿色破解版软件大小:150.1MB更新时间:2015-11-041、首先启动Photoshop cs5,执行文件-打开命令,打开一副…

[js高手之路]单例模式实现模态框的

[js高手之路]单例模式实现模态框的

模态框,单例模式,之路,示例,高手,什么是单例呢?单,就是一个的意思。例:就是实例化出来的对象,那合在一起就是保证一个构造函数只能new出一个实例,为什么要学习单例模式呢?或者说单例模式有哪些常见的应用场景.它的使用还是很广泛,比如:弹出一个模态…

ajax异步请求刷新

ajax异步请求刷新

刷新,异步请求,电脑软件,ajax,在网站刷新的方法中,ajax刷新是一种用户体验良好的刷新方式,在结合ssh等流行的框架!最为常用了!下面就是常用一个ajax刷新表单的一个demo.$(document).ready(function () { testchaxun(); setInterval("testch…

JS设置CSS样式的方式汇总

JS设置CSS样式的方式汇总

设置,样式,方式,电脑软件,JS,1. 直接设置style的属性 某些情况用这个设置 !important值无效如果属性有'-‘号,就写成驼峰的形式(如textAlign) 如果想保留 - 号,就中括号的形式 element.style[‘text-align'] = ‘100px';element.style.he…