日期:2014-05-17  浏览次数:20809 次

DIV+CSS的30条进阶技能

许许多多的网页新手正徘徊在专业编码的门槛前,而网上的教程参差不齐,鱼龙混杂,很容易让新手迷茫。这里总结了30条网页编码的“秘技”,只要在编码过程中牢记它们,灵活运用,你一定会写出一手漂亮的代码,早日迈入专业开发者的行列。

1. 一定要闭合标签

在以往的页面源代码里,经常看到这样的语句:

  1. <li>Some?text?here.??
  2. <li>Some?new?text?here.??
  3. <li>You?get?the?idea.?

也许过去我们可以容忍这样的非闭合标签,但在今天的标准来看,这是非常不可取的,是必须百分百避免的。一定要注意闭合你的标签,否则将无法通过验证,并且容易出现一些难以预见的问题。

最好使用这样的形式:

  1. <ul>??
  2. ??<li>Some?text?here.?</li>??
  3. ??<li>Some?new?text?here.?</li>??
  4. ??<li>You?get?the?idea.?</li>??
  5. </ul>?

2. 声明正确的文档类型( DocType )

Declare doctype

笔者早先曾加入过许多CSS论坛,在那里,如果有用户遇到问题,我们会建议他首先做两件事:

1. 验证CSS文件,解决所有可见的错误

2. 加上文档类型 Doctype

DOCTYPE 定义在HTML标签出现之前,它告诉浏览器这个页面包含的是HTML,XHTML,

还是两者混合出现,这样浏览器才能正确的解析标记。

通常有四种文档类型可供选择:

  1. <!DOCTYPE HTML PUBLIC “-//W3C//DTD HTML 4.01//EN” “http://www.w3.org/TR/html4/strict.dtd”>
  2. <!DOCTYPE HTML PUBLIC “-//W3C//DTD HTML 4.01 Transitional//EN” “http://www.w3.org/TR/html4/loose.dtd”>
  3. <!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
  4. <!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Strict//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd”>

关于该使用什么样的文档类型声明,一直有不同的说法。通常认为使用最严格的声明是最佳选择,但研究表明,大部分浏览器会使用普通的方式解析这种声 明,所以很多人选择使用HTML4.01标准。选择声明的底线是,它是不是真的适合你,所以你要综合考虑来选择适合你得项目的声明。

3.? 不要使用嵌入式CSS样式

当你在埋头写代码时,可能会经常顺手或偷懒的加上一点嵌入式css代码,就象这样:

  1. <p?style=“color:?red;”>Oncoding编码营</p>?

?这样看起来即方便又没有问题,但是它会在你得代码中产生问题。

在你开始写代码时,最好是在内容结构完成之后再开始加入样式代码。

这样的编码方式就像打游击,是一种很山寨的做法。——Chris Coyier

更好的做法是,把这个P的样式定义在样式表文件里:

  1. #someElement?>?p?{??
  2. ??color:?red;??
  3. }?

4. 在页面head标签中引入所有的样式表文件

理论上讲,你可以在任何位置引入CSS样式表,但HTML规范建议在网页的head标记中引入,这样可以加快页面的渲染速度。

在雅虎的开发过程中,我们发现,在head标签中引入样式表,会加快网页加载速度,

因为这样可以使页面逐步渲染。 ? —— ySlow团队

  1. <head>??
  2. <title>My?Favorites?Kinds?of?Corn</title>??
  3. <link?rel=“stylesheet”?type=“text/css”?media=“screen”?href=“path/to/file.css”? />??
  4. <link?rel=“stylesheet”?type=“text/css”?media=“screen”?href=“path/to/anotherFile.css”? />??
  5. </head>?

5. 在页面底部引入JavaScript文件

Place JS at bottom

要记住一个原则,就是让页面以最快的速度呈现在用户面前。当加载一个脚本时,页面会暂停加载,直到脚本完全载入。所以会浪费用户更多的时间。

如果你的JS文件只是要实现某些功能,(比如点击按钮事件),那就放心的在body底部引入它,这绝对是最佳的方法。

举例:

  1. <p>And?now?you?know?my?favorite?kinds?of?corn.?</p>??
  2. <script?type=“text/javascript”?src=“path/to/file.js”></script>??
  3. <script?type=“text/javascript”?src=“path/to/anotherFile.js”></script>??
  4. </body>??
  5. </html >?

6. 不要使用嵌入式JavaScript,这都21世纪了!

许多年以前,还存在一种这样的方式,就是直接将JS代码加入到标签中。尤其是在简单的图片相册中非常常见。本质上讲,一个“onclick”事件是 附加在 标签上的,其效果等同于一些JS代码。不需要讨论太多,非常不应该使用这样的方式,应该把代码转移到一个外部JS文件中,然后使用“ addEventListener / attachEvent ”加入时间侦听器。或者使用jQuery等框架,之需要使用其“clock”方法。

  1. $(‘a#moreCornInfoLink’).click(function()?{??
  2. ??alert(‘Want?to?learn?more?about?corn?’);??
  3. });?

7. 开发中随时进行标准验证

validate continuously

很多人并不真正理解标准验证的意义和价值,笔者在一篇 博客中详细分析了这个问题。一句话,标准验证是为你服务的,不是给你找麻烦的。