25种以上JavaScript速记编码技术
作者:Michael Wanyoike and Sam Deering
https://www.sitepoint.com/shorthand-javascript-techniques
对于任何JavaScript开发人员来说,这篇文章很值得一读。这里记录了我多年来学习的JavaScript代码简洁写法,也给大家提供一些编码上的思考和取舍。
1. 三元(三目)运算符
如果只想在一行中编写if..else语句时,这是一个很好的节省代码的方式。
常规:
简写:
嵌套版三元运算:
2. 短路判断简写
将变量值分配给另一个变量时,您可能希望确保源变量不为null,undefined或为空。您可以编写带有多个条件的长 if 语句,也可以使用短路判断。
常规:
简写:
再来点示例,尝试一下:
请注意,如果将variable1设置为false或0,则赋值为bar。
3. 声明变量简写
常规:
简写:
4. If真值判断简写
这可能是微不足道的,但值得一提。在执行“if 检查”时,有时可以省略全等运算符。
常规:
简写:
注意:这两个例子并不完全相同,因为只要likeJavaScript是一个真值,检查就会通过。
这是另一个例子。如果a不等于true,那就做点什么吧。
常规:
简写:
5. For循环简写
如果您想要纯JavaScript并且不想依赖外部库(如jQuery或lodash),这个小技巧非常有用。
常规:
简写:
如果您只想访问索引,请执行以下操作:
如果要访问文字对象中的键,这也适用:
Array.forEach简写:
6. 短路判断赋值
如果预期参数为null或undefined,我们可以简单地使用短路逻辑运算符,只需一行代码即可完成相同的操作,而不是编写六行代码来分配默认值。
常规:
简写:
7. 十进制基本指数
你可能已经看过这个了。它本质上是一种编写没有尾随零的数字的奇特方式。例如,1e7实质上意味着1后跟7个零。它表示一个十进制基数(JavaScript解释为浮点类型)等于10,000,000。
常规:
简写:
8. 对象属性简写
在JavaScript中定义对象很简单。ES6提供了一种更简单的方法来为对象分配属性。如果变量名称与对象键相同,则可以使用简写表示法。
常规:
简写:
9. 箭头函数简写
经典函数以简单的形式易于读写,但是一旦你开始将它们嵌套在其他函数调用中,它们往往会变得有点冗长和混乱。
常规:
简写:
重要的是要注意,箭头函数内部的 this 与常规函数的不同,因此这两个示例并不严格等效。有关详细信息,请参阅有关箭头函数语法的文章。
10. 隐式返回简写
Return 是我们经常使用的关键字,用于返回函数的最终结果。具有单个语句的箭头函数将隐式返回其执行结果(函数必须省略大括号({})以省略return关键字)。
要返回多行语句(例如对象),必须使用 () 而不是 {} 来包装函数体。这可确保将代码执行为单个语句。
常规:
简写:
11. 默认参数值
您可以使用if语句定义函数参数的默认值。在ES6中,您可以在函数声明本身中定义默认值。
常规:
简写:
12. 模板字符串
您是否厌倦了使用 '+' 将多个变量连接成一个字符串?有没有更简单的方法?如果你能够使用ES6,那么你很幸运。您需要做的就是使用反引号,并使用 ${} 来包含变量。
常规:
简写:
13. 解构赋值简写
如果您正在使用任何流行的Web框架,那么很有可能您将使用对象形式的数组或数据,在组件和API之间传递信息。数据对象到达组件后,您需要将其解构。
常规:
简写:
您甚至可以分配自己的变量名称,比如entity替换原来对象中的contact:
14. 多行字符串
如果您发现自己需要在代码中编写多行字符串,那么您可以编写它:
常规:
但是有一种更简单的方法。只需使用反引号。
简写:
15. 展开(spread)操作符
ES6中引入的展开运算符有几个用例,可以使JavaScript代码更高效,更有趣。它可以用来替换某些数组函数。展开操作符只是连续的三个点。
常规:
简写:
与 concat() 函数不同,您可以使用spread运算符在另一个数组内的任何位置插入数组。
您还可以将spread运算符与ES6解构表示法结合使用:
16. 强制参数
默认情况下,如果未传递值,JavaScript会将函数参数设置为undefined。其他一些语言会引发警告或错误。要强制执行参数赋值,可以使用 if 语句在未定义时抛出错误。
常规:
简写:
17. Array.find
如果您曾经在纯JavaScript中编写过 find 函数,那么您可能已经使用了for循环。在ES6中,引入了一个名为 find() 的新数组函数
常规:
简写:
18. Object[key]
你知道Foo.bar也可以写成Foo ['bar']吗?起初,似乎没有理由应该这样写。但是,这种表示法可以为编写可重用代码块提供方便。
思考一下,验证函数的这个简化示例:
这个功能完美地完成了它的工作,但是请考虑这样一种情况,即您需要验证的表单有很多,表单都具有不同字段和规则。构建可在运行时配置的通用验证函数不是更好吗?
简写:
现在我们有了一个通用验证函数,可以在所有表单中重用,而无需为每个表单编写自定义验证函数。
19. 双取反运算
双取反运算符有一个非常实用的场景。您可以将它用作 Math.floor() 的替代品。双取反运算符的优点是它可以更快地执行相同的操作。
常规:
简写:
20. 数学指数幂函数
常规:
简写:
21. 将字符串转换为数字
有时,您的代码会接收String类型的参数,但需要以数字类型处理。这不是什么大问题,我们可以进行快速转换。
常规:
简写:
22. 对象属性赋值
考虑以下代码:
你会如何把它们合并为一个对象?
一种方法是编写一个将第二个对象的数据复制到第一个对象的函数。
最简单的方法是,使用ES6中引入的 Object.assign 函数:
您还可以使用ES8中引入的对象销毁表示法:
您可以合并的对象属性数量没有限制。如果确实具有相同属性名称的对象,则将按合并的顺序覆盖值。
23. 取反运算 和 IndexOf
使用数组执行查找时,indexOf() 函数用于检索您要查找的项目的位置。如果未找到该项,则返回值-1。在JavaScript中,0被认为是'falsy',而大于或小于0的数字被认为是'truthy'。因此,必须像这样编写正确的代码。
常规:
简写:
取反(〜)运算符对 -1 以外的任何值,都返回 truthy 值。对它进行非运算,直接 !〜。
或者,我们也可以使用 includes() 函数:
24. Object.entries()
这是ES8中引入的一项功能,允许您将对象转换为键/值对数组。请参阅以下示例:
25. Object.values()
这也是ES8中引入的一个新功能,它执行与 Object.entries() 类似的功能,但没有key部分:
结语
- 工作中实际用到的简便方法有很多,希望大家能提出自己的简洁编码方式,评论区等大家~
喜欢博主的可以点赞关注一下
长得美的,长得帅的都关注了
现在就差你了
还不长按关注一下
----------------- END -----------------