DHTML
http://user.qzone.qq.com/170475387/blog/1190130375
HTML4.html
MyHtml.html This is my HTML page.
XHTML
- • 什么是XHTML
- • XHTML简介
- • XHTML1.0的标准定义
- • XHTML 1.0最主要的优势
http://www.hoodong.com/wiki/XHTML
XHTML - 什么是XHTML
XHTML是The Extensible HyperText Markup Language(可扩展标识语言)的缩写。HTML是一种基本的WEB网页设计语言,XHTML是一个基于XML的置标语言,看起来与HTML有些相 象,只有一些小的但重要的区别,XHTML就是一个扮演着类似HTML 的角色的XML ,所以,本质上说,XHTML是一个过渡技术,结合了部分XML的强大功能及大多数HTML的简单特性。
2000年底,国际W3C 组 织(World Wide Web Consortium)组织公布发行了XHTML 1.0版本。XHTML 1.0是一种在HTML 4.0基础上优化和改进的的新语言,目的是基于XML应用。XHTML是一种增强了的HTML,它的可扩展性和灵活性将适应未来网络应用更多的需求。 XML虽然数据转换能力强大,完全可以替代HTML,但面对成千上万已有的基于HTML语言设计的网站,直接采用XML还为时过早。因此,在 HTML4.0的基础上,用XML的规则对其进行扩展,得到了XHTML。所以,建立XHTML的目的就是实现HTML向XML的过渡。目前国际上在网站 设计中推崇的WEB标准 就是基于XHTML的应用(即通常所说的CSS+DIV )。
XHTML - XHTML简介
XHTML是当前和未来的文档标准之一,是对HTML4的重述、延伸和扩展。XHTML文档类型是基于XML,并最终为XML客户端服务的。
XHTML1.0是XHTML的第一个版本,它是作为XML1.0的应用对HTML4的三个版本的重新陈述。它将成为一种既符合XML标准,又能被HTML标准浏览器所识别的文档标记语言。
那些转向XHTML的开发者将会发掘下列优点:
XHTML是和XML保持一致的,同样地,它也是能被将来的XML工具察看、编辑和验证的。
XHTML文档在旧的基于HTML的浏览器中能够表现得和在新的基于XHTML的浏览器中一样出色。
XHTML在应用上,既能够利用HTML的文档对象模块(DOM),又能利用XML的文档对象模块。
在XHTML家族的发展过程中,XHTML格式的文档将会活跃在各类多种多样的XHTML环境之中。
XHTML是英特网发展的新的一步。在逐步转向XHTML的今日,文档开发者们能在保持向后和向前的兼容性的同时进入XML的殿堂并享受随之而来的种种优点。
XHTML - XHTML1.0的标准定义
1. 文档格式
1.1 严格定义的文档
一份严格定义的XHTML文档是一份符合下列标准的文档:
应该通过三种之一的DTD的验证。
文档的根元素应该是。
文档的根元素必须通过xmlns属性来指定XHTML词汇表。XHTML词汇表应该定义成http://www.w3.org/1999/xhtml 在文档里的根元素之前应该有文档类型申明的语句。文档类型申明中的public标识符必须引用,并使用三种DTD中的一种的正式public标识符引用。改变系统标识符可以用来反映本地的系统约定。
以下是一个短小的XHTML文档示范
Moved to vlib.org.
请注意,在上述例子中包含了XML申明。像上述的XML申明并不是所有XML文档必须的。XHTML文档作者们强烈建议在所有文档中使用XML申明。当字符集超出了默认的UTF-8或UTF-16的范围时,这样一个申明是必须的。
1.2 XHTML和其它词汇表一起使用
XHTML词汇表可以和其它词汇表一起使用,即使这样一份文档并不是上述严格定义的。今
后W3C将对这类混合使用词汇表的文档进行标准的格式化定义。
下面是一个在XHTML1.0中使用MATHML的例子:
The following is MathML markup:
下面是XHTML1.0在其他类型的XML词汇表中使用的例子:
This is also available href="http://www.w3.org/">online.
2. 客户端兼容性
一个和XHTML兼容的客户端必须符合以下标准:
为符合XML1.0推荐标准,客户端必须分析和评估XHTML文档是否是格式化(Well-Formedness)的。如果是一个验证了(validating)的客户端,那它必须进一步按照DTD验证文
档是否有效(validate)。
当客户端是申明支持本规范定义的设备(Facilities),或按照本规范进行标准的引用,那么也必须按照规范定义来验证设备。
当客户端按照普通XML文档来处理XHTML文档时,应该只有id属性被作为片断标识符。
当客户端遇到不能识别的元素时,其内容将被返回。
当客户端遇到不能识别的属性时,应该忽略整个属性内容(包括属性的名称和值)。
当客户端遇到不能识别的属性的值时,应该使用默认的属性值代替。
当客户端遇到不能识别的实体引用(可能是在外部的未读子集中)时,将返回用来代替实体的字符(以&开头,以;结尾)。
当客户端再返回内容的时候,如果遇到能识别但不能返回的字符或字符实体引用时,客户端应该以一种让用户清晰地知道文档难以用普通的方法返回的途径显示文档。
以下字符在XML中被定义为纯空字符(whitespace):
Space ( )
Tab ( )
Carriage return (
)
Line feed (
)
XML处理器将不同系统的行终止符处理成一种简单的Line-feed字符来传递给应用程序。
并且在XHTML处理器中,下列字符也必须被识别为纯空子符:
Form feed ( )
Zero-width space (?)
在处理元素时,当"xml:space"属性被置为"preserve"时,所有的纯空字符将被原封不动
地保留(开头和结尾的纯空字符将被删除)。否则,纯空子符将按照以下规则处理:
围绕块元素的纯空子符将被删除。
删除整个注释并不影响纯空子符的处理。在注释两头的纯空子符将加倍处理。
在块元素内部开头和结尾的纯空子符将被删除。
在块元素内部,line feed字符将被转换成space字符("xml:space"被置成"preserve"的情况除外)。
连续的纯空字符将被置换成一个单独的space字符("xml:space"被置成"preserve"的情况除外)。
关 于译文,客户端应用最适合于撰写文档的语言的风格来返回文档内容。在一个以拉丁文为主的脚本中,ASCII的空格字符被象征性地用来为拉丁语法规范的单词 分界和排字纯空字符编码;在一个以NAGARI文为主的脚本中,语法规则中的单词分界将被编码成ZW空格,而在排字输出的时候则不会被象征性地表现出来; 阿拉伯语的脚本中,排字纯空字符用space字符来做编码,也使用ZW空格来做“内部”分界的编码;而一个中文脚本通常不使用上述方法编码。
3. XHTML和HTML4的区别
3.1 文档必须是结构化的
“结构化”是XML提出的新的概念。从本质上来说,就是所有的元素都必须有结束标签(或者以一种特殊的方式呈现——下述),并且符合嵌套规则。
即使交错标签在SGML中是非法的,可是目前很多浏览器仍然允许这种写法。
正确:符合嵌套规则
here is an emphasizedparagraph.
错误:交错标签
here is an emphasizedparagraph.
3.2 元素和属性的名称必须是小写的
XHTML文档在使用HTML的元素和属性时必须使用小写字母。导致这种差异的原因是,XML区分大小些。
3.3 非空的元素必须有结束标签
在基于SGML的HTML4中,这样的元素被允许忽略结束标签;在这些元素后有隐藏的结束标签。在基于XML的XHTML中,这种忽略是非法的。除了在DTD中申明的空元素,所有元素必须有结束标签。
正确:结尾了的元素
here is a paragraph.
here is another paragraph.
错误:未结尾的元素
here is a paragraph.
here is another paragraph.
3.4 所有属性值必须用引号引用
所有属性值必须用引号引用,即使是属性值为数字的属性。
正确:使用引号的属性值