谈谈XHTML中CDATA

时间:2007-09-17 12:45:00 

  近来,随着XHTML(可扩展HTML)标准的出现,<script/>标签也经历了一些改变。该标签不再用language特性,而用type特性声明内嵌代码或要加入的外部文件的mime类型,JavaScript的mime类型是"text/javascript"。例如:

Example Source Code

<html> 
 <head> 
 <title>Title of Page</title> 
 <script type=”text/javascript”> 
 var i = 0; 
 </script> 
 <script type=”text/javascript” src=”../scripts/external.js”></script> 
 </head> 
 <body> 
 <!-- body goes here --> 
 </body> 
</html>


  即使许多浏览器不完全支持XHTML,但大多数开发者现在都用type特性,而不用language特性,以提供更好的XHTML支持。省略language特性不会带来任何问题,因为如前所述,所有浏览器都默认<script/>的该属性值为JavaScript。


  XHTML的第二个改变是使用CDATA段。XML中的CDATA段用于声明不应被解析为标签的文本(XHTML也是如此),这样就可以使用特殊字符,如小于(<)、大于(>)、和号(&)和双引号("),而不必使用它们的字符实体。考虑下面的代码:

Example Source Code



<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> 

  这个函数相当简单,它比较数字a和b,然后显示消息说明它们的关系。但是,在XHTML中,这段代码是无效的,因为它使用了三个特殊符号,即小于、大于和双引号。要修正这个问题,必须分别用这三个字符的XML实体<、>和"替换它们:


Example Source Code

<SCRIPT type=”text/javascript”> 
function compare(a, b) { 
if (a < b) { 
alert("A is less than B"); 
} else if (a > b) { 
131 
JavaScript in the Browser 
alert("A is greater than B"); 
} else { 
alert("A is equal to B"); 


</SCRIPT>


  这段代码存在两个问题。首先,开发者不习惯用XML实体编写代码。这使代码很难读懂。其次,在JavaScript中,这种代码实际上将视为有语法错,因为解释程序不知道XML实体的意思。用CDATA段即可以以常规形式(即易读的语法)编写JavaScript代码。正式加入CDATA段的方法如下:

Example Source Code

<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>


  虽然这是正式方式,但还要记住,大多数浏览器都不完全支持XHTML,这就带来主要问题,即这在JavaScript中是个语法错误,因为大多数浏览器还不认识CDATA段。


  当前使用的解决方案模仿了“对旧浏览器隐藏”代码的方法。使用单行的JavaScript注释,可在不影响代码语法的情况下嵌入CDATA段:

Example Source Code

<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>


标签:xml,cdata,xhtml
0
投稿

猜你喜欢

  • asp的command对象的使用

    2008-06-23 13:03:00
  • 谈谈网页设计中的字体应用 (3) 实战应用篇·上

    2009-11-24 13:09:00
  • asp如何读取一个文件内容?

    2009-11-19 17:23:00
  • css设计的具有亲和力的表格

    2008-03-16 19:28:00
  • MySQL重定位数据库目录的内容

    2009-02-26 16:03:00
  • 另外一种斜体的导航条

    2008-11-05 12:24:00
  • ASP控制每页打印行数实例

    2008-04-13 06:48:00
  • 提升网站可用性的3个忠告

    2008-01-31 13:48:00
  • asp如何在聊天室实现趣味答题并计分功能?

    2010-06-18 20:00:00
  • 原来CSS也可以把IE6弄死

    2007-08-14 09:30:00
  • Flash如何连接Mysql

    2010-11-11 11:57:00
  • 框架和框架之间的关系

    2008-01-17 18:54:00
  • ASP状态封装类Cache、Cookie & Session

    2008-05-11 19:33:00
  • css有趣而诡异的数组

    2009-02-04 16:06:00
  • msxml3.dll 错误解决办法

    2009-05-25 18:02:00
  • 网站设计配色方案教程

    2007-10-10 19:38:00
  • ACCESS 2007出现“错误 '80040e14'“

    2008-06-19 13:21:00
  • DHTML中重要的属性方法

    2008-06-21 17:13:00
  • 使table也能overflow:hidden

    2008-08-18 21:04:00
  • 双屏显示提升前端开发10%工作效率

    2009-03-16 18:22:00
  • asp之家 网络编程 m.aspxhome.com