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

2018-01-18  本文已影响0人  princehigh

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

上一篇下一篇

猜你喜欢

热点阅读