概述
如何让编写的JS代码更短?下面本篇文章就来给大家分享4个编写短小精炼JS代码的小技巧,希望对大家有所帮助!
短路
Javascript 里的逻辑运算符与(&&)
可以产生短路,例如
console.log(true && 0 && 2); // 0
console.log(true && 'test' && 2) // 2
登录后复制
即代码从左往右,如果遇到undefined
,null
,0
等等会被转化为false
的值时就不再继续运行。
x == 0 && foo()
// 等价于
if( x == 0 ){
foo()
}
登录后复制
链判断运算符 '?'
假设有一个对象
const student = {
name : {
firstName : 'Joe'
}
}
登录后复制
我们希望firstname存在的情况下做一些事情, 我们不得不一层一层检查
if(student && student.name && student.name.firstName){
console.log('student First name exists')
}
登录后复制
采用链判断运算符会在某一层取不到值的时候停止并返回undefined
if(student?.name?.firstName){
console.log('student First name exists')
}
登录后复制
空值合并运算符 '??'
我们有时候会使用三元运算来简化if...else...
或者返回一个默认值
const foo = () => {
return student.name?.firstName
? student.name.firstName
: 'firstName do not exist'
}
console.log(foo())
登录后复制
这种情况,我们可以通过空值合并进一步简化代码
const foo = () => {
return student.name?.firstName ?? 'firstName do not exist'
}
console.log(foo())
登录后复制
很像或||
运算符,但??
只对undefined
和 null
起作用,可以避免值是0麻烦
尽量避免if else 嵌套
例如
const foo = () => {
if(x<1) {
return 'x is less than 1'
} else {
if(x > 1){
return 'x is greater than 1'
} else {
return 'x is equal to 1'
}
}
}
登录后复制
通过删除 else 条件可以使 if else 嵌套变得不那么复杂,因为 return 语句将停止代码执行并返回函数
const foo = () => {
if(x<1){
return 'less than 1'
}
if(x>1){
return 'x is greater than 1'
}
return 'x is equal to 1'
}
登录后复制
最后
以上就是听话小馒头为你收集整理的4个编写短小精炼JS代码的小技巧(分享)的全部内容,希望文章能够帮你解决4个编写短小精炼JS代码的小技巧(分享)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复