作为一个从事WEB前端行业的程序员,开发规范是必须掌握的,开发规范可分为文档规范,html书写规范CSS规范,JavaSceipt规范,注释规范等几大类,下面就看看小编为大家整理的以下几类的开发规范。
文件规范
1. tpl, css, js, img文件均归档至约定的目录中;
2. tpl文件命名: 英文命名, 后缀.html,请重命名与php文件同名, 以方便后端添加功能时查找对应页面;
3. css文件命名: 英文命名, 后缀.css. 共用base.css, 首页index.css, 其他页面依实际模块需求命名.;
4. Js文件命名: 英文命名, 后缀.js. 共用common.js, 其他依实际模块需求命名.
HTML书写规范
1 文档类型声明及编码: 统一为html5声明类型; 编码统一为, 书写时利用IDE实现层次分明的缩进;
2. 非特殊情况下样式文件必须外链至之间;非特殊情况下JavaScript文件必须外链至页面底部;
4. 所有编码均遵循xhtml标准, 标签 & 属性 & 属性命名 必须由小写字母及下划线数字组成, 且所有标签必须闭合; 属性值必须用双引号包括;
5. 语义化html, 如 标题根据重要性用h(同一页面只能有一个h1), 段落标记用p, 列表用ul, 内联元素中不可嵌套块级元素;
6. 尽可能减少div嵌套
7. 在页面中尽量避免使用style属性,即style=”…”,应该尽量使用class或者id来定义新的样式,然后再对应的css文件里面修改;
8. 标签一定要正确嵌套,标签一定要闭合。
9. 非特殊情况下,css采用外链,加在之间;js文件放在页面底部之前。
10. title 不可缺少,控制在25个字、50个字节以内。“二级栏目 - 一级栏目 - 网站名称”。
CSS规范
1. 编码统一为utf-8;
2. 公用文件:协作开发过程中,会引入默认的base.css(里面包括了css reset、常用的css间距,css字体,css大小等,详细参见base.css);
3. class与id命名: ,样式名称由 小写英文 、 数字 和 _ 来组合命名, 如i_comment, fontred, width200; 避免使用中文拼音, 尽量使用简易的单词组合;命名要语义化, 简明化。
4. 为JavaScript预留钩子的命名, 尽量使用id属性,可以更快的获取到dom。
5. 书写代码前, 考虑并提高样式重复使用率;
6. 背景图片请尽可能使用sprite技术, 减小http请求, 考虑到多人协作开发, sprite按模块制作;
7. 必须为大区块样式添加注释, 小区块适量注释;
8. 代码缩进与格式: 建议单行书写, 可根据自身习惯, 后期优化会统一处理;
JavaScript规范
1. 文件编码统一为utf-8, 书写过程过, 每行代码结束必须有分号; 原则上所有功能均根据XXX项目需求原生开发, 以避免网上down下来的代码造成的代码污染(沉冗代码 || 与现有代码冲突 || …);
2. 库引入: 原则上仅引入jQuery库, 若需引入第三方库, 须与团队其他人员讨论决定;
3. 变量命名: 驼峰式命名. 原生JavaScript变量要求是纯英文字母, 首字母须小写, 如iTaoLun;
4. 另, 要求变量集中声明, 避免全局变量.
5. 类命名: 首字母大写, 驼峰式命名. 如 ITaoLun;
6.函数命名: 首字母小写驼峰式命名. 如iTaoLun();
7. 命名语义化, 尽可能利用英文单词或其缩写;
8. 尽量避免使用存在兼容性及消耗资源的方法或属性, 比如eval_r() & innerText;
9. 后期优化中, JavaScript非注释类中文字符须转换成unicode编码使用, 以避免编码错误时乱码显示;
10. 代码结构明了, 加适量注释. 提高函数重用率;
11. 注重与html分离, 减小reflow, 注重性能.
注释规范
1. html注释: 注释格式 , ‘–’只能在注释的始末位置,不可置入注释文字区域;
2. css注释: 注释格式 ;
3. JavaScript注释, 单行注释使用’//这儿是单行注释’ ,多行注释使用 ;
开发及测试工具约定
建议使用WebStorm||Aptana || Dw || Vim , 亦可根据自己喜好选择, 但须遵循如下原则:
1. 不可利用IDE的视图模式’画’代码;
2. 不可利用IDE生成相关功能代码, 比如Dw内置的一些功能js;
3. 编码必须格式化, 比如缩进;
其他规范
1. 开发过程中严格按分工完成页面, 以提高css复用率, 避免重复开发;
2. 减小沉冗代码, 书写所有人都可以看的懂的代码. 简洁易懂是一种美德. 为用户着想, 为服务器着想.
领取专属 10元无门槛券
私享最新 技术干货