JavaScript高级程序设计(第三版)笔记——第二章

    在HTML中使用JavaScript

      一.  <script>元素

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

        HTML 4.01 <script>定义了下列 6 个属性。
        1、async:可选。表示应该立即下载脚本,但不应妨碍页面中的其他操作,比如下载其他资源或等待加载其他脚本。只对外部脚本文件有效。
        2、charset:可选。表示通过 src 属性指定的代码的字符集。由于大多数浏览器会忽略它的值,因此这个属性很少有人用。
        3、defer:可选。表示脚本可以延迟到文档完全被解析和显示之后再执行。只对外部脚本文件有效。 IE7 及更早版本对嵌入脚本也支持这个属性。
        4、language:已废弃。
        5、src:可选。表示包含要执行代码的外部文件。

        6、type:可选。可以看成是 language 的替代属性;表示编写代码使用的脚本语言的内容类型(也称为 MIME 类型)。这个属性并不是必需的,如果没有指定这个属性,则其默认值仍为text/javascript

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


使用<script>元素的方式有两种:直接在页面中嵌入 JavaScript 代码和包含外部 JavaScript文件。

        在使用<script>嵌入 JavaScript 代码时,只须为<script>指定 type 属性。然后把 JavaScript 代码直接放在元素内部即可。包含在<script>元素内部的 JavaScript 代码将被从上至下依次解释。

        在使用<script>嵌入 JavaScript 代码时,记住不要在代码中的任何地方出现"</script>"字符串。 因为按照解析嵌入式代码的规则,当浏览器遇到字符串"</script>"时,就会认为那是结束的</script>标签。而通过转义字符“/”可以解决这个问题 。

        如果要通过<script>元素来包含外部 JavaScript 文件,那么 src 属性就是必需。这个属性的值是一个指向外部 JavaScript 文件的链接,例如:<script type="text/javascript" src="example.js"></script>

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

        src属性可以是指向当前 HTML 页面所在域之外的某个域中的完整 URL,例如:
<script type="text/javascript" src="http://www.somewhere.com/afile.js"></script>

        注意:在访问自己不能控制的服务器上的JavaScript 文件时则要注意安全性。


        1、标签位置

        按照传统的做法,所有<script>元素都应该放在页面的<head>元素中。这种做法的目的就是把所有外部文件(包括 CSS 文件和 JavaScript 文件)的引用都放在相同的地方。

        可是,在文档的<head>元素中包含所有 JavaScript 文件,意味着必须等到全部 JavaScript 代码都被下载、解析和执行完成以后,才能开始呈现页面的内容(浏览器在遇到<body>标签时才开始呈现内容)。如果JavaScript 代码很多的话,浏览器在呈现页面会出现明显的延迟,而延迟期间的浏览器窗口中将是一片空白。

        为了避免这个问题,现代 Web 应用程序一般都把全部 JavaScript 引用放在<body>元素中页面内容的后面。

        这样,在解析包含的 JavaScript 代码之前,页面的内容将完全呈现在浏览器中。而用户也会因为浏览器窗口显示空白页面的时间缩短而感到打开页面的速度加快了。

        2、延迟脚本

        HTML 4.01 <script>标签定义了 defer 属性。这个属性的用途是表明脚本在执行时不会影响页面的构造。也就是说,脚本会被延迟到整个页面都解析完毕后再运行。因此,在<script>元素中设置defer 属性,相当于告诉浏览器立即下载,但延迟执行。 
        HTML5 规范要求脚本按照它们出现的先后顺序执行,而这两个脚本会先于 DOMContentLoaded 事件执行。在现实当中,延迟脚本并不一定会按照顺序执行,也不一定会在 DOMContentLoaded 事件触发前执行,因此最好只包含一个延迟脚本。
        defer 属性只适用于外部脚本文件。这一点在 HTML5 中已经明确规定,因此支持HTML5 的实现会忽略给嵌入脚本设置的defer 属性。 IE4IE7 还支持对嵌入脚本的 defer 属性,但IE8 及之后版本则完全支持 HTML5 规定的行为。
        IE4Firefox 3.5Safari 5 Chrome 是最早支持 defer 属性的浏览器。其他浏览器会忽略这个属性,像平常一样处理脚本。为此,把延迟脚本放在页面底部仍然是最佳选择。

       3、异步脚本
        HTML5 <script>元素定义了 async 属性。这个属性与 defer 属性类似,都用于改变处理脚本的行为。同样与 defer 类似, async 只适用于外部脚本文件,并告诉浏览器立即下载文件。但与 defer不同的是,标记为 async 的脚本并不保证按照指定它们的先后顺序执行。
       
指定 async 属性的目的是不让页面等待多个脚本下载和执行,从而异步加载页面其他内容。为此,建议异步脚本不要在加载期间修改 DOM
        异步脚本一定会在页面的 load 事件前执行,但可能会在 DOMContentLoaded 事件触发之前或之后执行。支持异步脚本的浏览器有 Firefox 3.6Safari 5 Chrome

       4、在XHTML中用法
        可扩展超文本标记语言,即 XHTMLExtensible HyperText Markup Language),是将 HTML 作为XML 的应用而重新定义的一个标准。
        HTML 中,有特殊的规则用以确定<script>元素中的哪些内容可以被解析,但这些特殊的规则在 XHTML 中不适用。如比较语句 a < b 中的小于号( <)在 XHTML 中将被当作开始一个新标签来解析。但是作为标签来讲,小于号后面不能跟空格,因此就会导致语法错误。
        避免在 XHTML 中出现类似语法错误的方法有两个。一是用相应的 HTML 实体( &lt)替换代码中所有的小于号( < )。第二个方法,就是用一个 CData 片段来包含 JavaScript 代码。XHTMLXML)中, CData 片段是文档中的一个特殊区域,这个区域中可以包含不需要解析的任意格式的文本内容。因此,在 CData 片段中就可以使用任意字符——小于号当然也没有问题,而且不会导致语法错误。引入 CData 片段后的 JavaScript 代码块如下所示:
<script type="text/javascript"><![CDATA[
        function fn() {}
]]></script>
        在兼容 XHTML 的浏览器中,这个方法可以解决问题。但实际上,还有不少浏览器不兼容 XHTML,因而不支持 CData 片段。只需要使用 JavaScript 注释将 CData 标记注释掉就可以了。
<script type="text/javascript">
//<![CDATA[
        function fn() {}
//]]>

</script> 


       二.  嵌入代码与外部文件

        在 HTML 中嵌入 JavaScript 代码虽然没有问题,但一般认为最好的做法还是尽可能使用外部文件来包含 JavaScript 代码。 优点如下:
        1、可维护性
        2、 可缓存
        3、适应未来 


       三.  文档模式

        IE5.5 引入了文档模式的概念,而这个概念是通过使用文档类型(doctype)切换实现的。最初的两种文档模式是: 混杂模式quirks mode)标准模式standards mode)。 虽然这两种模式主要影响 CSS内容的呈现,但在某些情况下也会影响到 JavaScript 的解释执行。
        IE 引入文档模式的概念后,其他浏览器也纷纷效仿。在此之后, IE 又提出一种所谓的准标准模式almost standards mode)。这种模式下的浏览器特性有很多都是符合标准的,但也不尽然。不标准的地方主要体现在处理图片间隙的时候(在表格中使用图片时问题最明显)。
        如果在文档开始处没有发现文档类型声明,则所有浏览器都会默认开启混杂模式,但这是不值得推荐的。


       四.  <noscript>元素

        早期浏览器都面临浏览器不支持 JavaScript 时如何让页面平稳地退化的问题。解决方案是创造一个<noscript>元素,用以在不支持 JavaScript 的浏览器中显示替代的内容。这个元素可以包含能够出现在文档<body>中的任何 HTML 元素,<script>元素除外。包含在<noscript>元素中的内容只有在下列情况下才会显示出来:
        1、浏览器不支持脚本;
        2、浏览器支持脚本,但脚本被禁用。

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


      五.  小结

        JavaScript 插入到 HTML 页面中要使用<script>元素。使用这个元素可以把 JavaScript 嵌入到HTML 页面中,让脚本与标记混合在一起;也可以包含外部的 JavaScript 文件。而我们需要注意的地方有:
        1、在包含外部 JavaScript 文件时,必须将 src 属性设置为指向相应文件的 URL。而这个文件既可以是与包含它的页面位于同一个服务器上的文件,也可以是其他任何域中的文件。
        2、所有<script>元素都会按照它们在页面中出现的先后顺序依次被解析。在不使用 defer async 属性的情况下,只有在解析完前面<script>元素中的代码之后,才会开始解析后面<script>元素中的代码。
        3、由于浏览器会先解析完不使用 defer 属性的<script>元素中的代码,然后再解析后面的内容,所以一般应该把<script>元素放在页面最后,即主要内容后面, </body>标签前面。
        4、使用 defer 属性可以让脚本在文档完全呈现之后再执行。延迟脚本总是按照指定它们的顺序执行。
        5、使用 async 属性可以表示当前脚本不必等待其他脚本,也不必阻塞文档呈现。不能保证异步脚本按照它们在页面中出现的顺序执行。
        另外,使用
<noscript>元素可以指定在不支持脚本的浏览器中显示的替代内容。但在启用了脚本的情况下,浏览器不会显示<noscript>元素中的任何内容。



猜你喜欢

转载自blog.csdn.net/qq_36180015/article/details/80723126