ES6-7个实用技巧(收藏)

1、交换元素


利用  数组解构  来实现值得互换

let a =  'hello' , b = 'world'

[a, b] = [b, a]

console.log(a)  // 输出world

console.log(b) // 输出hello

2、调试


我们经常使用 console.log() 来进行调试,试试 console.table()。

const a = 1, b = 2, c = 3

console.log ({ a, b, c })

console.table({ a, b, c, m: {name: 'xxx', age:22}})

3、单条语句


es6时代,操作数组的语句将会更加的经凑

// 寻找数组中的最大值

const max = (arr) => Math.max(...arr)

max([123, 321 , 32]) // outputs: 321

// 计算数组的总和

const sum = (arr) => arr.reduce((a, b) => (a + b), 0)

sum([1, 2, 3, 4]) // output : 10

4、数组拼接


展开运算符可以取代 concat 的地位

const one = [ 'a', 'b', 'c' ]

const two = [ 'd', 'e', 'f' ]

const three = [ 'g', 'h', 'i']

const result = [... one, ...two, ...three]

5、 制作副本


我们可以很容易的实现数组和对象的浅拷贝

const obj = { ...oldObj }

const arr = [ ...oldArr ]

拷贝 = 深拷贝 ? 浅拷贝 ?

好像有些朋友对这里我说的浅拷贝有些质疑,我也能理解大家所说的。下面数组为例:

// 数组元素为简单数据类型非引用类型

const arr = [1, 2, 3, 4];

const newArr = [...arr];

// 数组元素为引用类型,,,,浅拷贝

const person01 = {name: 'name01', age: 1};

const person02 = {name: 'name01', age: 2};

const person03 = {name: 'name03', age: 3};

const arr = [person01, person02, person03];

const newArr = [...arr];

console.log(newArr[0] === person01);

// true

6、 命名参数👍👍👍


解构使得函数声明和函数的调用更加可读

// 我们尝尝使用的写法

const getStuffNotBad = (id, force, verbose) => {

 ...do stuff

}

// 当我们调用函数时, 明天再看,尼玛 150是啥,true是啥

getStuffNotBad(150, true, true)

// 看完本文你啥都可以忘记, 希望够记住下面的就可以了

const getStuffAwesome = ({id, name, force, verbose}) => {

 ...do stuff

}

// 完美

getStuffAwesome({ id: 150, force: true, verbose: true })

7、 Async/Await结合数组解构


数组解构非常赞!结合Promise.all和解构和await会使代码变得更加的简洁

const [user, account] = await Promise.all([

 fetch('/user'),

 fetch('/account')

])




原文:https://segmentfault.com/a/1190000012871249

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 4,236评论 0 13
  • let ,const, varvar :没有作用域一说,且存在作用域提升的问题let const: 只能在当前作用...
    壹点微尘阅读 514评论 0 1
  • ES6语法跟babel: 一、首先我们来解释一下什么是ES? ES的全称是ECMAScript。1996 11 ,...
    Mooya_阅读 1,065评论 0 0
  • js简介 Js是一种基于事件和对象驱动的解释性、松散性的语言。 一切皆对象 javascript 布兰登艾奇 ...
    塔库纳玛哈哈阅读 1,245评论 0 2
  • 童年债最近在群里出现频率颇高,可能受此影响,看到龙珠的拍品,没怎么想就拍了,于是其到单位的同时,顺道也把单位的少量...
    雪人的窝阅读 1,735评论 22 51