JavaScript高级程序第二章script元素

红宝书值得多读几遍。 

  • <script>元素

作用:向HTML页面中插入JavaScript的主要方法,就是使用<script>元素。

它的属性:

  • async:可选。表示应该立即下载脚本,但不应该妨碍页面中的其他操作,比如下载其他资源或等待加载其他脚本。只对外部脚本文件有效。
  • charset:可选。表示通过src属性指定的代码的字符集。由于大多数浏览器会忽略它的值,少有人用这个属性
  • defer:可选。表示脚本可以延迟到文档完全被解析和显示之后再执行。只对外部脚本文件有效。
  • src:可选。表示包含要执行代码的外部文件。
  • type:可选。可以看成是language的替代属性;表示编写代码使用的脚本语言的内容类型(也称为MIME类型)。虽然text/javascript和text/ecmascript都已经不被推荐使用,但人们一直以来使用的都还是text/javascript。

使用<script>元素的方式:

  • 直接在页面中嵌入JavaScript代码

语法:指定type属性

<script type="text/javascript">
    function sayHi(){ 
        alert("Hi!");
    }
</script>

使用这种方式嵌入JavaScript代码时,应该注意: 1.不要在代码中任何地方出现 "</script>" 字符串,否则会报错。

原因:按照解析嵌入式代码的规则,当浏览器遇到字符串 "</script>"时,就会认为那是结束的</script>标签。

如果真的需要在显示这个结束标签,可以把这个字符串分隔为两部分 ,如

<script type="text/javascript">
    function sayScript(){
        alert("<\/script>");
    }

包含外部JavaScript文件

使用这个方式来包含外部JavaScript文件,那么src属性就是必需的。这个属性的值是一个指向外部JavaScript文件的链接。

<script type="text/javascript">
    function sayScript(){
        alert("<\/script>");
    }

 

1.

外部文件的内容:只需要包含通常要放在开始的<script>和结束的</script>之间的那些JavaScript代码即可。

2.

XHMTL文档中,也可以省略结束标签。

<script type="text/javascript" src="example.js" />

注意:不能再HTML文档使用这种语法,原因是这种语法不符合HTML规范,而且也得不到某些浏览器(尤其是IE)的正确解析。

3.

在解析外部JavaScript文件(包括下载该文件)时,页面的处理也会暂时停止。

4.

带有src属性的<script>元素不应该在其<script>和</script>标签之间再包含额外的JavaScript代码。如果包含了嵌入的代码,则只会下载并执行脚本文件,嵌入的代码会被忽略。

5.

最备受争议的点: 通过<script>元素的src属性还可以包含来自外部域的JavaScript文件。位于外部域中的代码也会被加载和解析,就像这些代码位于加载它们的页面中一样。利用这一点就可以在必要时通过不同的域来提供JavaScript文件。

危险性:容易被怀有恶意的程序员随时替换该文件中的代码,如果想包含来自不同域的代码,则要么是那个域的所有者,要么那个域的所有者值得信赖。

相似点:元素,即它的src属性可以指向当前HTML页面所在域之外的某个域中URL。如:

<script type="text/javascript" src="http://www.somewhere.com/afile.js"></script>

总结:

  • 无论如何包含代码,只要不存在defer和async属性,浏览器都会按照<script>元素在页面中出现的先后顺序对它们依次进行解析。

  • 按照惯例,外部JavaScript文件带有.js扩展名。但是这个扩展名不是必需的,因为浏览器不会检查包含JavaScript的文件的扩展名。服务器通常还是需要看扩展名决定为响应应用那种MIME类型。如果不使用.js扩展名,请确保服务器能返回正确的MIME类型。

标签的位置

  • 按照惯例,所有<script>元素都应该放在页面的<head>元素中。 目的: 把所有外部文件(包括CSS文件和JavaScript文件)的引用都放在相同的地方。
  • 缺点:在文档的<head>元素中包含所有JavaScript文件,意味着必需等到全部JavaScript代码都被下载、解析和执行完成以后,才能开始呈现页面的内容(浏览器在遇到<body>标签时才开始呈现内容)。这样做会导致浏览器在呈现页面时出现明显的延迟,而延迟期间的浏览器窗口将是一片空白。为了避免这个问题。
  • 避免的方式:把全部JavaScript引用放在<body>元素中,放在页面的内容后面,在解析JavaScript代码之前,页面的内容将完全呈现在浏览器中。而用户也会因为浏览器窗口显示空白页面的时间缩短而感到打开页面的速度加快了。

延迟脚本

  • 用途: 这个属性的用途是表明脚本在执行时不会影响页面的构造。也就是说,脚本会被延迟到整个页面都解析完毕后再运行。在<script/>元素中设置defer属性,相当于告诉浏览器立即下载,但延迟执行,直到浏览器遇到标签后再执行。
  • 缺点:现实状况中,延迟脚本并不一定会按照顺序执行,也不一定会在DOMContentLoaded事件触发前执行,因此最好只包含一个延迟脚本。
  • 限制:HTML5的实现会忽略给嵌入脚本设置的defer属性
  • 在XHTML文档中,要把defer属性设置为defer=“defer”

异步脚本

  • 用途:HTML5为<script>元素定义了async属性,都用于改变处理脚本的行为。async只适用于外部脚本文件,并告诉浏览器立即下载文件。但是与defer不同的是,标记为async的脚本并不保证按照指定它们的先后顺序执行。异步脚本一定会在页面的load事件前执行,但可能会在DOMContentLoaded事件触发之前或之后执行。
  • 在XHTML文档中,要把async属性设置为async="async"。

嵌入JavaScript代码与外部文件.js的对比 尽可能使用外部文件来包含JavaScript代码,并不存在必须使用外部文件的硬性规定。

  • 嵌入:

  • 外部文件的优点:

1.可维护性:遍及不同HTML页面的JavaScript会造成维护问题。但把所有JavaScript文件都放在一个文件夹中,维护起来就轻松多了。而且开发人员因此也能够在不触及HTML标记的情况下,集中精力编辑JavaScript代码。

2.可缓存:浏览器能够根据具体的设置缓存链接的所有外部JavaScript文件。也就是说,如果有两个页面都使用同一个文件,那么这个文件只需下载一次。因此,最终结果就是能够加快页面加载的速度。

3.适应未来:通过外部文件来包含JavaScript无须使用前面提到XHTML或注释hack。HTML和XHTML包含外部文件的语法是相同的。

文档模式

种类: 混杂模式和标准模式 主要作用:影响CSS内容的呈现,但是某些情况下也会影响到JavaScript的解释执行。

  • 混杂模式: 混杂模式会让IE的行为与(包含非标准特性的)IE5相同
  • 标准模式:是让IE的行为更接近标准行为
  • 准标准模式: IE引入文档模式的概念后,其他浏览器也纷纷效仿。在此之后,IE又提出一种所谓的准标准模式。在这种模式下的浏览器特性有很多都是符合标准的,但也不尽然。不标准的地方主要体现在处理图片间隙的时候。
  • 默认情况下,文档开始出没有发现文档类型声明,则所有浏览器都会默认开启混杂模式。

对于标准模式,可以通过使用下面任何一种文档类型来开启

<!-- HTML 4.01 严格型 -->
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">

<!-- XHTML 1.0 严格型 -->
<!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">

<!-- HTML 5 -->
<!DOCTYPE html>

准标准模式,通过使用过渡型或框架集型(framset)文档类型来触发

<!-- HTML 4.01 过渡型 -->
<!DOCTYPE HTML PUBLIC
"-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">

<!-- HTML 4.01 框架集型 -->
<!DOCTYPE HTML PUBLIC
"-//W3C//DTD HTML 4.01 Frameset//EN"
"http://www.w3.org/TR/html4/frameset.dtd">

<!-- XHTML 1.0 过渡型 -->
<!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<!-- XHTML 1.0 框架集型 -->
< !DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Frameset//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">

<noscript>元素

问题:如果浏览器不支持JavaScript时如何让页面平稳地退化。

解决方式:创造一个<noscript>元素,作用:用以在不支持JavaScript的浏览器中显示替代的内容。

可替代的内容:包含能够出现在文档<body>中的任何HTML元素--<script>元素除外。

有效:

1.浏览器不支持脚本

2.浏览器支持脚本,但脚本被禁用

符合上述任何一个条件,浏览器都会显示<noscript>中的内容。而在除此之外的其他情况下,浏览器不会呈现<noscript>中的内容。

如:

<html> 
  <head>
    <title>Example HTML Page</title>
    <script type="text/javascript" defer="defer" src="example1.js"></script>
    <script type="text/javascript" defer="defer" src="example2.js"></script>
  </head>
  <body>
    <noscript>
      <p>本页面需要浏览器支持(启用)JavaScript。
    </noscript>
  </body>
</html>

当该页面的脚本无效时,就会显示<noscript>中的内容。在脚本有效时,用户是不会看到这部分的信息的。

总结:

  • 在包含外部JavaScript文件时,必需将src属性设置为相应文件的URL。而这个文件既可以是与包含5它的页面位于同一个服务器上的文件,也可以是其他任何域中的文件。

  • 所有<script>元素都会按照它们在页面中出现的先后顺序依次被解析。在不使用defer和async属性的情况下,只有在解析完前面<script>元素中的代码之后,才会开始解析后面<script>元素中的代码。

  • 由于浏览器会先解析完不使用defer属性的<script>元素中的代码,然后再解析后面的内容,所以一般应该把<script>元素放在页面最后,即主要内容后面,</body>标签前面。

  • 使用defer属性可以让脚本在文档完全呈现之后再执行。延迟脚本总是按照指定它们的顺序执行。

  • 使用async属性可以表示当前脚本不必等待其他脚本,也不必阻塞文档呈现。不能保证异步脚本按照它们在页面中出现的顺序执行。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值