Javascript在页面加载时的执行顺序.docxVIP

Javascript在页面加载时的执行顺序.docx

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一、在HTML中嵌入Javasript的方法 直接在Javascript代码放在标记对script和/script之间 由script /标记的src属性制定外部的js文件 放在事件处理程序中,比如: p?onclick=alert(我是由onclick事件执行的Javascript)点击我/p 作为URL的主体,这个URL使用特殊的Javascript:协议,比如: a?href=javascript:alert(我是由javascript:协议执行的javascript)点击我/a 利用javascript本身的document.write()方法写入新的javascript代码 利用Ajax异步获取javascript代码,然后执行 第3种和第4种方法写入的Javascript需要触发才能执行,所以除非特别设置,否则页面加载时不会执行。 二、Javascript在页面的执行顺序 页面上的Javascript代码是HTML文档的一部分,所以Javascript在页面装载时执行的顺序就是其引入标记script /的出现顺序, script /标记里面的或者通过src引入的外部JS,都是按照其语句出现的顺序执行,而且执行过程是文档装载的一部分。 每个脚本定义的全局变量和函数,都可以被后面执行的脚本所调用。 变量的调用,必须是前面已经声明,否则获取的变量值是undefined。 script?type=text/javscrpt//![CDATA[ alert(tmp);??//输出?undefined var?tmp?=?1; alert(tmp);??//输出?1 //]]/script 同一段脚本,函数定义可以出现在函数调用的后面,但是如果是分别在两段代码,且函数调用在第一段代码中,则会报函数未定义错误。 script?type=text/javscrpt//![CDATA[ aa();????????????//浏览器报错 //]]/script script?type=text/javscrpt//![CDATA[ aa();???????????//输出?1? function?aa(){alert(1);} //]]/script document.write()会把输出写入到脚本文档所在的位置,浏览器解析完documemt.write()所在文档内容后,继续解析document.write()输出的内容,然后在继续解析HTML文档。 script?type=text/javascript//![CDATA[ ????document.write(script?type=text/javascript?src=test.js//script); ????document.write(script?type=text/javascript); ????document.write(alert(2);) ????document.write(alert(我是?+?tmpStr);); ????document.write(//script); ????//]]/script ??script?type=text/javascript//![CDATA[ ????alert(3); ????//]]/script test.js的内容是: var?tmpStr?=?1; ????alert(tmpStr); ????*?在Firefox和Opera中的弹出值的顺序是:1、2、我是1、3 ????*?在IE中弹出值的顺序是:2、1、3,同时浏览器报错:tmpStr未定义? 原因可能是IE在document.write时,并未等待加载SRC中的Javascript代码完毕后,才执行下一行,所以导致2先弹出,并且执行到document.write(’document.write(我是?+?tmpStr)’)调用tmpStr时,tmpStr并未定义,从而报错。 解决这个问题,可以利用HTML解析是解析完一个HTML标签,再执行下一个的原理,把代码拆分来实现: script?type=text/javascript//![CDATA[ ????document.write(script?type=text/javascript?src=test.js//script); ????//]]/script ??script?type=text/javascript//![CDATA[ ????document.write(script?type=text/javascript); ????document.write(alert(2);) ????document.write(alert(我是?+?tmpStr);); ????doc

文档评论(0)

185****7617 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档