关注 Vue中文社区 ,回复“ 加群 ”
加入我们一起学习,天天进步
译 者: 前端 小智
https://segmentfault.com/a/1190000021518997
1..过滤唯一值
Set
对象类型是在ES6中引入的,配合展开操作...
一起,我们可以使用它来创建一个新数组,该数组只有唯一的值。
const array = [1, 1, 2, 3, 5, 5, 1]const uniqueArray = [...new Set(array)];console.log(uniqueArray); // Result: [1, 2, 3, 5]
在ES6之前,隔离惟一值将涉及比这多得多的代码。
此技巧适用于包含基本类型的数组:undefined
,null
,boolean
,string
和number
。(如果你有一个包含对象,函数或其他数组的数组,你需要一个不同的方法!)
2. 与或运算
三元运算符是编写简单(有时不那么简单)条件语句的快速方法,如下所示:
x > 100 ? 'Above 100' : 'Below 100';x > 100 ? (x > 200 ? 'Above 200' : 'Between 100-200') : 'Below 100';
但有时使用三元运算符处理也会很复杂。相反,我们可以使用'与'&&
和'或'||
逻辑运算符以更简洁的方式书写表达式。这通常被称为“短路”或“短路运算”。
它是怎么工作的
假设我们只想返回两个或多个选项中的一个。
使用&&
将返回第一个条件为假
的值。如果每个操作数的计算值都为true
,则返回最后一个计算过的表达式。
let one = 1, two = 2, three = 3;console.log(one && two && three); // Result: 3console.log(0 && null); // Result: 0
使用||
将返回第一个条件为真
的值。如果每个操作数的计算结果都为false
,则返回最后一个计算过的表达式。
let one = 1, two = 2, three = 3;console.log(one || two || three); // Result: 1console.log(0 || null); // Result: null
例一
假设我们想返回一个变量的长度,但是我们不知道变量的类型。
我们可以使用if/else
语句来检查foo
是可接受的类型,但是这可能会变得非常冗长。或运行可以帮助我们简化操作:
return (foo || []).length
如果变量foo
是true,它将被返回。否则,将返回空数组的长度:0
。
例二
你是否遇到过访问嵌套对象属性的问题?你可能不知道对象或其中一个子属性是否存在,这可能会导致令人沮丧的错误。
假设我们想在this.state
中访问一个名为data
的属性,但是在我们的程序成功返回一个获取请求之前,data
是未定义的。
根据我们使用它的位置,调用this.state.data
可能会阻止我们的应用程序运行。为了解决这个问题,我们可以将其做进一步的判断:
if (this.state.data) { return this.state.data;} else { return 'Fetching Data';}
但这似乎很重复。'或'
运算符提供了更简洁的解决方案:
return (this.state.data || 'Fetching Data');
一个新特性: Optional Chaining
过去在 Object 属性链的调用中,很容易因为某个属性不存在而导致之后出现Cannot read property xxx of undefined
的错误。
那 optional chaining
就是添加了?.
这么个操作符,它会先判断前面的值,如果是 null
或 undefined
,就结束调用、返回 undefined
。
例如,我们可以将上面的示例重构为 this.state.data?.()
。或者,如果我们主要关注state
是否已定义,我们可以返回this.state?.data
。
该提案目前处于第1阶段,作为一项实验性功能。你可以在这里阅读它,你现在可以通过Babel使用你的JavaScript,将 @babel/plugin-proposal-optional-chaining添加到你的.babelrc
文件中。
3.转换为布尔值
除了常规的布尔值true
和false
之外,JavaScript还将所有其他值视为 ‘truthy’ 或**‘falsy’**。
除非另有定义,否则 JavaScript 中的所有值都是'truthy',除了 0
,“”
,null
,undefined
,NaN
,当然还有false
,这些都是**'falsy'**
我们可以通过使用负算运算符轻松地在true
和false
之间切换。它也会将类型转换为“boolean”。
const isTrue = !0;const isFalse = !1;const alsoFalse = !!0;console.log(isTrue); // Result: trueconsole.log(typeof true); // Result: "boolean"
4. 转换为字符串
要快速地将数字转换为字符串,我们可以使用连接运算符+
后跟一组空引号""
。
const val = 1 + "";console.log(val); // Result: "1"console.log(typeof val); // Result: "string"
5. 转换为数字
使用加法运算符+
可以快速实现相反的效果。
let int = "15";int = +int;console.log(int); // Result: 15console.log(typeof int); Result: "number"
这也可以用于将布尔值转换为数字,如下所示
console.log(+true); // Return: 1 console.log(+false); // Return: 0
在某些上下文中,+
将被解释为连接操作符,而不是加法操作符。当这种情况发生时(你希望返回一个整数,而不是浮点数),您可以使用两个波浪号:~~
。
连续使用两个波浪有效地否定了操作,因为— ( — n — 1) — 1 = n + 1 — 1 = n
。换句话说,~—16
等于15。
const int = ~~"15"console.log(int); // Result: 15console.log(typeof int); Result: "number"
虽然我想不出很多用例,但是按位NOT运算符也可以用在布尔值上:~true = \-2
和~false = \-1
。
6.性能更好的运算
从ES7开始,可以使用指数运算符**
作为幂的简写,这比编写Math.pow(2, 3)
更快。这是很简单的东西,但它之所以出现在列表中,是因为没有多少教程更新过这个操作符。
console.log(2 ** 3); // Result: 8
这不应该与通常用于表示指数的^符号相混淆,但在JavaScript中它是按位异或
运算符。
在ES7之前,只有以2
为基数的幂才存在简写,使用按位左移操作符<<
Math.pow(2, n);2 << (n - 1);2**n;
例如,2 << 3 = 16
等于2 ** 4 = 16
。
7. 快速浮点数转整数
如果希望将浮点数转换为整数,可以使用Math.floor()
、Math.ceil()
或Math.round()
。但是还有一种更快的方法可以使用|
(位或运算符)将浮点数截断为整数。
console.log(23.9 | 0); // Result: 23console.log(-23.9 | 0); // Result: -23
|
的行为取决于处理的是正数还是负数,所以最好只在确定的情况下使用这个快捷方式。
如果n
为正,则n | 0
有效地向下舍入。如果n
为负数,则有效地向上舍入。更准确地说,此操作将删除小数点后面的任何内容,将浮点数截断为整数。
你可以使用~~
来获得相同的舍入效果,如上所述,实际上任何位操作符都会强制浮点数为整数。这些特殊操作之所以有效,是因为一旦强制为整数,值就保持不变。
删除最后一个数字
按位或
运算符还可以用于从整数的末尾删除任意数量的数字。这意味着我们不需要使用这样的代码来在类型之间进行转换。
let str = "1553";Number(str.substring(0, str.length - 1));
相反,按位或运算符可以这样写:
console.log(1553 / 10 | 0) // Result: 155console.log(1553 / 100 | 0) // Result: 15console.log(1553 / 1000 | 0) // Result: 1
8. 类中的自动绑定
我们可以在类方法中使用ES6箭头表示法,并且通过这样做可以隐含绑定。这通常会在我们的类构造函数中保存几行代码,我们可以愉快地告别重复的表达式,例如this.myMethod = this.myMethod.bind(this)
import React, { Component } from React;export default class App extends Compononent { constructor(props) { super(props); this.state = {}; }myMethod = () => { // This method is bound implicitly! }render() { return ( <> <div> {this.myMethod()} </div> </> ) }};
9. 数组截断
如果要从数组的末尾删除值,有比使用splice()
更快的方法。
例如,如果你知道原始数组的大小,您可以重新定义它的length
属性,就像这样
let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];array.length = 4;console.log(array); // Result: [0, 1, 2, 3]
这是一个特别简洁的解决方案。但是,我发现slice()
方法的运行时更快。如果速度是你的主要目标,考虑使用:
let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];array = array.slice(0, 4);console.log(array); // Result: [0, 1, 2, 3]
10. 获取数组中的最后一项
数组方法slice()
可以接受负整数,如果提供它,它将接受数组末尾的值,而不是数组开头的值。
let array = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];console.log(array.slice(-1)); // Result: [9]console.log(array.slice(-2)); // Result: [8, 9]console.log(array.slice(-3)); // Result: [7, 8, 9]
11.格式化JSON代码
最后,你之前可能已经使用过JSON.stringify
,但是您是否意识到它还可以帮助你缩进JSON?
stringify()
方法有两个可选参数:一个replacer
函数,可用于过滤显示的JSON和一个空格值。
console.log(JSON.stringify({ alpha: 'A', beta: 'B' }, null, '\t'));// Result:// '{// "alpha": A,// "beta": B// }'
包邮送书
《JavaScript编程精解(原书第3版)》 这本书由世界知名JS工程师撰写,JS之父BrendanEich及世界知名专家强力推荐,提纲挈领地介绍了JS语言的主要功能和特色,包括基本结构、函数、数据结构、高阶函数、错误处理、正则表达式、模块、异步编程、浏览器文档对象模型、事件处理、绘图、HTTP表单、Node等,读者可以通过学习这些内容循序渐进地掌握基本的编程概念、技术和思想 。
为了读者能够较快地上手实际的项目,这本书还安排了5个实战章节,涉及路径查找、自制编程语言、平台交互游戏、绘图工具和动态网站等方面,这些章节教会你如何利用掌握的知识实现各种功能,并组成一个完整的项目。《JavaScript编程精解》第3版包含了JavaScript语言ES6 规范的最新功能,比如绑定、常量、类、promise等。通过学习本书,你能了解该语言的最新发展,并编写出更强大的代码。适读人群:本书适合JavaScript零基础入门新手阅读。通过阅读本书,你将:
了解编程的基本要素,包括语法、控制和数据
使用面向对象和函数式编程技术组织和阐明代码
编写浏览器脚本并开发基本的Web应用程序
高效地使用DOM与浏览器进行交互
利用Node.js构建服务器和实用程序
怎么送
简单点,老规矩,公众号后台回复 666获取小程序抽奖码,扫码即可参与
开奖时间: 周三(04/29)晚18:00
往期
在看支持一下❤️
本文分享自微信公众号 - Vue中文社区(vue_fe)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。