异步加载JS的方法。

默认情况javascript是同步加载的,也就是javascript的加载时阻塞的,后面的元素要等待javascript加载完毕后才能进行再加载,对于一些意义不是很大的javascript,如果放在页头会导致加载很慢的话,是会严重影响用户体验的。 所以,那么有些不涉及dom操作的脚本可以延迟加载。

1.使用<script>标签的defer属性。

如:<script type="text/javascript" src="example.js" defer="defer"></script>。W3C 说进IE支持该属性。

 

2.HTML5的async属性。

async属性仅适合外部脚本。

 

3.动态创建<script>标签。

 1 <script>
 2     /*
 3         这里是必须要先加载的代码
 4     */
 5     var script = document.createElement('script');
 6     script.type = 'text/javascript';
 7     script.src = 'script/example.js';
 8     var elem = document.getElementsByTagName('script')[0];
 9     elem.parentNode.insertBefore(script,elem);
10 </script>

 

4.利用ajax异步加载。

原理是利用ajax通过responseText获得脚本内容,然后同伙eval()来运行。

 

5.异步iframe,这个自己还不大不理解,先记录。

转载于:https://www.cnblogs.com/SKLthegoodman/p/3614887.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值