用代码来说话,如下:
<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.”并没有被解析和显示。