HTML中使用JavaScript
延时脚本和异步脚本
延迟脚本defer 属性
<script type="text/javascript" defer="defer">
alert(document.getElementById("p1").firstChild.nodeValue);
</script>
defer 属性规定是否对脚本执行进行延迟,直到页面加载为止。
有的 javascript 脚本 document.write 方法来创建当前的文档内容,其他脚本就不一定是了。
表明脚本在执行时不会影响页面的构造,也就是说整个页面都解析完毕在运行。
异步脚本async 属性
<script type="text/javascript" src="demo_async.js" async="async"></script>
async 属性规定一旦脚本可用,则会异步执行。
注释:async 属性仅适用于外部脚本(只有在使用 src 属性时)。
注释:有多种执行外部脚本的方法:
- 如果 async=“async”:脚本相对于页面的其余部分异步地执行(当页面继续进行解析时,脚本将被执行)
- 如果不使用 async 且 defer=“defer”:脚本将在页面完成解析时执行
- 如果既不使用 async 也不使用 defer:在浏览器继续解析页面之前,立即读取并执行脚本
在HTML中的用法
XHTML是将HTML作为XML的应用而重新定义的一个标准,其标准比HTML要严格得多。
比如说XHTML中 < 是无效的,要用<进行替代。但是也可以引入CData片段,进行规范使用。
以下是合法的:
<script>
<![CDATA[
function matchwo(a,b)
{
if (a < b && a < 0) then
{
return 1;
}
else
{
return 0;
}
}
]]>
</script>