11个JavaScript小技巧







关注  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以前,隔离唯一值将涉及比这多得多的代码。vue

此技巧适用于包含基本类型的数组:undefinednullbooleanstringnumber。(若是你有一个包含对象,函数或其余数组的数组,你须要一个不一样的方法!)webpack

2. 与或运算

三元运算符是编写简单(有时不那么简单)条件语句的快速方法,以下所示:web

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: 3
console.log(0 && null); // Result: 0

使用||将返回第一个条件为的值。若是每一个操做数的计算结果都为false,则返回最后一个计算过的表达式。小程序

let one = 1, two = 2, three = 3;
console.log(one || two || three); // Result: 1
console.log(0 || null); // Result: null

例一

假设咱们想返回一个变量的长度,可是咱们不知道变量的类型。segmentfault

咱们可使用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 就是添加了?.这么个操做符,它会先判断前面的值,若是是 nullundefined,就结束调用、返回 undefined

例如,咱们能够将上面的示例重构为 this.state.data?.()。或者,若是咱们主要关注state 是否已定义,咱们能够返回this.state?.data

该提案目前处于第1阶段,做为一项实验性功能。你能够在这里阅读它,你如今能够经过Babel使用你的JavaScript,将 @babel/plugin-proposal-optional-chaining添加到你的.babelrc文件中。

3.转换为布尔值

除了常规的布尔值truefalse以外,JavaScript还将全部其余值视为 ‘truthy’ 或**‘falsy’**。

除非另有定义,不然 JavaScript 中的全部值都是'truthy',除了 0“”nullundefinedNaN,固然还有false,这些都是**'falsy'**

咱们能够经过使用负算运算符轻松地在truefalse之间切换。它也会将类型转换为“boolean”。

const isTrue  = !0;
const isFalse = !1;
const alsoFalse = !!0;
console.log(isTrue); // Result: true
console.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: 15
console.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: 15
console.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: 23
console.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: 155
console.log(1553 / 100 | 0) // Result: 15
console.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

往期

轻松优化你的webpack
面试官:前端代码线上出错如何解决?使用sentry

在看支持一下❤️

本文分享自微信公众号 - Vue中文社区(vue_fe)。
若有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一块儿分享。

相关文章
相关标签/搜索