Javascript应用-Js在页面中被引入的几种方法

开发 前端
javaScript是一种解释型语言,它的执行是自上而下,但是各个浏览器对于至上而下的理解是有细微差别的,而代码的上下游也就是程序流又对于程序正确至关重要。

 首先得了解有几种方法能把javaScript加入到页面中? 常见下述的前2种,其实还有更多。

[[433600]]

1.页面中直接引入外部js文件:

2.页面中直接写入 js片段:

3.在js中引入js文件(比较少用): document.write("");

注意:这时候".."必须拆成"",否则浏览器可能会把父js片段关闭掉,出错;

4.同样在js中引用其他js片段,document.write("");

你可能觉得这个并没有必要,既然已经在script中了还套一层干嘛?呵呵,怎么说也是一种写法,而且它具有其特殊的行为,稍后我们讨论到。

5.使用Ajax中的xmlHttpRequest结合eval()来引入js,我最早在Dojo的代码见到,写的详细些:

 

  1. var ajaxRequest = getXmlHttpRequest()//省去各个浏览器得到xmlHttpRequest的部门  
  2. ajaxRequest.open("GET","my.js",false);//使用xmlHttpRequest对象Get方法的同步调用  
  3. ajaxRequest.send(null);  
  4. sJsFragment = ajax.responseText;//得到字符串为js片段  
  5. eval(sJsFragment);//执行js片段 

 

注意:这里要求my.js即后来的sJsFragment内容得是非常规范的js,且没有//开头的注释,怎样检查js是否规范呢?去http://jslint.com/

6.无所不能的Dom方法,非常好用:

 

  1. var oScript = document.createElement("script");//创建一个Script元素 
  2. oScript.src = "my.js";//制定src属性  
  3. document.getElementsByTagName("head")[0].appendChild(oScript); 

 

说明:my.js的内容会在oScript加入到文档中之后获得并执行。仔细看下这段容易发现这个调用是异步的,可以在文档载入之后通过事件触发,我用它变通了一下,作为了xmlHttpRequest的Get方法在跨域取数时的替代,获得了很完美的效果,以后有机会专门写篇文。

六种不少吧,可能还会有吧,而且这几种之间还可能相互嵌套,变化无常。

其中1、2、4、6种方式引入的javaScript的执行顺序是非常自然的,随着页面的载入以及后续的事件触发,它们遵守先来后到、而其内部自上而下。

责任编辑:华轩 来源: 今日头条
相关推荐

2010-06-03 08:55:43

LINQ

2020-08-24 08:05:47

JavaScriptJavaScript 页面

2018-02-08 09:04:58

Nginx404页面方法

2020-10-16 18:35:53

JavaScript字符串正则表达式

2009-09-04 11:20:47

ASP.NET页面间值

2010-05-17 15:17:06

MySQL常用操作

2009-09-18 12:29:55

2009-12-16 09:16:53

ASP.NET页面间数

2013-08-21 11:31:21

iPhone图片方法

2010-10-26 09:23:03

Web Service

2010-04-30 16:22:07

Unix终端

2010-01-22 14:46:25

C++语言

2021-03-08 09:32:04

Python文件命令

2009-09-09 11:24:46

PHP实现MVC

2009-08-31 09:19:31

c#隐藏窗口

2021-02-26 13:20:48

Shell空行Linux

2011-06-16 10:48:33

session

2020-01-10 16:23:44

Springboot停止服务Java

2020-06-23 14:51:13

JavaScript字符字符串

2021-03-02 10:55:07

云计算自动化云应用
点赞
收藏

51CTO技术栈公众号