本文总结了30条html代码编写指南,只要在编写html代码的过程中牢记它们,灵活运用,你一定会写出一手漂亮的代码,早日迈入专业开发者的行列。
在以往的页面源代码里,经常看到这样的语句:
<li>some text here.<li>some new text here.<li>you get the idea.
也许过去我们可以容忍这样的非闭合html标签,但在今天的标准来看,这是非常不可取的,是必须百分百避免的。一定要注意闭合你的html标签,否则将无法通过验证,并且容易出现一些难以预见的问题。
最好使用这样的形式:
<ul><li>some text here. </li><li>some new text here. </li><li>you get the idea. </li></ul>
笔者早先曾加入过许多css论坛,在那里,如果有用户遇到问题,我们会建议他首先做两件事:
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标准。选择声明的底线是,它是不是真的适合你,所以你要综合考虑来选择适合你得项目的声明。
当你在埋头写代码时,可能会经常顺手或偷懒的加上一点嵌入式css代码,就象这样:
<p style="color: red;">网页设计</p>
这样看起来即方便又没有问题,但是它会在你得代码中产生问题。
在你开始写代码时,最好是在内容结构完成之后再开始加入样式代码。
这样的编码方式就像打游击,是一种很山寨的做法。——chris coyier
更好的做法是,把这个p的样式定义在样式表文件里:
someelement > p {color: red;}
理论上讲,你可以在任何位置引入css样式表,但html规范建议在网页的head标记中引入,这样可以加快页面的渲染速度。
在雅虎的开发过程中,我们发现,在head标签中引入样式表,会加快网页加载速度,
因为这样可以使页面逐步渲染。 —— yslow团队
<head><title>my favorites kinds of corn</title><link rel="stylesheet" type="text/css" media="screen" href="path/to/file.css" /><link rel="stylesheet" type="text/css" media="screen" href="path/to/anotherfile.css" /></head>
要记住一个原则,就是让页面以最快的速度呈现在用户面前。当加载一个脚本时,页面会暂停加载,直到脚本完全载入。所以会浪费用户更多的时间。
如果你的js文件只是要实现某些功能,(比如点击按钮事件),那就放心的在body底部引入它,这绝对是最佳的方法。
举例:
<p>and now you know my favorite kinds of corn. </p><script type="text/javascript" src="path/to/file.js"></script><script type="text/javascript" src="path/to/anotherfile.js"></script></body></html>
许多年以前,还存在一种这样的方式,就是直接将js代码加入到html标签中。尤其是在简单的图片相册中非常常见。本质上讲,一个“onclick”事件是附加在 标签上的,其效果等同于一些js代码。不需要讨论太多,非常不应该使用这样的方式,应该把代码转移到一个外部js文件中,然后使用“ addeventlistener / attachevent ”加入时间侦听器。或者使用jquery等框架,之需要使用其“clock”方法。
$('a#morecorninfolink').click(function() {alert('want to learn more about corn?');});
很多人并不真正理解标准验证的意义和价值,笔者在一篇博客中详细分析了这个问题。一句话,标准验证是为你服务的,不是给你找麻烦的。
如果你刚开始从事网页制作,那强烈建议你下载这个网页开发工具条 ,并在编码过程中随时使用”html标准验证”和“css标准验证”。如果你认为css是一种非常好学的语言,那么它会把你整的死去活来。你的不严谨的代码会让你的页面漏洞百出,问题不断,一个好的方法就是—— 验证,验证,再验证。
firebug是当之无愧的网页开发最佳插件,它不但可以调试javascript,还可以直观的让你了解页面标记的属性和位置。不用多说, 下载它!
据笔者观察,大部分的使用者仅仅使用了firebug 20%的功能,那真是太浪费了,你不妨花几个小时的时间来系统学习这个工具,相信会让你事半功倍。
firebug教程:
理论上讲,你可以像这样随性的书写标记:
<div><p>here's an interesting fact about corn. </p></div>
最好不要这样写,费力气输入大些字母没有任何用处,并且会让代码很难看,这样子就很好:
<div><p>here's an interesting fact about corn. </p></div>
笔者建议你在网页中使用其中全部六种标记,虽然大部分人只会用到前四个,但使用最多的h会有很多好处,比如设备友好、搜索引擎友好等,不妨把你的p标签都替换成h6。
今天笔者在twitter上发起一次讨论:是该把h1定义到logo上还是定义到文章标题上,有80%的人选择了后者。
当然具体如何使用要看你的需求,但我建议你在建立博客的时候,将文章题目定为h1,这对搜索引擎优化(seo)是非常有好处的。
在过去几年里,雅虎的团队在前端开发领域做了许多伟大的工作。前不久,它们发布了一个叫yslow的firebug扩展,它会分析你的<网页,并返回 一个“成绩单”,上面细致分析了这个网页的方方面面,提出需要改进的地方,虽然它有点苛刻,但它绝对会对你有所帮助,强烈推荐—— yslow!
通常网站都会有导航菜单,你可以用这样的方式定义:
<div id="nav"><a href="#">home </a><a href="#">about </a><a href="#">contact </a></div>
如果你想书写优美的代码,那最好不要用这种方式,
为什么要用ul布局导航菜单?
——因为ul生来就是为定义列表准备的
最好这样定义:
<ul id="nav"><li><a href="#">home</a></li><li><a href="#">about</a></li><li><a href="#">contact</a></li></ul>
ie一直以来都是前端开发人员的噩梦!
如果你的css样式表基本定型了,那么可以为ie单独建立一个样式表,然后这样仅对ie生效:
<!--[if lt ie 7]><link rel="stylesheet" type="text/css" media="screen" href="path/to/ie.css" /><![endif]-->
这些代码的意思是:如果用户浏览器是ie6及以下,那这段代码才会生效。如果你想把ie7也包含进来,那么就把“[if lt ie 7]”改为“[if lte ie 7]”。
不论你是windows还是mac用户,这里都有很多优秀的编辑器供你选择:
回望我们大多数人写的第一个页面,一定会发现严重的 “div癖”( divitis ),通常初学者的本能就是把一个段落用div包起来,然后为了控制定位而套上更多的div。—— 其实这是一种低效而有害的做法。
网页写完后,一定要多次回头检查,尽量的减少元素的数量。
能用ul布局的列表就不要用一个个的div去布局。
正如写文章的关键是“缩减,缩减,缩减”一样,写页面也要遵循这个标准。
为图片加上alt属性的好处是不言而喻的 —— 这样可以让禁用图片或者使用特殊设备的用户无障碍得了解你的王爷信息,并且对图像搜索引擎友好。
firefox不支持显示图像alt属性,可以加入title属性:
<img src="cornimage.jpg" alt="网页设计" title="网页设计" />
我经常不知不觉的学习工作到凌晨,我认为这是个很好的状况。
我的“啊~哈!”时间( “ah-ha” moments,指柳暗花明或豁然开朗的时刻)通常都发生在深夜,比如我彻底理解javascript的“闭包”概念,就是在这样一种情况下。如果你还没有感受过这种奇妙的时刻,那就马上试试吧!
没有什么比模仿你的偶像能让你更快的学习html。起初,我们都要甘做复印机,然后慢慢得发展自己的风格。研究你喜欢的网站页面代码,看看他们是怎么实现的。这是高手的必经之路,你一定要试一下。注意:只是学习和模仿他们的编码风格,而不是抄袭和照搬!
留意网络上各种炫酷的javascript效果,如果看上去是使用了插件,那根据它源码中head标签内的文件名,就可以找到这个插件名称,然后就可以学习它据为己用。
这一条在你制作其他公司企业网站时尤为必要。你自己不使用blockquote标记?那用户可能会用,你自己不使用ol?用户也可能会。花时间做一个页面,显示出ul, ol, p, h1-h6, blockquotes, 等等元素的样式,检查一下是否有遗漏。
译者注:英文原文标题为“使用twitter”
现在互联网上流行着许多可以免费加在网页中的api,这些工具非常强大。它可以帮你实现许多巧妙的功能,更重要的是可以帮你宣传网站。
photoshop是前端工程师的一个重要工具,如果你已经熟练掌握html和css,那不妨多学习一下photshop。
虽然有些html标签很少用到,但你依然应该了解他们。比如“abbr”、“cite”等,你必须学习它们以备不时之需。
网络上有许许多多优秀的资源,而社区中也隐藏着许多高手,这里你既可以自学,也能请教经验丰富的开发者。
css reset也就reset css ,就是重置一些html标签样式,或者说默认的样式。
关于是否应该使用css reset,网上也有激烈的争论,笔者是建议使用的。你可以先选用一些成熟的css reset,然后慢慢演变成适合自己的。
简单来说,你应该尽可能的对齐你的网页元素。可以观察一下你喜欢的网站,它们的logo、标题、图表、段落肯定是对得非常整齐的。否则就会显得混乱和不专业。
现在你已经掌握了html、css、photoshop知识,那么你还需要学习如何把psd转换为网页上的图片和背景,下面有两个不错的教程:
javascript和css都有许多优秀的框架,但如果你是初学者,不要急于使用它们。如果你还没能熟练的驾驭css,使用框架会混淆你的知识体系。
css框架是为熟练开发者设计的,这样会节省它们大量的时间。
新闻热点
疑难解答