JavaScript 全面解析各种浏览器网页中的JS 执行顺序


Posted in Javascript onFebruary 17, 2009

我们知道javaScript是一种解释型语言,他的执行是自上而下,但是各个浏览器对于至上而下的理解是有细微差别的,而代码的上下游也就是程序流又对于程序正确至关重要,所以我觉得有必要深入理解多个js块儿的执行顺序。
首先得知道有多少方法能把javaScript加入到页面中呢?常见下述的前2种,其实还有更多。
1.页面中直接引入外部js文件:<script src="my.js"></script>
2.页面中直接写如js片段<script>alert(1)</script>
3.在js中引入js文件document.write("<scr"+"ipt src='my.js'></scr"+"ipt>");
注意:这时候"..</script>"必须拆成"</scr"+"ipt>",否则浏览器可能会把父js片段关闭掉,出错;
4.同样在js中引用其他js片段,document.write("<scr"+"ipt>alert(1)</scr"+"ipt>");
你可能觉得这个并没有必要,既然已经在script中了还套一层干嘛?呵呵,怎么说也是一种写法,而且它具有其特殊的行为,稍后我们讨论到。
5.使用Ajax中的xmlHttpRequest结合eval()来引入js,我最早在Dojo的代码见到,写的详细些:
var ajaxRequest = getXmlHttpRequest()//省去各个浏览器得到xmlHttpRequest的部门
ajaxRequest.open("GET","my.js",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";//制定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)

Javascript 相关文章推荐
JQuery从头学起第一讲
Jul 04 Javascript
jquery监控数据是否变化(修正版)
Apr 12 Javascript
jquery实现图片渐变切换兼容ie6/Chrome/Firefox
Aug 02 Javascript
jQuery实现点击文本框弹出热门标签的提示效果
Nov 17 Javascript
JS简单操作select和dropdownlist实例
Nov 26 Javascript
javascript实现简单加载随机色方块
Dec 25 Javascript
Bootstrap实现弹性搜索框
Jul 11 Javascript
BootStrap中
Dec 10 Javascript
jQuery实现鼠标滑过预览图片大图效果的方法
Apr 26 jQuery
vue 中引用gojs绘制E-R图的方法示例
Aug 24 Javascript
Vue实现页面添加水印功能
Nov 09 Javascript
webpack的 rquire.context用法实现工程自动化的方法
Feb 07 Javascript
JSON扫盲帖 JSON.as类教程
Feb 16 #Javascript
动态为事件添加js代码示例
Feb 15 #Javascript
Ext JS Grid在IE6 下宽度的问题解决方法
Feb 15 #Javascript
javascript Ext JS 状态默认存储时间
Feb 15 #Javascript
Javascript 获取链接(url)参数的方法
Feb 15 #Javascript
JavaScript 获得选中文本内容的方法
Feb 15 #Javascript
检测是否已安装 .NET Framework 3.5的js脚本
Feb 14 #Javascript
You might like
PHP中动态HTML的输出技术
2006/10/09 PHP
php运行出现Call to undefined function curl_init()的解决方法
2010/11/02 PHP
php pdo oracle中文乱码的快速解决方法
2016/05/16 PHP
PHP 文件上传限制问题
2019/09/01 PHP
laravel-admin的多级联动方法
2019/09/30 PHP
JavaScript CSS修改学习第五章 给“上传”添加样式
2010/02/19 Javascript
jquery ajax执行后台方法
2010/03/18 Javascript
jquery判断字符输入个数(数字英文长度记为1,中文记为2,超过长度自动截取)
2010/10/15 Javascript
JavaScript对象之间的转换 jQuery对象和原声DOM
2011/03/07 Javascript
多浏览器兼容性比较好的复制到剪贴板的js代码
2011/10/09 Javascript
js自定义事件及事件交互原理概述(二)
2013/02/01 Javascript
jQuery实现个性翻牌效果导航菜单的方法
2015/03/09 Javascript
jQuery实现仿美橙互联两级导航菜单效果完整实例
2015/09/17 Javascript
jQuery实现带渐显效果的人物多级关系图代码
2015/10/16 Javascript
利用Angularjs和Bootstrap前端开发案例实战
2016/08/27 Javascript
Sequelize中用group by进行分组聚合查询
2016/12/12 Javascript
bootstrapValidator 重新启用提交按钮的方法
2017/02/20 Javascript
深究AngularJS如何获取input的焦点(自定义指令)
2017/06/12 Javascript
vue如何从接口请求数据
2017/06/22 Javascript
基于JavaScript实现数码时钟效果
2020/03/30 Javascript
小程序:授权、登录、session_key、unionId的详解
2019/05/15 Javascript
vue滚动插件better-scroll使用详解
2019/10/18 Javascript
实践Python的爬虫框架Scrapy来抓取豆瓣电影TOP250
2016/01/20 Python
Scrapy的简单使用教程
2017/10/24 Python
python监控键盘输入实例代码
2018/02/09 Python
详解PyTorch批训练及优化器比较
2018/04/28 Python
在Python 字典中一键对应多个值的实例
2019/02/03 Python
Python自动巡检H3C交换机实现过程解析
2020/08/14 Python
属性与 @property 方法让你的python更高效
2020/09/21 Python
eDreams澳大利亚:预订机票、酒店和度假产品
2017/04/19 全球购物
购房个人委托书范本
2014/10/11 职场文书
《女娲补天》读后感5篇
2019/12/31 职场文书
浅谈golang package中init方法的多处定义及运行顺序问题
2021/05/06 Golang
python基础学习之生成器与文件系统知识总结
2021/05/25 Python
HTML中的表单元素介绍
2022/02/28 HTML / CSS
戴尔Win11系统no bootable devices found解决教程
2022/09/23 数码科技