Web常见约定规范(精选)
常见的约定规范
(一)HTML约定规范
1,html属性顺序:id class name data-xxx (src for type href)(title alt)(aria-xxx role)
2,a 不允许嵌套 div 和 a
3,a 里不不可以嵌套交互式元素:a button select等
4,p里不可以嵌套块级元素 div p h1~h6 ul ol li dl dt dd form等
5,语义化:blockquote 大段引用; cite 一般引用; code 代码标识; abbr缩写
6,使用 link 代替 @import
(二)CSS约定规范
1,class与id属性多个单词组成时单词之间用 - 分隔
2,属性定义统一使用双引号
3,布尔类型(disabled checked selected) 等属性不用设置值
4,组件块和子组件块以及声明块之间使用一空行分隔,子组件块之间三空行分隔
5,如果使用了多个css文件,按照组件形式分拆
6,不要将元素选择器和ID class混合使用,不利于维护
7,样式书写顺序:定位属性放在首位,盒模型放在第二位,其他放在后面
8,链接的样式顺序:a:link a:visited a:hover a:active
9,使用translate取代absolute定位会得到更好的fps,动画会更顺滑
(三)JS约定规范
1,单行注释,独占一行,//后面跟一个空格,缩进与下一行被注释的代码一致
2,避免使用多行注释
3,函数说明/方法注释:参数、返回值注释必须包含类型信息和说明
4,当函数为内部函数,外部不可访问时,可以使用@inner标识
5,文件注释:内容、依赖关系、兼容性信息
6,变量、函数、函数的参数、类的方法和属性使用驼峰命名法
7,类、枚举变量使用Pascal命名法
8,常量、枚举的属性使用全部大写字母、单词间下划线分隔的命名方式
9,不要在Array上使用for-in循环,因为遍历的是所有出现在对象及其原型链的键值
10,尽量使用requertAnimationFrame代替setTimeout,setInterval
11,声明块的左{前添加一个空格,右}单独成行,:后应添加一个空格,以;结尾
12,以 , 分隔的属性值,每个逗号后应添加一个空格
以上就是我给大家推荐的一些常见的约定规范!
Web常见约定规范(精选)的更多相关文章
- WEB前端开发规范
WEB前端开发规范 规范目的 为提高团队协作效率, 便于后台人员添加功能及前端后期优化维护, 输出高质量的文档, 特制订此文档.本文档如有不对或者不合适的地方请及时提出, 经讨论决定后方可更改. 基本 ...
- Java Web 项目目录规范
一.项目结构 这里和其他项目区别不大,我将模板抽离出来,更容易分析和理解: 解释一下:js主要包括extends(引入第三方的js).module(项目模块自己的js).lib(引用包,这里也可以继续 ...
- WEB前端开发规范文档(转)
http://codeguide.bootcss.com/ 编写灵活.稳定.高质量的 HTML 和 CSS 代码的规范上面的文档 再结合下面的规范: 无论是从技术角度还是开发视角,对于web前端开发 ...
- C语言常见命名规范
C语言常见命名规范 1 常见命名规则 比较著名的命名规则首推匈牙利命名法,这种命名方法是由Microsoft程序员查尔斯·西蒙尼(Charles Simonyi) 提出的.其主要思想是“在变量和函 ...
- Web 前端代码规范
Web 前端代码规范 最后更新时间:2017-06-25 原始文章链接:https://github.com/bxm0927/web-code-standards 此项目用于记录规范的.高可维护性的前 ...
- 网站开发进阶(三十八)Web前端开发规范文档你需要知道的事
Web前端开发规范文档你需要知道的事 规范目的 为提高团队协作效率, 便于后台人员添加功能及前端后期优化维护, 输出高质量的文档, 特制订此文档. 本规范文档一经确认, 前端开发人员必须按本文档规范进 ...
- HTML编码规范 - (WEB前端命名规范)
HTML编码规范 (一)命名规则: 头:header 内容:content/container 尾:footer 导航:nav 侧栏:sidebar 栏目:column 页面外围控制整体布局宽度:wr ...
- Web前端开发规范文档你需要知道的事
Web前端开发规范文档你需要知道的事 规范目的 为提高团队协作效率, 便于后台人员添加功能及前端后期优化维护, 输出高质量的文档, 特制订此文档. 本规范文档一经确认, 前端开发人员必须按本文档规范进 ...
- WEB前端开发规范文档[转]
为新项目写的一份规范文档, 分享给大家. 我想前端开发过程中, 无论是团队开发, 还是单兵做站, 有一份开发文档做规范, 对开发工作都是很有益的. 本文档由本人编写, 部分意见来源于网络, 以此感谢, ...
随机推荐
- 降低Redis内存占用
1.降低redis内存占用的优点 1.有助于减少创建快照和加载快照所用的时间 2.提升载入AOF文件和重写AOF文件时的效率 3.缩短从服务器进行同步所需的时间 4.无需添加额外的硬件就可以让redi ...
- 在TFS中通过程序动态创建Bug并感知Bug解决状态
为便于跟踪问题解决情况,预警引擎产生的比较严重的预警日志,需要在TFS中登记Bug,通过TFS的状态流转,利用TFS Bug的Web挂钩功能,动态感知Bug解决状态,从而跟踪预警问题的解决状态, 整体 ...
- NGUI 解决UILable 在空行起始位置加‘\n’
NGUI 解决UILable 默认在顶满第一行时,在起始位置如键入空格无效,其原因就是会加入换行符,使字符串,整体换行了 解决办法加入bool变量控制 1在 UILable代码中添加 [HideInI ...
- vue监听滚动事件,实现滚动监听
在vue中实现滚动监听和原生js无太大差异,下面是一个简单的demo,可在控制台查看结果 <!DOCTYPE html> <html lang="en"> ...
- Python之路-shell&计划任务
开发脚本自动部署及监控1.编写脚本自动部署反向代理.web.nfs:要求: I.部署nginx反向代理三个web服务,调度算法使用加权轮询: II.所有web服务使用共享存储nfs ...
- 手机自动化测试:Appium代码之Logger
手机自动化测试:Appium代码之Logger poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.poptest推出手机自动化测 ...
- hiveF 函数解析时间问题
#!/bin/bashsource /etc/profileupdatetime=`date --date='0 days ago' +"%Y-%m-%d %H:%M:%S"`ec ...
- oracle的insert的时候&符号如何插入(转义)
chr(38)替换& insert into table values( 'http://localhost:8080/index.action?username=138& ...
- BZOJ2818 与 BZOJ2301【euler,线性筛,莫比乌斯】
题目大意: 给一个范围[1,n],从中找出两个数x,y,使得gcd(x,y)为质数,问有多少对(x,y有序) 解法: 不难,欧拉函数练手题,可以定义集合P ={x|x为素数},那么我们枚举gcd(x, ...
- Oracle to_date函数
TO_DATE格式(以时间:2007-11-02 13:45:25为例)Year: yy two digits 两位年 显示值:07yyy three di ...