JS脚本defer的作用示例介绍


Posted in Javascript onJanuary 02, 2014
<script src="../cgi-bin/delscript.js" defer></script> 
中的defer作用是文档加载完毕了再执行脚本,这样回避免找不到对象的问题---有点问题 
<button id="myButton" onclick="alert('ok')">test</button> 
<script> 
myButton.click(); 
</script> 
<script> 
myButton.click(); 
</script> <button id="myButton" onclick="alert('ok')">test</button> 
<script defer> 
function document.body.onload() { 
alert(document.body.offsetHeight); 
} 
</script>

加上 defer 等于在页面完全在入后再执行,相当于 window.onload ,但应用上比 window.onload 更灵活!

defer是脚本程序强大功能中的一个“无名英雄”。它告诉浏览器Script段包含了无需立即执行的代码,并且,与SRC属性联合使用,它还可以使这些脚本在后台被下载,前台的内容则正常显示给用户。
--但是 文档加载完毕了再执行脚本

最后请注意两点:

1、不要在defer型的脚本程序段中调用document.write命令,因为document.write将产生直接输出效果。
2、而且,不要在defer型脚本程序段中包括任何立即执行脚本要使用的全局变量或者函数。

一个常用的优化性能的方法是:当脚本不需要立即运行时,在<SCRIPT>标签中设置“defer”属性。 (立即脚本没有被包含在一个function块中,因此会在加载过程中执行。) 设置“defer”属性后,IE就不必等待该脚本装载和执行完毕。这样页面加载会更快。一般来说,这也表明立即脚本最好放在function块中,并在document或者body对象的onload 句柄中处理该函数。在有一些脚本需要依赖用户操作而执行时----例如点击按钮,或者移动鼠标到某个区域----使用该属性非常有用。但当有一些脚本需要在页面加载过程中或加载完成后执行,使用defer属性得到的好处就不太大。

都是defer惹的祸,这两天网站查看全文出错的原因

<p style='line-height: 150%;text-indent: 15pt;'>上周末,本站投放了Google广告,当时为了防止广告的投入延长页面导入的时间,修改了下Google Ad代码,<script>使用了defer延迟导入广告,我一直使用的是FireFox浏览器,一直没发现有问题,今天,有朋友上本站查资料,她用的是Maxthon,告诉我一查看文章,页面就一闪就过去了,这才知道有问题,我说这两天这么网站的访问一直在掉呢,一查原因,才发现是defer的原因,因为在Firfox中defer好象是失效的,页面实际还是原始内容一起载入了,而在IE中,由于延后载入脚本,对于Google Ad脚本来说,其使用的是Document.write的写入方法,并且因为defer的原因,Google AD的脚本检测为iframe了,所以当获取到Google 广告的实际内容的时候就把整个页面给覆盖了,也就造成了查看全文一闪而过的现象。</p>

<p style='line-height: 150%;text-indent: 15pt;'>这都怪我修改了代码没这么测试,以后不管改什么都需要在IE和FireFox中都测试通过才可以,对于这两天造成大家的访问困难致以最最真挚的道歉!</p>
<p style='line-height: 150%;text-indent: 15pt;'>另:推荐大家使用FireFox访问本站,访问和解析速度以及页面布局的一致性都更好!</p>

Javascript 相关文章推荐
文本加密解密
Jun 23 Javascript
js采用map取到id集合组并且实现点击一行选中一行
Dec 16 Javascript
js获取数组的最后一个元素
Apr 14 Javascript
41个Web开发者必须收藏的JavaScript实用技巧
Jul 22 Javascript
微信小程序 wx.request(OBJECT)发起请求详解
Oct 13 Javascript
js代码实现下拉菜单【推荐】
Dec 15 Javascript
理解AngularJs篇:30分钟快速掌握AngularJs
Dec 23 Javascript
详解Vue2.0里过滤器容易踩到的坑
Jun 01 Javascript
Vue 父子组件的数据传递、修改和更新方法
Mar 01 Javascript
javascript变量提升和闭包理解
Mar 12 Javascript
使用vuex缓存数据并优化自己的vuex-cache
May 30 Javascript
详解vantUI框架在vue项目中的应用踩坑
Dec 06 Javascript
Javascript中常见的校验如域名、手机、邮箱等等
Jan 02 #Javascript
JavaScript四种调用模式和this示例介绍
Jan 02 #Javascript
ParseInt函数参数设置介绍
Jan 02 #Javascript
JS中Date日期函数中的参数使用介绍
Jan 02 #Javascript
JavaScript中Math对象方法使用概述
Jan 02 #Javascript
javascript数组快速打乱重排的方法
Jan 02 #Javascript
利用进制转换压缩数字函数分享
Jan 02 #Javascript
You might like
UCenter中的一个可逆加密函数authcode函数代码
2010/07/20 PHP
php设计模式 Singleton(单例模式)
2011/06/26 PHP
PHP中数组定义的几种方法
2013/09/01 PHP
php实现TCP端口检测的方法
2015/04/01 PHP
thinkPHP线上自动加载异常与修复方法实例分析
2016/12/01 PHP
PHP 观察者模式深入理解与应用分析
2019/09/25 PHP
phpcmsv9.0任意文件上传漏洞解析
2020/10/20 PHP
简单的无缝滚动程序-仅几行代码
2007/05/08 Javascript
javascript getElementsByClassName 和js取地址栏参数
2010/01/02 Javascript
圣诞节Merry Christmas给博客添加浪漫的下雪效果基于jquery实现
2012/12/27 Javascript
对jQuery的事件绑定的一些思考(补充)
2013/04/20 Javascript
Javascript拓展String方法小结
2013/07/08 Javascript
理解jquery事件冒泡
2016/01/03 Javascript
js拼接html字符串的注意事项
2016/10/13 Javascript
JavaScript实现垂直向上无缝滚动特效代码
2016/11/23 Javascript
解决Extjs下拉框不显示的问题
2017/06/21 Javascript
JS 中document.write()的用法和清空的原因浅析
2017/12/04 Javascript
vue-cli3 项目从搭建优化到docker部署的方法
2019/01/28 Javascript
ES6 class的应用实例分析
2019/06/27 Javascript
原生js实现表格循环滚动
2020/11/24 Javascript
python实现在sqlite动态创建表的方法
2015/05/08 Python
浅析Python中的for 循环
2016/06/09 Python
Swift 3.0在集合类数据结构上的一些新变化总结
2016/07/11 Python
python3+PyQt5实现自定义分数滑块部件
2018/04/24 Python
Python if语句知识点用法总结
2018/06/10 Python
15行Python代码实现网易云热门歌单实例教程
2019/03/10 Python
Python/Django后端使用PIL Image生成头像缩略图
2019/04/30 Python
Python Pandas分组聚合的实现方法
2019/07/02 Python
远程部署工具Fabric详解(支持Python3)
2019/07/04 Python
利用matplotlib实现根据实时数据动态更新图形
2019/12/13 Python
基于matplotlib xticks用法详解
2020/04/16 Python
文秘专业毕业生就业推荐信
2013/11/08 职场文书
《周恩来的四个昼夜》观后思想汇报范文两篇
2014/09/10 职场文书
2014年庆祝国庆65周年演讲稿
2014/09/21 职场文书
早读课迟到检讨书
2014/09/25 职场文书
婚礼嘉宾致辞
2015/07/28 职场文书