您的位置:首页 > Web前端 > JavaScript

JavaScript基础——在HTML中使用JavaScript

2016-05-17 14:23 253 查看
只要一提到把JavaScript放到网页中,就不得不涉及Web的核心语言——HTML。在当初开发JavaScript的时候,Netscape要解决的一个重要问题就是如何让JavaScript既能与HTML页面共存,又不影响那些页面在其他浏览器中的呈现效果。经过尝试、纠错和争论,最终的决定就是为Web增加统一的脚本支持。而Web诞生早期的很多做法也都保留了下来,并被正式纳入HTML规范当中。
<script>元素

向HTML页面中插入JavaScript的主要方法,就是使用<script>元素。这个元素由Netscape创造并在NetscapeNavigator 2中首先实现。后来,这个元素被加入到正式的HTML规范中。HTML4.01为<script>定义了下列6个属性。

♢async:可选。表示应该立即下载脚本,但不应妨碍页面中的其他操作,比如下载其他资源或等待加载其他脚本。只对外部脚本文件生效。

♢charset:可选。表示通过src指定的代码的字符集。由于大多数浏览器会忽略它的值,因此这个属性很少有人用。

♢defer:可选。表示脚本可以延迟到文档完全解析和显示之后再执行。只对外部文件有效。IE7及更早版本对嵌入脚本也支持这个属性。

♢language:已废弃。原来用于表示编写代码使用的脚本语言(如JavaScript、JavaScript1.2或VBScript)。大多数浏览器会忽略这个属性,因此也没必要再用了。

♢src:可选。表示包含要执行代码的外部文件。

♢type:可以看成是language的替代属性;表示编写代码使用的脚本语言的内容类型(也称为MIME类型)。虽然text/javascript和text/ecmascript都已经不被推荐使用,但人们一直以来使用的都还是text/javascript。实际上,服务器在传送JavaScript文件时使用的MIME类型通常是application/x-javascript,但在type中设置这个值可能导致脚本被忽略,另外,在非IE浏览器中还可以使用以下值:application/javascript和application/ecmascript。考虑到约定成俗和最大限度的浏览器兼容性,目前type属性的值依旧还是text/javascript。不过,这个属性并不是必需的,如果没有指定这个值,则其默认值仍为text/javascript。

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

在使用<script>元素嵌入JavaScript代码时,只须为<script>指定type属性。然后,把JavaScript代码直接放在元素内部即可。

包含在<script>元素内部的JavaScript代码将被从上至下依次解释。在解释器对<script>元素内部的所有代码求值完毕以前,页面中的其余内容都不会被浏览器加载或显示。

在使用<script>嵌入JavaScript代码时,记住不要在代码中的任何地方出现</script>字符串。例如,浏览器在加载下面所示的代码时就会产生一个错误:

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

因为按照解析嵌入式代码的规则,当浏览器遇到字符串”</script>”时,就会认为那是结束的</script>标签。而通过把这个字符串分隔为两部分可以解决这个问题,例如:

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

像这样分成两部分来写就不会造成浏览器的误解了,因而也就不会导致错误了。

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

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

在这个例子中,外部example.js将被加载到当前页面中。外部文件只须包含通常要放在开始的<script>和结束的</script>之间的那些JavaScript代码即可。与解析嵌入式JavaScript代码一样,在解析外部JavaScript文件(或下载该文件时),页面的处理也会暂时停止。如果是在XHTML文档中,也可以省略前面示例代码中结束的</script>标签,例如:

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

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

按照惯例,外部JavaScript文件带有.js扩展名。但这个扩展名不是必需的,因为浏览器不会检查包含JavaScript的文件的扩展名。这样一来,使用JSP、PHP或其他服务器端语言动态生成JavaScript代码也成了可能。但是,服务器通常还是需要看扩展名决定为响应应用哪种MIME类型。如果不使用.js扩展名,请确保服务器能返回正确的MIME类型。

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

另外,通过<script>元素的src属性还可以包含来自外部域的JavaScript文件。这一点既使<script>元素倍显强大,又让它备受争议。在这一点上,<script>与<img>元素非常相似,即它的src属性可以是指向当前HTML页面所在域之外的某个域中的URL,例如:

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

这样外部域中的代码也会被加载和解析,就像这些代码位于加载它们的页面中一样。利用这一点可以在必要时通过不同的域来提供JavaScript文件。不过,在访问自己不能控制的服务器上的JavaScript文件时则要多加小心。如果不幸遇到了怀有恶意的程序员,那他们随时都有可能替换该文件中的代码。因此,如果向包含来自不同域的代码,则要么你是那个域的所有者,要么那个域的所有者值得信赖。

无论如何包含代码,只要不存在defer和async属性,浏览器都会按照<script>元素在页面中出现的先后顺序对它们依次解析。换句话说,在第一个<script>元素包含的代码解析完成后,第二个<script>包含的代码才会被解析,以此类推。

标签的位置

按照惯例,所有<script>元素都应该放在页面的<head>元素中。这样做法的目的就是把所有外部文件(包括CSS文件和JavaScript文件)的引用都放在相同的地方。可是,在文档的<head>元素中包含所有JavaScript文件,意味着必须等到全部JavaScript代码都被下载、解析和执行完成以后,才能开始呈现页面的内容(浏览器在遇到<body>标签时才开始呈现内容)。对于那些需要很多JavaScript代码的页面来说,这无疑会导致浏览器在呈现页面时出现明显的延迟,而延迟期间的浏览器窗口将是一片空白。为了避免这个问题,现代Web应用程序一般都把全部JavaScript引用放在<body>元素中页面的内容后面,也就是在</body>标签的上面。

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

延迟脚本

HTML4.01为<script>标签定义了defer属性。这个属性的用途是表名脚本在执行时不会影响页面的构造。也就是说,脚本被被延迟到整个页面都解析完毕后再运行。因此,在<script>元素中设置defer属性,相当于告诉浏览器立即下载,但延迟执行。在现实中,延迟脚本并不一定会按照顺序执行,也不一定会在DOMContentLoaded事件触发前执行,因此最好只包含一个延迟脚本。

异步脚本

HTML5为<script>元素定义了async属性。这个属性与defer属性类似,偶用于改变处理脚本的行为。同样与defer类似,async只适用于外部脚本文件,并告诉浏览器立即下载文件。但与defer不同的是,标记为async的脚本并不保证按照它们的先后顺序执行。

在XHTML中的用法

可扩展超文本标记语言,即XHTML(ExtensibleHyperText Markup Language),是将HTML作为XML的应用而重新定义的一个标准。编写XHTML代码的规则要比编写HTML严格得多,而且直接影响能否在嵌入JavaScript代码时使用<script/>标签。以下面的代码块为例,虽然它们在HTML中是有效的,但在XHTML中则是无效的。

<script
type="text/javascript">
function compare(a , b){
if(a < b){
alert("A is less than B.");
}else
if
(a > b){
alert("A is greater than B.");
}else{
alert("A is equal to B.");
}
}
</script>

在HTML中,有特殊的规则用以确定<script>元素中的哪些内容可以被解析,但这些特殊的规则在XHTML中不适用。这里比较语句a < 中的小于号(<)在XHTML中将被当作一个新标签来解析。但是作为标签来讲,小于号后面不能跟空格,因此就会导致语法错误。

避免在XHTML中出现类似语法错误的方法有两个。一是用响应的HTML实体(<)替换代码中所有的小于号(<),虽然这样可以让代码在XHTML中正常运行,但却导致代码不好理解了。为此,我们可以考虑采用另一个方法。保证让相同代码在XHTML中正常运行的第二个方法,就是用一个CDATA片段来包含JavaScript代码。在XHTML(XML)中,CDATA片段是文档中的一个特殊区域,这个区域中可以包含不需要解析的任意格式的文本内容。因此,在CDATA片段中就可以使用任意字符——小于号当然也没有问题,而且不会导致语法错误。引入CDATA片段后的JavaScript代码块如下所示:

<script
type="text/javascript"><![CDATA[
function compare(a , b){
if(a < b){
alert("A is less thanB.");
}else if(a > b){
alert("A is greater thanB.");
}else{
alert("A is equal to B.");
}
}
]]></script>

在兼容XHTML的浏览器中,这个方法可以解决问题。但实际上,还有不少浏览器不兼容XHTML,因而不支持CDATA片段。此时,再使用JavaScript注释将CDATA标记注释掉就可以了:

<script
type="text/javascript">
//<![CDATA[
function compare(a , b){
if(a < b){
alert("A is less than B.");
}else
if
(a > b){
alert("A is greater than B.");
}else{
alert("A is equal to B.");
}
}
//]]>
</script>

这种格式在所有现代浏览器中都可以正常使用。虽然有积分hack的味道,但它能通过XHTML验证,而且对XHTML之前的浏览器也会平稳退化。

嵌入代码与外部文件

在HTML中嵌入JavaScript代码虽然没有问题,但一般认为最好的做法还是尽可能使用外部文件来包含JavaScript代码。不过,并不存在必须使用外部文件的硬性规定,但支持使用外部文件的人多会强调如下优点:

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

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

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

<noscript>元素

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

□ 浏览器不支持脚本;

□ 浏览器支持脚本,但脚本被禁用。

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

<html>

<head>

<title>ExampleHTML Page</title>

</head>

<body>

<noscript>

<p>本页面需要浏览器支持(启用)JavaScript</p>

</noscript>

</body>

</heml>

这个页面会在脚本无效的情况下向用户显示一条信息。而在启用了脚本的浏览器中,用户永远也不会看到它——尽管它也是页面的一部分。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: