JavaScript全面解析各种浏览器网页中的JS执行顺序_javascript技巧
作者:c6643e7f36_253 | 来源:互联网 | 2018-05-14 09:58
近来我通过一些测试以全面的解析网页在各种浏览器中的JavaScript代码的执行顺序,在这儿做个记录。
我们知道Javascript是一种解释型语言,他的执行是自上而下,但是各个浏览器对于至上而下的理解是有细微差别的,而代码的上下游也就是程序流又对于程序正确至关重要,所以我觉得有必要深入理解多个js块儿的执行顺序。 首先得知道有多少方法能把Javascript加入到页面中呢?常见下述的前2种,其实还有更多。 1.页面中直接引入外部js文件: 2.页面中直接写如js片段 3.在js中引入js文件document.write(" "); 注意:这时候".."必须拆成"",否则浏览器可能会把父js片段关闭掉,出错; 4.同样在js中引用其他js片段,document.write("alert(1) "); 你可能觉得这个并没有必要,既然已经在script中了还套一层干嘛?呵呵,怎么说也是一种写法,而且它具有其特殊的行为,稍后我们讨论到。 5.使用Ajax中的xmlHttpRequest结合eval()来引入js,我最早在Dojo的代码见到,写的详细些: var ajaxRequest = getXmlHttpRequest()//省去各个浏览器得到xmlHttpRequest的部门 ajaxRequest.open("GET","my.js?6.1.3",false);//使用xmlHttpRequest对象Get方法的同步调用 ajaxRequest.send(null); sJsFragment = ajax.responseText;//得到字符串为js片段 eval(sJsFragment);//执行js片段 注意:这里要求my.js即后来的sJsFragment内容得是非常规范的js,切没有//开头的注释,怎样检查js是否规范呢?去http://jslint.com/ 6.无所不能的Dom方法,这个我最早在Yahoo的前端代码中见到,非常厉害,也写的详细些: var oScript = document.createElement("script");//创建一个Script元素 oScript.src = "my.js?6.1.3";//制定src属性 document.getElementsByTagName("head")[0].appendChild(oScript); 说明:my.js的内容会在oScript加入到文档中之后获得并执行。仔细看下这段容易发现这个调用是异步的,可以在文档载入之后通过事件触发,我用它变通了一下,作为了xmlHttpRequest的Get方法在跨域取数时的替代,获得了很完美的效果,以后有机会专门写篇文。 六种不少吧,可能还会有吧,而且这几种之间还可能相互嵌套,变化无常。 其中1、2、4、6种方式引入的Javascript的执行顺序是非常自然的,随着页面的载入以及后续的事件触发,它们遵守先来后到、而其内部自上而下。 我们主要关注的是第3、4种引入js方法带来的问题(转帖请注明出处:http://blog.csdn.net/lenel)
推荐阅读
本文讨论了如何在codeigniter中识别来自angularjs的请求,并提供了两种方法的代码示例。作者尝试了$this->input->is_ajax_request()和自定义函数is_ajax(),但都没有成功。最后,作者展示了一个ajax请求的示例代码。 ...
[详细]
蜡笔小新 2023-12-12 12:37:07
本文介绍了选择网络请求模块axios的原因,以及axios框架的基本使用和封装方法。包括发送并发请求的演示,全局配置的设置,创建axios实例的方法,拦截器的使用,以及如何封装和请求响应劫持等内容。 ...
[详细]
蜡笔小新 2023-12-12 10:16:43
本文介绍了使用FormData对象上传文件同时附带其他参数的方法。通过创建一个表单,将文件和参数添加到FormData对象中,然后使用ajax发送POST请求进行文件上传。在发送请求时,需要设置processData为false,告诉jquery不要处理发送的数据;同时设置contentType为false,告诉jquery不要设置content-Type请求头。 ...
[详细]
蜡笔小新 2023-12-09 19:51:18
蜡笔小新 2023-10-17 15:39:31
asp.net(vb脚本)如何获取xml的节点值?xmlversion1.0encodingutf-8?rootimageimagemenusmenuurl#frame_paren ...
[详细]
蜡笔小新 2023-10-17 12:13:19
1、概述首先和大家一起回顾一下Java消息服务,在我之前的博客《Java消息队列-JMS概述》中,我为大家分析了:然后在另一篇博客《Java消息队列-ActiveMq实战》中 ...
[详细]
蜡笔小新 2023-10-17 10:34:08
本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ...
[详细]
蜡笔小新 2023-12-14 14:25:33
本文讲述了如何通过代码在Android中更改Recycler视图项的背景颜色。通过在onBindViewHolder方法中设置条件判断,可以实现根据条件改变背景颜色的效果。同时,还介绍了如何修改底部边框颜色以及提供了RecyclerView Fragment layout.xml和项目布局文件的示例代码。 ...
[详细]
蜡笔小新 2023-12-14 12:45:01
本文介绍了如何突破MIUI14的限制,实现自定义胶囊图标和大图标样式,并支持任意APP。需要一定的动手能力和主题设计师账号权限或者会主题pojie。详细步骤包括应用包名获取、素材制作和封包获取等。 ...
[详细]
蜡笔小新 2023-12-12 12:07:16
本文介绍了搭建iOS超签签名服务器的原因和优势,包括不掉签、用户可以直接安装不需要信任、体验好等。同时也提到了超签的劣势,即一个证书只能安装100个,成本较高。文章还详细介绍了超签的实现原理,包括用户请求服务器安装mobileconfig文件、服务器调用苹果接口添加udid等步骤。最后,还提到了生成mobileconfig文件和导出AppleWorldwideDeveloperRelationsCertificationAuthority证书的方法。 ...
[详细]
蜡笔小新 2023-12-11 20:23:23
本文介绍了在Mac上安装Xamarin并使用Windows上的VS开发iOS app的方法,包括所需的安装环境和软件,以及使用Xamarin.iOS进行开发的步骤。通过这种方法,即使没有Mac或者安装苹果系统,程序员们也能轻松开发iOS app。 ...
[详细]
蜡笔小新 2023-12-11 19:13:35
本文讨论了如何使用Web.Config进行自定义配置节的配置转换。作者提到,他将msbuild设置为详细模式,但转换却忽略了带有替换转换的自定义部分的存在。 ...
[详细]
蜡笔小新 2023-12-11 17:54:55
蜡笔小新 2023-10-17 11:40:18
/这个是全局的ajax请求头设置,所有的ajax请求都会加上这个请求头 ...
[详细]
蜡笔小新 2023-10-17 09:23:24
请教大神一个问题。是这样的,有一个js文件,然后里面有异步的ajax请求,需要把请求结果赋值给一个变量来导出,用export,但是由于ajax请求是异步的,所以expo ...
[详细]
蜡笔小新 2023-10-16 21:20:21
c6643e7f36_253
这个家伙很懒,什么也没留下!