经典样式表大赛中web标准应用存在的问题
|
源代码网整理以下 一.CSS校验的问题 源代码网整理以下 首先根据比赛要求,参赛作品必须符合XHTML标准,提交的CSS必须通过W3C的校验。CSS校验的情况比较理想,参赛作品中只有8份作品未通过CSS2.0校验,主要校验错误都是:“Line : 0 font-family: 建议你指定一个种类族科作为最后的选择” 源代码网整理以下 W3C建议字体定义的时候,最后以一个类别的字体结束,而不要以单独某个字体结束。例如"sans-serif"就,以保证在不同操作系统下,网页字体都能被显示。 源代码网整理以下 虽然多数人都在body标签上定义了"sans-serif",但在其它的id或class中再次定义字体时漏了sans-serif,被认为校验不通过。这个错误不是很严重,只要稍加注意就可以避免。 源代码网整理以下 二.CSS的书写建议 源代码网整理以下 给CSS文件加注释。注释会为你今后的维护带来方便,建议尽可能给CSS文件加注释,不要担心增加少量的字节。 源代码网整理以下 三.XHTML校验的问题 源代码网整理以下 因为是样式表比赛,大家对CSS的校验比较注意,但在XHTML符合标准方面有点忽视,出现很多低级错误。主要问题罗列如下: 源代码网整理以下 target="_blank",这个语法在HTML4.0里是正确的,在XHTML1.0里是不允许使用的。解决的办法之一是写成target="new",另外一个办法是用js处理所有的target; 源代码网整理以下 样式表最好不要内嵌,将样式表文件独立出来易于维护。如果内嵌<style>一定要写成<style type="text/css">,其中的type不能忽略,否则XHTML无法判断你的style作用在什么方面。 源代码网整理以下 <br>必须写成<br />,XHTML要求所有的标签必须关闭,不成对的标签直接在后面加" /"。 源代码网整理以下 重复使用同一ID。一个ID在XHTML中只能使用1次,如果需要多次引用样式,应该使用class。 源代码网整理以下 <meta http-equiv="Content-Type" content="text/html; charset="gb2312" />很明显content属性值里面多了一个引号。 源代码网整理以下codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=5,0,0,0" 源代码网整理以下 <param name="SRC" value="http://www.chinaz.com/Design/Rules/test.swf"> <embed src="http://www.chinaz.com/Design/Rules/test.swf" wmode="transparent" quality="high" 源代码网整理以下 pluginspage="http://www.macromedia.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash" 源代码网整理以下 type="application/x-shockwave-flash" width="300" height="100"> </embed> </object> 源代码网整理以下 但直接写在XHTML中依然不可以,我们现在只能通过把上面代码写在http://www.chinaz.com/Design/Rules/flash.js文件里,然后再调用来骗过校验。 源代码网整理以下 <script type="text/javascript" src="http://www.chinaz.com/Design/Rules/flash.js"></script> 源代码网整理以下 关于flash是否符合标准,是一个存在争议的问题。更多说明:参考http://www.blueidea.com/tech/site/2004/1920.asp 源代码网整理以下 类似id=header class=title代码都应该写成id="header" class="title"。给属性值加引号是最XHTML基本的语法规则。 源代码网整理以下 四.兼容的问题 源代码网整理以下 有12份作品在IE6.0、Mozilla Firefox1.0、Opera 7.12中浏览发生变形和错位。(我没有用IE5.0测试,偷懒啦:)IE5.0对所有CSS布局的设计师都是个挑战)。 源代码网整理以下 在IE里居中,但Mozilla里没有。在IE中设置body {TEXT-ALIGN: center;}就已经可以居中了,但在Mozilla中必须对需要居中的层再加入以下样式设置:MARGIN-RIGHT: auto;MARGIN-LEFT: auto; 超出宽度。在Mozilla里看正常的页面,在IE里因为超出宽度而变形,并排的层移到下面去了。这个情况是因为IE和Mozilla对盒模型解释不同造成的,有很多解决办法,比如"!important"方法。 源代码网整理以下 总得来说,参赛作品整体上是合格的居多,这次大赛的目的也已经基本达到,web标准和CSS布局已经被越来越多的设计师了解和掌握。对于部分作品美工简陋,我想这是一个过程,资深设计师应该都记得Table布局刚出现的时候,网页大多也很朴素。CSS布局经过一段时间的消化理解和应用,会有更多象一等奖作品这样技术美观兼顾的网页涌现。 |
