JavaScript 全面解析各种浏览器网页中的JS 执行
来源:互联网 发布:怎样成为一个网络作家 编辑:程序博客网 时间:2024/06/05 00:27
我们知道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)
详细出处参考:http://www.jb51.net/article/17261.htm
- JavaScript 全面解析各种浏览器网页中的JS 执行
- JavaScript 全面解析各种浏览器网页中的JS 执行顺序
- JavaScript:全面解析各种浏览器网页中的JS代码的执行顺序
- JavaScript:全面解析各种浏览器网页中的JS代码的执行顺序
- 全面解析javascript事件流模型以及各事件流模型在浏览器中的兼容性情况
- 通过实例全面解析JS中的This
- 全面解析JS中的this机制
- 通过JS解析手机浏览器UA标志中的各种设备信息
- JS获取浏览器中的各种宽高值
- js获取网页中的各种高度
- js获取浏览器大小以及网页大小的各种方式
- 使用HtmlUnit模拟浏览器执行JS来获取网页内容
- javascript在浏览器中的解析次序
- 深入解析JavaScript中的立即执行函数
- javascript的加载、解析、执行对浏览器渲染的影响
- 全面解析js中的数据类型与类型转换
- JavaScript判断各种浏览器
- javascript 识别各种浏览器
- 感谢原帖的作者(asterisk不能正常显示来电号码)
- 理解JS脚本执行的过程
- 日常生存自救手册视频总结09_山地骑车事故_遭遇追袭
- 在线工具--把C#代码、VB.NET代码 互转
- 浅谈Oracle中大数据量表的管理
- JavaScript 全面解析各种浏览器网页中的JS 执行
- DB2和Oracle的并发控制(锁)比较
- 单向链表实现源代码
- js function
- HTTP响应代码(Response Status Code)中文详解
- 有效创建oracle dblink 的两种方式
- win32系统默认环境变量
- Ie和firefox的Js区别
- TO_LOB函数