html定义变量的语句规则,前端规范

前言:

不规范的开发不仅使日后代码维护变的困难,同时也不利于团队的合作。下面列出了前端开发规范

通用规范:

1、前端工具统一sublime text,配置信息统一,如下:

{

"caret_style": "phase",

"color_scheme": "Packages/User/SublimeLinter/Monokai (SL).tmTheme",

"default_line_ending": "unix",

"ensure_newline_at_eof_on_save": true,

"findreplace_small": true,

"font_size": 12,

"ignored_packages":

[

"Vintage"

],

"line_padding_bottom": 4,

"line_padding_top": 4,

"show_panel_on_build": false,

"tab_size": 4,

"tabs_medium": true,

"trim_trailing_white_space_on_save": false

}

2、空格还是Tab?我们强制使用4个占位符的Tab缩进,如果遇到不是tab缩进的,可以借助sublime text来转换成tab缩进,步骤如下:

ctrl+shift+p 输入convert to Tabs,敲回车就可以

3、统一采用UTF8编码

4、项目发布必须压缩、图片优化,提高页面访问速度

5、文件命名统一使用小写字母,js文件多个字母用'-'连接,页面多个字母用'_'连接

6、js、css能够通用化、组件化

es5:

1、一行代码长度尽量保持80列左右

2、变量

声明变量必须加上var关键字,推荐一个var同时声明多个变量,或者一组有逻辑关系的变量,避免一个变量一个 var,声明Array和Object使用[]和{},声明变量时将其初始化,更易读且性能更好。

变量不要使用关键字,对象key也不要使用关键字,在ie8下会报错

// bad

var obj = {

default: 1

};

3、命名

函数和变量命名使用驼峰式,命名尽量语义化,

// bad

var e = '',

l = 0;

// good

var element = '',

length = 0;

4、单例模式、模块化开发

5、命名空间

每个应该有自己的命名空间,并不会影响到其他模块

6、单双引号

强制使用单引号,性能好

7、语句结尾一定要加';'

8、JSON对象的最后一个字段、数组最后一个元素后面都不能加',',在IE8下会报错

9、尽量不要使用with/eval

10、对象延迟声明,对于页面初始化不需要的变量,延迟声明

11、所有语句都在声明变量之后

12、提前返回值,提升代码的性能

// bad

function fun(arg) {

var test;

if (arg) {

test = arg;

} else {

test = 'another'

}

return test;

}

// good

function fun(arg) {

if (arg) {

return arg;

} else {

return'another'

}

}

13、使用arg

var obj = {};

Object.keys({}).forEach(function(key) {

console.log(this); //obj

}, obj);

可以使用arg的Array.prototype.every、 Array.prototype.forEach、 Array.prototype.some、 Array.prototype.map、 Array.prototype.filter

14、this

15、条件优化

// bad

if(a !== "") {

}

// good

if(!a) {

}

16、规范定义JSON对象,补全双引号

// bad

var json = {

a: 1

};

// good

var json = {

"a":1

};

17、函数返回值应尽量明确

// bad

function fun() {

return ;

}

// good

function fun() {

return false;

}

18、减少js对dom操作次数

19、对于if/else等后面的语句即使只有一行代码也要在该行代码的首尾加上'{}'。对于switch语句要给出default:情况的处理逻辑

20、字符串拼接在少量(次数为个位数)的情况下可以使用'+', 大量的时候使用数组 join(), 或者尽可能采用模板引擎渲染

21、for循环遍历提前计算数组长度

22、变量类型转换

字符转数字:+'0' 1*'0' toString()

数字转字符:''+0 parseInt() parseFloat()

数字取整:Math.ceil() Math.floor() Math.round()

字符转布尔:!!'0'

23、变量比较使用===,除(==null)之外

24、私有属性、变量和方法名应该以下划线'_'开头

25、异常处理

try{} catch(e){}

26、false

"", 0, null, undefined, NaN, void 0

27、true

"''", '""', '0', 'null', 'undefined', {}, []

28、跨行语句以操作符结尾

var x = a ?

b :

c;

29、函数句柄命名是名词

30、注释

采用jsdoc方式注释,函数注释用/**/,函数内注释用//

禁止使用行末注释

css:

1、命名空间

wei- 组件的命名空间(取weiUI首)

pg- 页面的命名空间(取page)

2、class 命名遵循关注分离(不要考虑html结构,比如子元素选择器)、松耦合的原则,同时注重易于理解

3、模块化编写,语义化的模块名

4、命名规则

4.1、BEM命名法,.a > .a-b > .a-b-c

4.2、所有名称小写,符合w3c规范

4.3、类名和id,多个变量之间用中划线分割,{命名空间}-{模块名}-{状态描述}

4.4、所有变量只能使用名词

4.5、id、class命名语义化,不要使用 red、left 等表象的词命名,常见例子

容器: wed-container

列表: wed-list we-list-item

内容: wed-content

注意:class用来定义样式,如果javascript里用到放在最后顺序,id用来写交互,不需要特殊声明(J_ 废除)

5、为了实现代码复用,减少重复冗余,难免要把代码拆分在不同的 class 下面。我们要寻找一个平衡点,避免过细的拆分,减少不必要的 class

6、不建议过度嵌套选择符(semantic躺枪),选择符嵌套在必要的情况下一般不超过三层;选择符叠加一般不多于两个

7、css3不用加前缀,统一用autoprefixer生成,规则:

[

'ie >= 7',

'ie_mob >= 10',

'ff >= 30',

'chrome >= 34',

'safari >= 7',

'opera >= 23',

'ios >= 7',

'android >= 2.3',

'bb >= 10'

]

8、色值全部使用6位数

html:

1、语义化标签,webapp尽量多使用html5

2、禁止使用非法标签属性

3、后台交互

data-api 接口

data-url 跳转链接

最多支持二级,比如

关注:data-api-follow

取消关注:data-api-unfollow

4、标签扁平化,禁止不必要的嵌套

5、标签属性,属性值使用中划线或者驼峰式,禁止使用下划线

6、html嵌套规则

6.1块级元素与块级元素平级、内嵌元素与内嵌元素平级

6.2块元素可以包含内联元素或某些块元素,但内联元素不能包含块元素,它只能包含其它的内联元素

6.3有几个特殊的块级元素只能包含内嵌元素,不能再包含块级元素

6.4块级元素不能放在标签p里面

6.5li 标签可以包含 div 标签,因为li 和 div 标签都是装载内容的容器

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/349859.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

云技术-SaaS架构初步理解

最近公司准备整一个SaaS的东西。有幸参入这一块东西的搭建,借着這个机会也重新好好梳理了一下对SaaS的认识。今天整理一下! 一、云计算与SaaS 说起SaaS,就得先说说云计算了。关于云计算分为三层,基础设施在最下端,平台…

primefaces_轻量级Web应用程序框架:PrimeFaces(JSF)+ Guice + MyBatis(第2部分)

primefaces在这一部分中,我将继续演示JSF,Guice和MyBatis的集成。 在持久层中使用DBCP连接池和MYSQL数据库。 看一下第1部分 。 在上一篇文章中 ,我们创建了一个ServletContextListener。 现在,我们只需要在contextInitialized方…

html三元运算符 模板,AngularJS模板中的三元运算符

小编典典更新 :Angular1.1.5添加了一个三元运算符,因此现在我们可以简单地编写如果您使用的是较早版本的Angular,则有两个选择:(condition && result_if_true || !condition && result_if_false){true: result_if…

pycharm 更改创建文件默认路径

pycharm 更改创建文件默认路径 1、操作 依次找到以下路径修改为自己想要的路径即可:PyCharm——>Settings——>Appearance&Behavior——>System Setting——>Project Opening——>Default directory 2、图示 posted on 2019-07-29 14:18 初妍 阅…

Spring Security和多个过滤器链

Spring Security是一项非常有用的技术。 它使您可以保护应用程序而不会过于侵入,并允许插入许多不同的身份验证机制。 另一方面,要使用它并不是那么容易,并且每次接触它时我都必须重新学习这些工具之一。 在这篇文章中,我将介绍Sp…

计算机网络相关论文目录怎么弄,如何给你的标书、论文编页码和目录-论文页码设置...

一、如何从任意一页开始编码无论是做标书,还是写论文,都有一个给word文档编页码的问题。一般封面、目录、内容提要等前几页不要页码,页码从正文开始编起;或者前面内容编不同于正文的页码,或其中的某一页用罗马数字的页…

关于我

我的博客一般没有密码,有的话密码也是:znsbc, 写博客很少放题干,既然你搜到这个题解那么你肯定知道题干再搜的这个题 另外由于博主过于弱,所以博客难题会很少 借用$lnc$一句话( WA0的快感,让我难以自拔。) 另外由于博主写博客时大多神志不清…

NOIP模拟测试10「大佬·辣鸡·模板」

大佬 显然假期望 我奇思妙想出了一个式子$f[i]f[i-1]\sum\limits_{j1}^{j<m} C_{k \times j}^{k}\times w[j]$ 然后一想不对得容斥 于是我得到$f[i]f[i-1]\sum\limits_{j1}^{j<m} C_{j\times(k-1)}^{k-1} \times w[j]$ 但还是不对 现在思考第一个式子为什么不对 我们枚举…

activemq 持久订阅_ActiveMQ群集,持久订阅者和虚拟主题可助您一臂之力

activemq 持久订阅因此&#xff0c;您希望使用ActiveMQ跨分布式主题进行发布-订阅&#xff0c;并且要可靠。 您可以使用永久订阅&#xff0c;对吗&#xff1f; 可以&#xff0c;但是&#xff0c;如果您将群集与ActiveMQ一起使用&#xff0c;则可能会遇到意外的行为。 我最近在一…

会计电算化算不算计算机专业,成都会计学校会计电算化专业介绍

由于会计的火热&#xff0c;有很多同学都在咨询老师想要了解成都会计学校会计电算化专业&#xff0c;老师也整理了相关内容为同学们作为参考&#xff0c;希望对同学们有所帮助。就是将计算机信息技术应用到会计实务中&#xff0c;实现对会计信息的管理。会计电算化从20世纪50年…

给APK签名,修改签名

简介&#xff1a; 本来是不需要签名的&#xff0c;但是我有个android的专用设备&#xff0c;限制安装&#xff0c;但是售后给我通过了一个证书的验证。 那么我想装什么软件&#xff0c;就需要这个证书验证。 现在记录一下签名的主要过程&#xff0c;还有修改签名的方法。 一&am…

Neo4j:Cypher –删除重复的节点

我最近在处理的图上遇到问题&#xff0c;因为我没有应用任何唯一的约束 &#xff0c;我设法创建了重复的节点。 我想删除重复项&#xff0c;并遇到了吉米鲁茨&#xff08;Jimmy Ruts&#xff09;的精彩文章 &#xff0c;其中显示了一些方法。 让我们首先创建一个包含一些重复…

计算机学英文是什么,“计算机科学与技术专业本科课程”的英文翻译是什么?...

1计算机导论 Intorduction of Computer2高等数学 Avanced Mathematics3线性代数 Linear Alberia4离散数学 Discrete Mathematics5数值分析 Numerical value Analysis6大学英语 Colleage English7模拟电子电路 Analog Electronic Circuit8数字电子电路 Digital Electronic Circu…

Pearson相关系数 - Pearson's Correlation Coefficient

Pearson相关系数用来衡量两个数据集合是否在一条线上面。其计算公式为&#xff1a;一个具体的计算的例子&#xff1a;X Y1 22 53 6原文地址&#xff1a;http://woodstudio.javaeye.com/blog/141005 转载于:https://www.cnblogs.com/cmleung/archive/2009/12/09/1619922.html

swfobject.embedSWF属性与用法

swfobject.embedSWF属性与用法2010-06-29 09:47/点击数( 2218)swfobject.embedSWF(swfUrl, id, width, height, version, expressInstallSwfurl, flashvars, params, attributes)有5个必须的参数和4个可选的参数&#xff1a; swfUrl&#xff08;String&#xff0c;必须的&#…

台式计算机装机软件选择,装机软件哪个好?小编教你最好的装机软件推荐

金山重装高手是一款傻瓜式重装系统软件&#xff0c;一键系统重装&#xff0c;解决系统慢、卡、报 错、蓝屏等问题。电脑使用时间长了会让系统运行变得缓慢&#xff0c;通常我们都会对系统进行重装&#xff0c;很多用户对重装系统一窍不通&#xff0c;不敢动手操作&#xff0c;那…

Vaadin提示:以声明方式构建UI

如果您使用了GWT&#xff0c;那么您可能会发现UiBinder对于设计复杂的UI很有用。 在有关Vaadin的系列文章中&#xff0c;我们希望在Vaadin和GWT之间得出相似之处。 Vaadin提供了多种开箱即用的工具和组件&#xff0c;用于构建复杂且美观的UI。 其中之一是可以像UiBinder那样声明…

奇怪的道路

DeepinC的题解 考场AC nb%%%%%%%%%%%%%%%%%% 2019/4/27Day1 T3 奇怪的道路step1&#xff1a;复杂度分析1< n < 30, 0 < m < 30, 1 < K < 8.按照习惯&#xff0c;正解复杂度一般在1e6-1e8级别而且往往复杂度关系最大的就是最小的那个数对&#xff0c;抓住那个…

江苏省专转本计算机题知识点,江苏专转本计算机真题17

61、在Word 2003中&#xff0c;下列关于查找操作的叙述&#xff0c;正确的是 。A、使用查找命令时&#xff0c;可以区分全角和半角字符&#xff0c;但不能区分大小写B、不支持用通配符来描述查找内容C、查找时只能从文档开始处进行D、除了可以按文字的内容进行查找&#xff0c;…

圣杯布局总结

1.左侧定宽,右侧自适应布局 html部分 <div class"parent"><div class"layout_left">左边宽度固定</div><div class"layout_main">主内容宽度自适应</div> </div>  css部分 <style>*{margin:0;paddin…