君临天下锋 發表於 2021-4-18 18:41:00

Web 前端开发规范手册

<p align="center">&nbsp;</p>
<p align="left">一、规范目的</p>
<p align="left"><strong>Web</strong><strong>&nbsp;</strong>前端开发规范手册</p>
<p align="left">1.1&nbsp;概述&nbsp;.....................................................................................................................................&nbsp;1</p>
<p align="left">二、文件规范</p>
<p align="left">2.1&nbsp;文件命名规则.........................................................................................................................1<br>
2.2&nbsp;文件存放位置..........................................................................................................................2<br>
2.3 css&nbsp;书写规范..........................................................................................................................3<br>
2.4 html&nbsp;书写规范.........................................................................................................................7<br>
2.5 JavaScript&nbsp;书写规范.............................................................................................................11<br>
2.6&nbsp;图片规范...................................................................................................................................12<br>
2.7&nbsp;注释规范...................................................................................................................................13<br>
2.8 css&nbsp;浏览器兼容.......................................................................................................................13</p>
<p align="left">一、规范目的</p>
<p align="left">1.1&nbsp;概述</p>
<p align="left">为提高团队协作效率,&nbsp;便于后台人员添加功能及前端后期优化维护,&nbsp;输出高质量的文档,&nbsp;特制订此文档.&nbsp;本规范文档一经确认,&nbsp;前端开发人员必须按本文档规范进行前台页面开发.&nbsp;本文档如有不对或者不合适的地方请及时提出,&nbsp;经讨论决定后可以更改此文档.</p>
<p align="left">二、文件规范</p>
<p align="left"><strong>2.1&nbsp;</strong>文件命名规则</p>
<p align="left">文件名称统一用小写的英文字母、数字和下划线的组合,其中不得包含汉字、空格和特殊字符;命名原则的指导思想一是使得你自己和工作组的每一个成员能够方便的理解每一个文件的意义,二是当我们在文件夹中使用“按名称排例”的命令时,同一种大类的文件能够排列在一起,以便我们查找、修改、替换、计算负载量等等操作。</p>
<p align="left">a. HTML&nbsp;的命名原则<br>
引文件统一使用&nbsp;<strong>index.htm index.html index.asp&nbsp;</strong>文件名(小写)</p>
<p align="left">各子页命名的原则首先应该以栏目名的英语翻译取单一单词为名称。例如:<br>
关于我们&nbsp;\ aboutus<br>
信息反馈&nbsp;\ feedback<br>
产 品&nbsp;\ product如果栏目名称多而复杂并不好以英文单词命名,则统一使用该栏目名称拼音或拼音的首字母表示;每一个目录中应该包含一个缺省的&nbsp;html&nbsp;文件,文件名统一用&nbsp;<strong>index.htm index.html index.asp</strong>;</p>
<p align="left">b.&nbsp;图片的命名原则<br>
图片的名称分为头尾两部分,用下划线隔开,头部分表示此图片的大类性质例如:广告、标志、菜单、按钮等等。<br>
放置在页面顶部的广告、装饰图案等长方形的图片取名:&nbsp;banner<br>
标志性的图片取名为:&nbsp;logo<br>
在页面上位置不固定并且带有链接的小图片我们取名为&nbsp;button在页面上某一个位置连续出现,性质相同的链接栏目的图片我们取名:&nbsp;menu<br>
装饰用的照片我们取名:&nbsp;pic<br>
不带链接表示标题的图片我们取名:&nbsp;title<br>
范 例 :&nbsp;<strong>banner_sohu.gif banner_sina.gif menu_aboutus.gif
menu_job.gif title_news.giflogo_police.gif logo_national.gif pic_people.jpg</strong>鼠标感应效果图片命名规范为"图片名+_+on/off"。<br>
例如:<strong>menu1_on.gif
menu1_off.gif</strong></p>
<p align="left">c. javascript&nbsp;的命名原则<br>
例如:广告条的&nbsp;javascript&nbsp;文件名为&nbsp;ad.js&nbsp;弹出窗口的&nbsp;javascript&nbsp;文件名为&nbsp;pop.js</p>
<p align="left">d.&nbsp;动态语言文件命名原则以性质_描述,描述可以有多个单词,用“_”隔开,性质一般是该页面得概要。范例:<strong>register_form.asp register_post.asp topic_lock.asp</strong></p>
<p align="left"><strong>2.2&nbsp;</strong>文件存放位置规范</p>
<p align="left">&nbsp;</p>
<p align="left">_Root<br>
cn&nbsp;存放中文&nbsp;HTML&nbsp;文件en&nbsp;存放英文&nbsp;HTML&nbsp;文件flash&nbsp;存放&nbsp;Flash&nbsp;文件images&nbsp;存放图片文件imagestudio&nbsp;存放&nbsp;PSD&nbsp;源文件flashstudio&nbsp;存放&nbsp;flash&nbsp;源文件inc&nbsp;存放include&nbsp;文件library&nbsp;存放&nbsp;DW&nbsp;库文件media&nbsp;存放多媒体文件project&nbsp;存放工程项目资料temp&nbsp;存放客户原始资料js&nbsp;存放&nbsp;JavaScript&nbsp;脚本</p>
<p align="left">css&nbsp;存放&nbsp;CSS&nbsp;文件 </p>
<p align="left"><strong>2.3 CSS&nbsp;</strong>书写规范基本原则:</p>
<p align="left">CSS&nbsp;样式可细分为&nbsp;3&nbsp;类:自定义样式、重新定义&nbsp;HTML&nbsp;样式、链接状态样式。<br>
1.&nbsp;样式为设计师自定义的新&nbsp;CSS&nbsp;样式,影响被使用本样式的区域,用于完成网页中局部的样式设定。样式名
“<strong>.</strong>”+“相应样式效果描述的单词或缩写”例:“&nbsp;<strong>.shadow</strong>”文字样式样式名“<strong>.</strong>no”+“字号”+“行距”+“颜色缩写”例:“&nbsp;<strong>.no12&nbsp;</strong>” 、“&nbsp;<strong>.no12-24&nbsp;</strong>”<br>
2.&nbsp;义&nbsp;HTML&nbsp;样式为设计师重新定义已有的&nbsp;HTML&nbsp;标签样式,影响全部的被设定标签样式,用于统一网页中某一标签的样式定义。样式名“HTML&nbsp;标签”例:<strong>hr { border: 1px dotted #333333 }<br>
</strong>3.&nbsp;态样式为设计师对链接不同状态设定特殊样式,影响被使用本样式区域中的链接。该样式写法有2种:a.nav:link&nbsp;nav.a:link&nbsp;第一种只能修饰<strong>&lt;a&gt;</strong>标签中;第二种可以修饰所有包含有<strong>&lt;a&gt;</strong>标签的其他标签。<br>
页面内的样式加载必须用链接方式&lt;link rel="stylesheet" type="text/css"
href="style/style.css"&gt;</p>
<p align="left">注意细则:</p>
<p align="left">1.&nbsp;协作开发及分工: i&nbsp;会根据各个模块,&nbsp;同时根据页面相似程序,&nbsp;事先写好大体框架文件,&nbsp;分配给前端人员实现内部结构&amp;表现&amp;行为;&nbsp;共用&nbsp;css&nbsp;文件&nbsp;base.css&nbsp;由&nbsp;i&nbsp;书写,&nbsp;协作开发过程中,&nbsp;每个页面请务必都要引入,&nbsp;此文件包含&nbsp;reset&nbsp;及头部底部样式,&nbsp;此文件不可随意修改;<br>
2. class&nbsp;与&nbsp;id&nbsp;的使用: id&nbsp;是唯一的并是父级的, class&nbsp;是可以重复的并是子级的,&nbsp;所以&nbsp;id&nbsp;仅使用在大的模块上, class&nbsp;可用在重复使用率高及子级中;
id&nbsp;原则上都是由我分发框架文件时命名的,&nbsp;为&nbsp;JavaScript&nbsp;预留钩子的除外;</p>
<ol>
<li>为&nbsp;JavaScript&nbsp;预留钩子的命名,&nbsp;请以&nbsp;js_&nbsp;起始,&nbsp;比如: js_hide, js_show;</li>
<li>class&nbsp;与&nbsp;id&nbsp;命名:&nbsp;大的框架命名比如&nbsp;header/footer/wrapper/left/right&nbsp;之类的在&nbsp;2&nbsp;中由&nbsp;i&nbsp;统一命名.其他</li>

</ol>
<p align="left">样式名称由 小写英文&nbsp;&amp;&nbsp;数字&nbsp;&amp; _&nbsp;来组合命名,&nbsp;如&nbsp;i_comment, fontred, width200;&nbsp;避免使用中文拼音,尽量使用简易的单词组合;&nbsp;总之,&nbsp;命名要语义化,&nbsp;简明化.</p>
<p align="left">5.<br>
a,<br>
b,<br>
c,<br>
d,<br>
id="mainnav"&gt;&lt;/div&gt;中加入新的&nbsp;div&nbsp;元素,<br>
按&nbsp;a&nbsp;命名法则: &lt;div
id="mainnav"&gt;&lt;div
class="firstnav"&gt;...&lt;/div&gt;&lt;/div&gt;,样式写法: #mainnav .firstnav{.......}</p>
<p align="left">规避&nbsp;class&nbsp;与&nbsp;id&nbsp;命名(此条重要,&nbsp;若有不明白请及时与&nbsp;i&nbsp;沟通):通过从属写法规避,&nbsp;示例见&nbsp;d;<br>
取父级元素&nbsp;id/class&nbsp;命名部分命名,&nbsp;示例见&nbsp;d;重复使用率高的命名,&nbsp;请以自己代号加下划线起始,&nbsp;比如&nbsp;i_clear;</p>
<p align="left">a,b&nbsp;两条,&nbsp;适用于在&nbsp;2&nbsp;中已建好框架的页面,&nbsp;如,&nbsp;要在&nbsp;2&nbsp;中已建好框架的页面代码&lt;div</p>
<p align="left">按&nbsp;b&nbsp;命名法则: &lt;div id="mainnav"&gt;&lt;div
class="main_firstnav"&gt;...&lt;/div&gt;&lt;/div&gt;,<br>
样式写法: .main_firstnav{.......}<br>
6. css&nbsp;属性书写顺序,&nbsp;建议遵循
布局定位属性--&gt;自身属性--&gt;文本属性--&gt;其他属性.&nbsp;此条可根据自身习惯书写,&nbsp;但尽量保证同类属性写在一起.&nbsp;属性列举:&nbsp;布局定位属性主要包括: margin、padding、float(包括clear)、position(相应的&nbsp;top,right,bottom,left)、display、visibility、overflow&nbsp;等;自身属性主要包括: width&amp; height &amp; background &amp; border;&nbsp;文本属性主要包括:font、color、text-align、text-decoration、text-indent</p>
<p align="left">等;其他属性包括: list-style(列表样式)、vertical-vlign、cursor、z-index(层叠顺序)&nbsp;、zoom&nbsp;等.我所列出的这些属性只是最常用到的,&nbsp;并不代表全部;</p>
<ol>
<li>书写代码前,&nbsp;考虑并提高样式重复使用率;</li>
<li>充分利用&nbsp;html&nbsp;自身属性及样式继承原理减少代码量,&nbsp;比如:</li>

</ol>
<p align="left">&lt;ul class="list"&gt;&lt;li&gt;这儿是标题列表&lt;span&gt;2010-09-15&lt;/span&gt;&lt;/ul&gt;定义&nbsp;ul.list li{position:relative} ul.list li
span{position:absolute; right:0}即可实现日期居右显示</p>
<ol>
<li>样式表中中文字体名,&nbsp;请务必转码成&nbsp;unicode&nbsp;码,&nbsp;以避免编码错误时乱码;</li>
<li>背景图片请尽可能使用sprite技术,减小http请求,考虑到多人协作开发,sprite按模块制作;</li>
<li>使用&nbsp;table&nbsp;标签时(尽量避免使用&nbsp;table&nbsp;标签),&nbsp;请不要用&nbsp;width/ height/cellspacing/cellpadding&nbsp;等&nbsp;table</li>

</ol>
<p align="left">属性直接定义表现,&nbsp;应尽可能的利用&nbsp;table&nbsp;自身私有属性分离结构与表现,&nbsp;如thead,tr,th,td,tbody,tfoot,colgroup,scope; (cellspaing&nbsp;及&nbsp;cellpadding&nbsp;的&nbsp;css&nbsp;控 制
方 法&nbsp;:table{border:0;margin:0;border-collapse:collapse;} table th, table
td{padding:0;} , base.css&nbsp;文件中我会初始化表格样式)</p>
<p align="left">12.&nbsp;杜绝使用&lt;metahttp-equiv="X-UA-Compatible"content="IE=7"/&gt;兼容ie8;<br>
13.&nbsp;用png图片做图片时,要求图片格式为png-8格式,若png-8实在影响图片质量或其中有半透明效果,请为&nbsp;ie6&nbsp;单独定义背景:background:none;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=crop,src=’img/bg.png’);<br>
14.&nbsp;避免兼容性属性的使用,比如text-shadow||css3的相关属性;<br>
15.&nbsp;减少使用影响性能的属性,比如position:absolute||float;<br>
16.&nbsp;必须为大区块样式添加注释,&nbsp;小区块适量注释;<br>
17.&nbsp;代码缩进与格式:建议单行书写,可根据自身习惯,后期优化i会统一处理;</p>
<p align="left">命名规则:</p>
<p align="left">头:header<br>
内容:content/container<br>
尾:footer<br>
导航:nav<br>
侧栏:sidebar<br>
栏目:column页面外围控制整体布局宽度:wrapper左右中:left
right center登录条:loginbar<br>
标志:logo<br>
广告:banner<br>
页面主体:main<br>
热点:hot<br>
新闻:news<br>
下载:download<br>
子导航:subnav<br>
菜单:menu</p>
<p align="left">子菜单:submenu搜索:search友情链接:friendlink页脚:footer版权:copyright滚动:scroll内容:content标签页:tab文章列表:list提示信息:msg小技巧:tips栏目标题:title加入:joinus指南:guild服务:service注册:regsiter状态:status投票:vote合作伙伴:partner</p>
<p align="left">(二)注释的写法:/* Footer */内容区<br>
/* End Footer */</p>
<p align="left">(三)id&nbsp;的命名:<br>
(1)页面结构<br>
容器: container<br>
页头:header内容:content/container页面主体:main<br>
页尾:footer<br>
导航:nav<br>
侧栏:sidebar<br>
栏目:column页面外围控制整体布局宽度:wrapper左右中:left
right center</p>
<p align="left">(2)导航<br>
导航:nav主导航:mainbav子导航:subnav顶导航:topnav边导航:sidebar左导航:leftsidebar右导航:rightsidebar</p>
<p align="left">菜单:menu子菜单:submenu标题: title<br>
摘要: summary</p>
<p align="left">(3)功能标志:logo广告:banner登陆:login登录条:loginbar注册:regsiter搜索:search功能区:shop标题:title加入:joinus状态:status按钮:btn滚动:scroll标签页:tab文章列表:list提示信息:msg当前的: current小技巧:tips<br>
图标: icon注释:note指南:guild服务:service热点:hot新闻:news下载:download投票:vote合作伙伴:partner友情链接:link版权:copyright\</p>
<p align="left">基本样式:</p>
<p align="left">/* CSS Document */<br>
body {margin:0; padding:0; font:12px "\5B8B\4F53",san-serif;background:#fff;}div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,blockquote,p{padding:0;margin:0;}<br>
table,td,tr,th{font-size:12px;}<br>
li{list-style-type:none;}<br>
img{vertical-align:top;border:0;}</p>
<p align="left">ol,ul {list-style:none;}<br>
h1,h2,h3,h4,h5,h6 {font-size:12px; font-weight:normal;}address,cite,code,em,th
{font-weight:normal; font-style:normal;}.fB{font-weight:bold;}<br>
.f12px{font-size:12px;}<br>
.f14px{font-size:14px;}<br>
.left{float:left;}<br>
.right{float:right;}</p>
<p align="left">a {color:#2b2b2b; text-decoration:none;}<br>
a:visited {text-decoration:none;}<br>
a:hover {color:#ba2636;text-decoration:underline;}a:active {color:#ba2636;}</p>
<p align="left">重定义的最先,伪类其次,自定义最后,便于自己和他人阅读!</p>
<p align="left">不同浏览器上字号保持一致,字号建议用点数&nbsp;pt&nbsp;和像素&nbsp;px&nbsp;来定义,pt&nbsp;一般使用中文宋体的&nbsp;9pt&nbsp;和&nbsp;11pt,px&nbsp;一般使用中文宋体&nbsp;12px&nbsp;和&nbsp;14.7px&nbsp;这是经过优化的字号,黑体字或者宋体字加粗时,一般选用&nbsp;11pt&nbsp;和14.7px&nbsp;的字号比较合适。中英文混排时,我们尽可能的将英文和数字定义为&nbsp;verdana&nbsp;和&nbsp;arial&nbsp;两种字体。</p>
<p align="left"><strong>2.4
html&nbsp;</strong>书写规范</p>
<p align="left"><strong>1.&nbsp;</strong>网页制作细节&nbsp;<strong>---- head&nbsp;</strong>区代码规范<br>
head&nbsp;区是指&nbsp;HTML&nbsp;代码的&lt;head&gt;和&lt;/head&gt;之间的内容。必须加入的标签<br>
a)&nbsp;公司版权注释&nbsp;&lt;!--- The site is designed by
EHM,Inc 07/2005 ---&gt;b)&nbsp;网页显示字符集<br>
简体中文:<br>
繁体中文:<br>
英 语:<br>
c)&nbsp;网页制作者信息</p>
<ol>
<li>d) &nbsp;网站简介</li>
<li>e) &nbsp;搜索关键字</li>
<li>f) &nbsp;网页的&nbsp;css&nbsp;规范</li>
<li>g) &nbsp;网页标题</li>

</ol>
<p align="left">可以选择加入的标签<br>
a)&nbsp;设定网页的到期时间。一旦网页过期,必须到服务器上重新调阅。<br>
&lt;META
HTTP-EQUIV="expires" CONTENT="Wed, 26 Feb 1997 08:21:57 GMT"&gt;b)&nbsp;禁止浏览器从本地机的缓存中调阅页面内容。<br>
&lt;META
HTTP-EQUIV="Pragma" CONTENT="no-cache"&gt;<br>
c)&nbsp;用来防止别人在框架里调用你的页面。<br>
&lt;META
HTTP-EQUIV="Window-target" CONTENT="_top"&gt;<br>
d)&nbsp;自动跳转。</p>
<p align="left">&lt;META HTTP-EQUIV="Content-Type" CONTENT="text/html;
charset=gb2312"&gt;</p>
<p align="left">&lt;META HTTP-EQUIV="Content-Type" CONTENT="text/html;
charset=utf-8"&gt;</p>
<p align="left">&lt;META HTTP-EQUIV="Content-Type" CONTENT="text/html;
charset=utf-8"&gt;</p>
<p align="left">&lt;META name="author"
content="webmaster@maketown.com"&gt;</p>
<p align="left">&lt;META NAME="DESCRIPTION"
CONTENT="xxxxxxxxxxxxxxxxxxxxxxxxxx"&gt;</p>
<p align="left">&lt;META NAME="keywords"
CONTENT="xxxx,xxxx,xxx,xxxxx,xxxx,"&gt;</p>
<p align="left">&lt;LINK href="../css/style.css" rel="stylesheet"
type="text/css"&gt;</p>
<p align="left">&lt;title&gt;xxxxxxxxxxxxxxxxxx&lt;/title&gt;</p>
<p align="left">&lt;META HTTP-EQUIV="Refresh" CONTENT="5;URL=http://www.yahoo.com"&gt;&nbsp;5&nbsp;指时间停留&nbsp;5&nbsp;秒e)&nbsp;网页搜索机器人向导。用来告诉搜索机器人哪些页面需要索引,哪些页面不需要索引。<br>
&lt;META
NAME="robots" CONTENT="none"&gt;<br>
CONTENT&nbsp;的参数有&nbsp;all,none,index,noindex,follow,nofollow。默认是&nbsp;all。</p>
<ol>
<li>f) &nbsp;收藏夹图标&nbsp;&lt;link rel = "Shortcut Icon" href="favicon.ico"&gt;</li>
<li>g) &nbsp;所有的&nbsp;javascript&nbsp;的调用尽量采取外部调用.</li>

</ol>
<p align="left">&lt;SCRIPT LANGUAGE="JavaScript"
SRC="script/xxxxx.js"&gt;&lt;/SCRIPT&gt;h)&nbsp;附&lt;body&gt;标签:</p>
<p align="left">&lt;body&gt;标签不属于&nbsp;head&nbsp;区,这里强调一下,为了保证浏览器的兼容性,必须设置页面背景&lt;bodybgcolor="#FFFFFF"&gt;</p>
<p align="left"><strong>2.&nbsp;</strong>网页制作细节&nbsp;<strong>----&nbsp;</strong>字体<br>
<strong>1.&nbsp;</strong>在设定字体样式时对于文字字号样式和行间距应必须使用&nbsp;CSS&nbsp;样式表。禁止在页面中出现&nbsp;&lt;fontsize=?&gt;&nbsp;标记。</p>
<p align="left"><strong>2.</strong>在网页中中文应首选使用宋体。英文和数字首选使用&nbsp;verdana&nbsp;和&nbsp;arial&nbsp;两种字体。一般使用中文宋体的9pt和11pt&nbsp;或12px和14.7px这是经过优化的字号,黑体字或者宋体字加粗时,一般选用11pt和14.7px的字号比较合适。</p>
<p align="left"><strong>3.&nbsp;</strong>为了最大程度的发挥浏览器自动排版的功能,在一段完整的文字中请尽量不要使用&lt;br&gt;&nbsp;来人工干预分段。</p>
<p align="left"><strong>4.</strong>不同语种的文字之间应该有一个半角空格,但避头的符号之前和避尾的符号之后除外,汉字之间的标点要用全角标点,英文字母和数字周围的括号应该使用半角括号。</p>
<p align="left"><strong>5.&nbsp;</strong>请不要在网页中连续出现多于一个的 也尽量少使用全角空格(英文字符集下,全角空格会变成乱码),空白应该尽量使用&nbsp;text-indent, padding, margin, hspace,
vspace以及透明的&nbsp;gif&nbsp;图片来实现。</p>
<p align="left"><strong>6.&nbsp;</strong>行距建议用百分比来定义,常用的两个行距的值是&nbsp;line-height:120%/150%.</p>
<p align="left"><strong>7.&nbsp;</strong>排版中我们经常会遇到需要进行首行缩进的处理,不要使用 或者全角空格来达到效果,规范的做法是在样式表中定义&nbsp;p { text-indent: 2em; }&nbsp;然后给每一段加上&nbsp;&lt;p&gt;标记,注意,一般情况下,请不要省略&lt;/p&gt;&nbsp;结束标记 。</p>
<p align="left"><strong>3.&nbsp;</strong>网页制作细节&nbsp;<strong>----&nbsp;</strong>链接<br>
<strong>1.&nbsp;</strong>网站中的链接路径全部采用相对路径,一般链接到某一目录下的缺省文件的链接路径不必写全名,如我们不必这样:&lt;a href=”aboutus/index.htm”&gt;&nbsp;而应该这样:&lt;a href=”aboutus/”&gt;,所有内页指向首页的链接写成&lt;a href=”/”&gt;</p>
<p align="left"><strong>2.&nbsp;</strong>在浏览器里,当我们点击空链接时,它会自动将当前页面重置到首端,从而影响用户正常的阅读内容,我们用代码“javascript:void(null)”代替原来的“#”标记</p>
<p align="left">&nbsp;</p>
<p align="left"><strong>4.&nbsp;</strong>网页制作细节&nbsp;<strong>----&nbsp;</strong>表格<br>
1px&nbsp;表格&nbsp;style="border-collapse: collapse"<br>
实例如下:<br>
&lt;table
border="1" cellspacing="0" width="32"
height="32" style="border-collapse:collapse"<br>
bordercolor="#000000" cellpadding="0"&gt;<br>
&lt;tr&gt;<br>
&lt;td&gt;&lt;/td&gt;<br>
&lt;/tr&gt;<br>
&lt;/table&gt;<br>
设置亮、暗边框颜色表格有亮边框(bordercolorlight)和暗边框(bordercolordark)两个属性可以对表格样式设置。<br>
&lt;table
border="1" width="500" bordercolorlight="#000000"
bordercolordark="#FFFFFF"&gt;</p>
<p align="left">在写&nbsp;&lt;table&gt;&nbsp;互相嵌套时,严格按照的规范,对于单独的一个&lt;table&gt;来说,&lt;table&gt;&lt;tr&gt;对齐,&lt;td&gt;&nbsp;缩进两个半角空格,&lt;td&gt;&nbsp;中如果还有嵌套的表格,&lt;table&gt;也缩进两个半角空格,如果&lt;td&gt;中没有任何嵌套的表格,&lt;/td&gt;&nbsp;结束标记应该与&nbsp;&lt;td&gt;&nbsp;处于同一行,不要换行,如我们注意在源代码中不应有这样的代码:</p>
<p align="left"><strong>&lt;td&gt;&lt;img
src=”../images/sample.gif”&gt;<br>
&lt;/td&gt;<br>
</strong>而应该是这样的:<br>
<strong>&lt;td&gt;&lt;img
src=”../images/sample.gif”&gt;&lt;/td&gt;</strong>这是因为浏览器认为换行相当于一个半角空格,以上不规范的写法相当于无意中增加一个半角空格,如果确实有必要增加一个半角空格,也应该这样写:</p>
<p align="left"><strong>&lt;td&gt;&lt;img
src=”../images/sample.gif”&gt; &lt;/td&gt;</strong></p>
<p align="left">一个网页要尽量避免用整个一张大表格,所有的内容都嵌套在这个大表格之内,因为浏览器在解释页面的元素时,是以表格为单位逐一显示,如果一张网页是嵌套在一个大表格之内,那么很可能造成的后果就是,当浏览者敲入网址,他要先面对一片空白很长时间,然后所有的网页内容同时出现。如果必须这样做,请使用&nbsp;&lt;tbody&gt;标记,以便能够使这个大表格分块显示</p>
<p align="left"><strong>5.&nbsp;</strong>网页制作细节&nbsp;<strong>----&nbsp;</strong>下载速度<br>
首页&nbsp;Flash&nbsp;网页大小应限定在&nbsp;200K&nbsp;以下,尽可能的使用矢量图形和&nbsp;<strong>Action&nbsp;</strong>来减小动画大小。非首页静态页面含图片大小应限定在&nbsp;70K&nbsp;左右,尽可能的使用背景颜色替换大块同色图片。</p>
<p align="left"><strong>6.&nbsp;</strong>网页制作细节&nbsp;<strong>---- include<br>
</strong>asp&nbsp;标准写法&nbsp;&lt;!--#include
file="inc/index_top.asp" --&gt;<br>
jsp&nbsp;标准写法&nbsp;&lt;%@ include
file="../inc/index_top..jsp" %&gt;</p>
<p align="left"><strong>7.&nbsp;</strong>网页制作细节&nbsp;<strong>----</strong>Alt和Title<br>
都是提示性语言标签,请注意它们之间的区别。在我们浏览网页时,当鼠标停留在图片对象或文字链接上时,在鼠标的右下角有时会出现一个提示信息框。对目标进行一定的注释说明。在一些场合,它的作用是很重要的。</p>
<p align="left">&nbsp;</p>
<p align="left">alt&nbsp;用来给图片来提示的。Title用来给链接文字或普通文字提示的。用法如下:<br>
&lt;p Title="给链接文字提示"&gt;文字&lt;/p&gt;<br>
&lt;a href="#" Title="给链接文字提示"&gt;文字&lt;/a&gt;</p>
<p align="left">&lt;img
src="图片.gif"
alt="给图片提示"&gt;</p>
<p align="left"><strong>8.&nbsp;</strong>网页制作细节&nbsp;<strong>----&nbsp;</strong>缓存<br>
网页不会被缓存<br>
HTM网页<br>
&lt;META HTTP-EQUIV="pragma" CONTENT="no-cache"&gt;<br>
&lt;META HTTP-EQUIV="Cache-Control" CONTENT="no-cache,
must-revalidate"&gt;&lt;META HTTP-EQUIV="expires"
CONTENT="0"&gt;</p>
<p align="left">ASP网页<br>
Response.Expires = -1Response.ExpiresAbsolute = Now() - 1Response.cachecontrol
= "no-cache"</p>
<p align="left"><strong>9.&nbsp;</strong>网页制作细节&nbsp;<strong>----&nbsp;</strong>浏览器兼容性<br>
创建站点时,应该明白访问者可能使用各种&nbsp;Web&nbsp;浏览器。在已知的其他设计限制下,尽可能将站点设计为具有最大的浏览器兼容性。<br>
目前使用的&nbsp;Web&nbsp;浏览器有二十多种,大多数已发行了多个版本。即使您只针对使用&nbsp;Netscape Navigator和&nbsp;Microsoft Internet Explorer&nbsp;的大多数&nbsp;Web&nbsp;用户,但您应明确并不是每个人都在使用这两种浏览器的最新版本。您的站点越复杂(在布局、动画、多媒体内容和交互方面),跨浏览器兼容的可能性就越小。例如,并非所有的浏览器都可以运行&nbsp;JavaScript。不使用特殊字符的纯文本页面或许能够在任何浏览器中正确显示,但比起有效地使用图形、布局和交互的页面,这样的页面在美感上可能要差得多。所以,应尽量在最佳效果设计和最大浏览器兼容性设计之间取得平衡。<br>
所有的&nbsp;HTML&nbsp;标签的属性都要用单引号或者双引号括起,即我们应该写&nbsp;&lt;a href=”url”&gt;&nbsp;而不 是&nbsp;&lt;ahref=url&gt;.</p>
<p align="left"><strong>10.&nbsp;</strong>图片处理细节&nbsp;<strong>---- banner<br>
</strong>全尺寸&nbsp;banner&nbsp;为&nbsp;468X60px,半尺寸&nbsp;banner&nbsp;为&nbsp;234X60px,小&nbsp;banner&nbsp;为&nbsp;88X31px。另外&nbsp;120X90,120X60&nbsp;也是小图标的标准尺寸。全尺寸&nbsp;banner&nbsp;不超过&nbsp;14K。普遍的banner&nbsp;尺寸&nbsp;760X100,750X120,468X60,468X95,728X90,585X140次级页的&nbsp;pip&nbsp;尺寸&nbsp;360X300,336X280<br>
游标:100X100&nbsp;或&nbsp;120X120</p>
<p align="left"><strong>11.&nbsp;</strong>图片处理细节&nbsp;<strong>----
LOGO&nbsp;</strong>的国际标准规范<br>
为了便于&nbsp;INTERNET&nbsp;上信息的传播,一个统一的国际标准是需要的。实际上已经有了这样的一整套标准。其中关于网站的&nbsp;LOGO,目前有三种规格:<br>
88*31&nbsp;这是互联网上最普遍的&nbsp;LOGO&nbsp;规格。<br>
120*60&nbsp;这种规格用于一般大小的&nbsp;LOGO。<br>
120*90&nbsp;这种规格用于大型&nbsp;LOGO。</p>
<p align="left">&nbsp;</p>
<p align="left"><strong>12.&nbsp;</strong>图片处理细节&nbsp;<strong>----&nbsp;</strong>页面修饰图片处理图片经过优化以加快下载的速度,有较佳的视觉空间效果,用图要与页面风格、页面内容相符;制作精美,细节处理得当。</p>
<p align="left">2.5
JavaScript书写规范</p>
<p align="left">1.&nbsp;书写过程中,&nbsp;每行代码结束必须有分号;&nbsp;原则上所有功能均根据XXX项目需求原生开发,&nbsp;以避免网上down&nbsp;下来的代码造成的代码污染(沉冗代码&nbsp;||&nbsp;与现有代码冲突&nbsp;|| ...);</p>
<ol>
<li>库引入:&nbsp;原则上仅引入&nbsp;jQuery&nbsp;库,&nbsp;若需引入第三方库,&nbsp;须与团队其他人员讨论决定;</li>
<li>变量命名:&nbsp;驼峰式命名.&nbsp;原生&nbsp;JavaScript&nbsp;变量要求是纯英文字母,&nbsp;首字母须小写,&nbsp;如&nbsp;iTaoLun;</li>

</ol>
<p align="left">jQuery变量要求首字符为'_',&nbsp;其他与原生JavaScript&nbsp;规则相同,&nbsp;如:_iTaoLun;&nbsp;另,&nbsp;要求变量集中声明,避免全局变量.</p>
<p align="left">0. 类命名:&nbsp;首字母大写,&nbsp;驼峰式命名.&nbsp;如&nbsp;ITaoLun;</p>
<ol>
<li>函数命名:&nbsp;首字母小写驼峰式命名.&nbsp;如&nbsp;iTaoLun();</li>
<li>命名语义化,&nbsp;尽可能利用英文单词或其缩写;</li>
<li>尽量避免使用存在兼容性及消耗资源的方法或属性,&nbsp;比如&nbsp;eval() &amp; innerText;</li>

</ol>
<p align="left">0. 后期优化中, JavaScript&nbsp;非注释类中文字符须转换成&nbsp;unicode&nbsp;编码使用,&nbsp;以避免编码错误时乱码显</p>
<p align="left">示;</p>
<ol>
<li>代码结构明了,&nbsp;加适量注释.&nbsp;提高函数重用率;</li>
<li>注重与html分离,减小reflow,注重性能.</li>

</ol>
<p align="left">2.6&nbsp;图片规范</p>
<ol>
<li>所有页面元素类图片均放入&nbsp;img&nbsp;文件夹,&nbsp;测试用图片放于&nbsp;img/demoimg&nbsp;文件夹;</li>
<li>图片格式仅限于&nbsp;gif || png || jpg;</li>
<li>命名全部用小写英文字母&nbsp;||&nbsp;数字&nbsp;|| _&nbsp;的组合,其中不得包含汉字&nbsp;||&nbsp;空格&nbsp;||&nbsp;特殊字符;尽量用易懂</li>

</ol>
<p align="left">的词汇,&nbsp;便于团队其他成员理解;&nbsp;另,&nbsp;命名分头尾两部分,&nbsp;用下划线隔开,&nbsp;比如&nbsp;ad_left01.gif || btn_submit.gif;</p>
<ol>
<li>在保证视觉效果的情况下选择最小的图片格式与图片质量,&nbsp;以减少加载时间;</li>
<li>尽量避免使用半透明的&nbsp;png&nbsp;图片(若使用,&nbsp;请参考&nbsp;css&nbsp;规范相关说明);</li>
<li>运用&nbsp;css sprite&nbsp;技术集中小的背景图或图标,&nbsp;减小页面&nbsp;http&nbsp;请求,&nbsp;但注意,&nbsp;请务必在对应的&nbsp;sprite psd&nbsp;源</li>

</ol>
<p align="left">图中划参考线,&nbsp;并保存至&nbsp;img&nbsp;目录下.</p>
<p align="left"><strong>2.7&nbsp;</strong>注释规范</p>
<ol>
<li>html&nbsp;注释:&nbsp;注释格式&nbsp;&lt;!--这儿是注释--&gt;, '--'只能在注释的始末位置,不可置入注释文字区域;</li>
<li>css&nbsp;注释:&nbsp;注释格式&nbsp;/*这儿是注释*/;</li>
<li>JavaScript&nbsp;注释,&nbsp;单行注释使用'//这儿是单行注释' ,多行注释使用&nbsp;/*&nbsp;这儿有多行注释&nbsp;*/;</li>

</ol>
<p align="left"><strong>2.8&nbsp;</strong>浏览器兼容性&nbsp;<strong>CSS hack</strong></p>
<table style="width: 554px" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td width="554">
<p align="left">一、标识区别:</p>
<p align="left">区别&nbsp;IE6,IE7,IE8,FF。<br>
1. IE&nbsp;都能识别* ;&nbsp;标准浏览器(如&nbsp;FF)不能识别*;</p>
<p align="left">2. IE6能识别*,但不能识别&nbsp;!important; IE6在样式前面加_3. IE7能识别*,也能识别!important;4.IE8能识别\9例如:background:red \9;<br>
5. firefox&nbsp;不能识别*,但能识别!important;</p>
<p align="left">1.IE6和&nbsp;firefox&nbsp;的区别:<br>
background:orange;*background:blue;意思就是火狐浏览器的背景颜色是橙色,而&nbsp;IE&nbsp;浏览器的背景色是蓝色.</p>
<p align="left">2. IE6和&nbsp;IE7的区别:<br>
background:green !important;background:blue;意思指的是:IE7的背景颜色是绿色,IE6的背景颜色是蓝色</p>
<p align="left">3. IE7和&nbsp;FF&nbsp;的区别:<br>
background:orange; *background:green;意思指的是:火狐浏览器的背景颜色是橙色,而&nbsp;IE7的背景颜色是绿色</p>
<p align="left">4. FF,IE7,IE6的区别:<br>
background:orange;<br>
*background:green !important;<br>
*background:blue;<br>
意思是火狐浏览器的的背景橙色,IE7浏览器的背景颜色是绿色,而&nbsp;IE6浏览器的颜色是蓝色.</p>
<p align="left">二、实践建议</p>
<p align="left">(1).&nbsp;开发平台的选择</p>


</td>


</tr>
<tr>
<td width="554">
<p align="left">在&nbsp;Firefox&nbsp;上编写&nbsp;CSS,&nbsp;同时兼容其他浏览器的.&nbsp;这样做肯定会比在&nbsp;IE&nbsp;做好再到别的浏览器兼容来得容易,&nbsp;因为&nbsp;IE&nbsp;对老标准支持还是很不错的,&nbsp;而&nbsp;IE&nbsp;的一些特有功能人家却不支持.&nbsp;所以推荐以Firefox&nbsp;结合&nbsp;Firebug&nbsp;扩展作为平台。</p>


</td>


</tr>
<tr>
<td width="554">
<p align="left">(2). CSS Hack&nbsp;的顺序</p>
<p align="left">使用&nbsp;Firefox&nbsp;作为平台,&nbsp;只要代码写得够标准,&nbsp;其实要&nbsp;Hack&nbsp;的地方不会很多的, IE&nbsp;以外的浏览器几乎都不会有问题,&nbsp;所以可以暂时忽略,</p>
<p align="left">顺序如下:Firefox -&gt; IE6 -&gt; IE7
-&gt;&nbsp;其他(3). Hack&nbsp;的方法</p>
<p align="left">说到方法有两种,&nbsp;一种是在不同文件中处理,&nbsp;另一种则是在同一个文件中处理.&nbsp;其实作用是相同的,只是出发点不一样而已.</p>
<p align="left">1.&nbsp;同一文件中处理.<br>
如: id="bgcolor"的控件要在&nbsp;IE6中显示蓝色, IE7中显示绿色, Firefox&nbsp;等其他浏览器中显示红色。</p>


</td>


</tr>


</tbody>

</table>
<p align="left">IE6不认&nbsp;!important,也不认&nbsp;*+html.所以&nbsp;IE6只能是&nbsp;blue.<br>
IE7认&nbsp;!important,也认&nbsp;*+html,优先度: (*+html + !important) &gt; !important &gt; +html. IE7可以是&nbsp;red,blue&nbsp;和&nbsp;green,但&nbsp;green&nbsp;的优先度最高.<br>
Firefox&nbsp;和其他浏览器都认&nbsp;!important. !important&nbsp;优先, Firefox&nbsp;可以是&nbsp;red&nbsp;和&nbsp;blue,但&nbsp;red&nbsp;优先度高.上述的优先符号均是&nbsp;CSS3标准允许的,其他浏览器也还有其他的&nbsp;Hack&nbsp;方法,但我迄今还没遇到过Firefox&nbsp;正常, IE&nbsp;以外的其他浏览器不正常的情况,所以无可分享.只要代码规范,相信这种情况的发生应该是很罕见&nbsp;(JavaScript&nbsp;除外).</p>
<p align="left">2.&nbsp;不同文件中处理.<br>
为什么同一文件中可以处理还要写在多个文件里面针对不同的浏览器?这是为了欺骗&nbsp;W3C的验证工具,其实只需要两个文件,一个是针对所有浏览器的,一个只为&nbsp;IE&nbsp;服务.将所有符合&nbsp;W3C&nbsp;的代码写到一个里面去,而一些&nbsp;IE&nbsp;中必须的,又不能通过&nbsp;W3C&nbsp;验证的代码&nbsp;(如: cursor:hand;)放到另一个文件中,再用下面的方法导入.</p>
<p>&nbsp;</p><br><br>
来源:https://www.cnblogs.com/jimyking/p/14674219.html
頁: [1]
查看完整版本: Web 前端开发规范手册