JavaScript在Html中的解析顺序

用代码来说话,如下:

<html> <head> <title> Today's Date </title> </head> <body> <mce:script language="Javascript"><!-- function print_date(){ document.write(new Date().toLocaleString()); } //alertString("I am on the up script"); //error // --></mce:script> <mce:script language="Javascript"><!-- print_date(); //OK alertString("I am in the same script"); //OK, but why?(if you are Java/C++ programmer,you may ask "but why?") function alertString(str){ alert(str); }; // --></mce:script> Hello,Jack. </body> </html>

这个简单的代码说明了一下几点:

1. “一个HTML文档中可以包含任意多个<script>元素。这些多个独立的执行顺序就是他们在文档中的出现顺序”。

2. “但是,这些脚本却是同一个Javascript程序的组成部分,因为在一个脚本中定义的函数和变量适用于随后出现的同一HTML文件中的所有脚本。”——《Javascript 权威指南》

但是,这并不准确。

函数有一个小小的特殊的地方。位于当前脚本中,函数的调用可以在定义之前(但这并不推荐,这完全没有必要,而且可能与浏览器对Javascript的解析有关系)。

例如:12行调用“alertString()”会报错。但是16行调用“alertString()”却没有问题。而alertString()的定义却在17行。

3. 脚本能够输出以插入到HTML文档中,这意味着HTML解析器必须在解析的过程中解释Javascript脚本。

但我们执行17行时,浏览器中显示的文本是日期。而23行“Hello Jack.”并没有被解析和显示。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值