|
||
|
|||
ASP毕业设计 | VB毕业设计 | JSP毕业设计 | VC毕业设计 | 文献参考 | C#毕业设计 | vb.net毕业设计 Delphi毕业设计 | Asp.NET毕业设计 | 技术经验 | VBA (Access) 毕业设计 | VBA (Excel) 毕业设计 | PB毕业设计 | android(安卓)毕业设计 Nodejs ES6前端全栈 vue react 小程序 express koa2 mern | python(web开发Django框架) | html5游戏开发 | Jquery毕业设计 | XSLT毕业设计 |
∷毕设简介∷
|
提供 系统开发过程,业务需求分析,流程分析,系统数据库表结构,数据字典,免费提供您参考阅读!请下载演示参考系程序细节! |
重点: 转:https://zhuanlan.zhihu.com/p/22998282 |
在打算写这篇文章之前,我是一个分号党,在写这篇文章之后,可能会转为无分号党了。之前是写分号是编辑器语法较检所养成的强迫症,现在观念的转变,是因为看了不少大神的讨论后,觉得javascript语句后写分号除了增大工作量外,意义不大。
在说要不要写分号之前,先了解一下javascript自动填补分号的规则。
在《javascript权威指南》中有一段话“如果一条语句以“(”、“[”、“/”、“+”、或“-”开始,那么它极有可能和前一条语句合在一起解释。”,写javascript的时候,如果每条语句都独自写成一行,是不需要写分号的,但是下一行如果遇到上面提到的符号,javascript可能会与下一行合并解释。其中以“/”、“+”和“-”开头的语句在实现项目中比较少见,以“(”和“[”开头的则非常常见。下面各找了一个例子来说明。
a = b
(function() {
})()
javascript会解释成:
a = b(function() {
})();
a = function() {
}
[1,2,3].forEach(function(item) {
});
javascript会解释成:
a = function() {
}[1,2,3].forEach(function(item) {
});
a = 'abc'
/[a-z]/.test(a)
期望的结果为true,但是javascript会解释成,接着就报错了:
a = ‘abc’/[a-z]/.test(a);
a = b
+c
javascript会解释成
a = b + c;
a = b
-c
javascript会解释成
a = b - c;
如果在return、break、continue、throw等关键字后面换行,javascript会在换行处填补分号。如:
return
{
a: 1
}
会解释成:
return;
{
a: 1
}
如果“++”或“--”运算符作为表达式的后缀时,表达式应该写在同一行,否则也会解释有误
例如:
x
++
y
会解释成:
x;
++y;
而不是
x++;
y;
对于究竟要不要写分号这个问题,我之前也没有细想,看到编辑器有提示就写了,也没有想过写与不写有什么区别,甚至在写这篇文章时,思路还是要将写分号当作团队代码的规范。后来看到知乎上vuejs的作者尤雨溪和前端大神贺师俊的回答后,我对写分号的想法完全颠覆了。
对于总是写分号的缺陷,贺思俊的总结很到位,他总结的3点缺陷如下:
人总是有可能忘记写分号。ASI(分号自动插入机制)导致无法区分是无意中忘记还是有意不写(代码折行)。
“总是写分号”并不能完全解决ASI缺陷(如return后换行会自动插入分号)。
“}”后是否要加分号需要回溯到对应“{”之前进行语义判断(是否是函数表达式),成本远高于前置分号判断(只要对行首字符进行token判断:是否是 [ ( + - / 五个符号之一)。
而对于上面提到的五种符号需要加分号的情况,完成可以用工具来帮我们自动完成,现在看来写分号除了满足强迫症外,好像真的没有什么必要了
∷下载地址∷ | ∷相关毕设∷ |
此软件暂不提供下载 |
· jsp面向学生的心理咨询网站心理系.. · nodejs koa2-ejs 影院售票电影院.. · jsp排考场编排自动排考场-1740-源.. · jsp webgis车辆轨迹轨迹移动GPS的.. · jsp 社区流动人口管理流入流出协.. · nodejs koa2 ejs模板引擎编程答题.. · jsp医院住院管理信息系统(床位住.. · vue在线阅读写书图书发布出书APP.. |
∷下载说明∷ |
* 如果您发现该软件不能下载,请点击报告错误谢谢! * 站内提供的极少部分源码,文献均是由网上搜集,若侵犯了你的版权利益,敬请来信通知我们! * 本站提供算法,数据构架,编程语言基础知识的辅导讲解,尽心尽力为所有客户提供最好的服务! |
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图 - 管理登录 Copyright ©2024 3Q2008.Com 网络 |
|||
|