重温CSS系列(二)

不同的HTML和CSS版本

CSS有多个版本,所以知道要使用哪个版本是很重要的。CSS 1在1996年末成为推荐标准,其中包含非常基本的属性,比如字体、颜色、外边距。CSS 2在1998年发布,它添加了高级概念(比如浮动和定位)以及高级的选择器(比如子选择器、相邻同胞选择器和通用选择器)。

万维网联盟(W3C)的行动非常缓慢,所以尽管CSS 3的开发工作在新千年到来之前就开始了,但是距离最终的发布还有相当长的路要走。为提高开发和浏览器实现的速度,CSS 3被分割为多个模块,这些模块可以独立发布和实现。CSS 3包含一些令人兴奋的新特性,包括一个高级布局模块、全新的背景属性和一批新的选择器。其中一些模块原计划于2009年下半年发布。但是,目前还没什么进展,而且一些模块在发布前夕又回到了"最后公告"或"工作草案"状态,所以很难确定实际发布会多少个模块。希望到2011年会有许多模块成为正式的推荐标准。更让人担心的是,一些模块还没有开始开发,其他模块好几年没有更新了。如此缓慢的开发进度让人觉得CSS 3似乎不可能全部完成了。

不过,尽管有一些拖延,还是有许多浏览器厂商已经实现了CSS 3规范中比较有意思的一些特性。因此,目前已经可以使用许多新的选择器了。

因为预期从CSS 2到CSS 3的发布之间时间会很长,2002年启动了CSS 2.1的开发。这是CSS 2的修订版,它计划纠正一些错误,并且更精确地描述CSS的浏览器实现。CSS 2.1正在逐渐完成,因此我建议使用这个CSS版本。

HTML 4.01于1999年末成为推荐标准,这是大多数人目前使用的HTML版本。2000年1月,W3C发布了HTML 4.01的XML版并命名为XHTML 1.0。XHTML 1.0和HTML 4.01之间的主要差异是它遵守XML编码约定。这意味着与常规的HTML不同,所有XHTML属性必须包含引号,所有元素必须是封闭的。因此,以下代码在HTML中是合法的,而在XHTML中不合法:

    
    
    
    
  1. <h2>Peru Celebrates Guinea Pig festival  
  2.   <p><img src=pigonastick.jpg alt=Roast Guinea Pig> 
  3.   <p>Guinea pigs can be fried, roasted, or served in a casserole. 

在XHTML 1.0中,必须写成下面这样:

    
    
    
    
  1. <h2>Peru Celebrates Guinea Pig festival</h2> 
  2.   <p><img src="pigonastick.jpg" alt="Roast Guinea Pig" /></p> 
  3.   <p>Guinea pigs can be fried, roasted, or served in a casserole.</p> 

XHTML 1.1比XHTML 1.0更接近XML。这两种语言之间没有实际的差异。但是,有一个重大的概念性差异。XHTML 1.0页面可以作为HTML文档,而XHTML 1.1页面是作为XML发送给浏览器的。这意味着,即使XHTML 1.1页面只包含一个错误(比如未编码的&符号),Web浏览器也不会显示页面。大多数网站开发人员显然不喜欢这样,所以XHTML 1.1不受欢迎。

是把XHTML 1.0页面作为HTML提供,还是应该坚持使用HTML 4.01?对于这个问题仍然有争论。但是,显然不应该使用XHTML 1.1,除非使用正确的mime类型,而且能够容忍一个错误导致整个页面无法显示。

HTML 5相对较新,是一个不断变动的规范草案。但是,它的发展势头很强,一些流行的浏览器已经开始着手支持它了。XHTML 2的开发非常缓慢而且过时了,让开发人员失去了信心。因此,一批开发人员决定开发自己的规范,由此催生出了HTML 5。这一行动非常成功,HTML 5已经成为正式的W3C项目,而XHTML 2的开发则停止了。

前面提到过,HTML 5的目标是建立一种现代的标记语言,可以更好地反映在Web上发布的信息类型。因此它引入了新的结构性元素,比如header、nav、article、sections和footer。它还包含一批新的表单特性,可以大大简化Web应用程序开发。



你可能感兴趣的:(html,xml,XHTML,浏览器,css,程序开发)