ES6知识盲点整理

2021-11-15 15:35:08 浏览数 (1)

ES6知识盲点整理

  • 箭头函数
  • JS数组的map()方法
  • 关于严格模式普通函数和箭头函数中this的指向问题
  • call、apply和bind的区别
  • 深入理解ES6箭头函数里的this
  • ES6(...)展开运算符

箭头函数

箭头函数


JS数组的map()方法

map() 方法创建一个新数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果。

语法:

代码语言:javascript复制
var new_array = arr.map
(
function callback(currentValue,index,array)
{
 ...
 return ...
}
,thisArg)

参数:

callback 生成新数组元素的函数,使用三个参数:

currentValue callback 数组中正在处理的当前元素。

index可选 callback 数组中正在处理的当前元素的索引。

array可选 map 方法调用的数组。

thisArg可选 执行 callback 函数时值被用作this。

返回值:

一个由原数组每个元素执行回调函数的结果组成的新数组。

Array.prototype.map()


关于严格模式普通函数和箭头函数中this的指向问题

1.在ES5,ES6中,全局作用域下无论是否为严格模式this都指向window

2.全局作用域中函数中的this:es5,非严格模式this指向window,严格模式下的this指向undefined;es6箭头函数的this都指向window。

关于严格模式普通函数和箭头函数中this的指向问题


call、apply和bind的区别

call调用 将方法中的this指向call中第一个参数,当第一个参数为null、undefined时,默认指向window; call中第一个参数之后是要传递给方法的参数列表。

apply与call相似,不同之处在于传递给方法的参数形式不一致。apply传递给方法的参数是数组的形式。

call和apply在改变方法的this指向时,会同时执行方法;而bind不会执行方法,而是返回改变this指向后的新方法。


深入理解ES6箭头函数里的this

深入理解ES6箭头函数里的this,看这篇就够了

关于箭头函数中的this的指向


ES6(…)展开运算符

在ES6中用…来表示展开运算符,它可以将数组方法或者对象进行展开。先来看一个例子它是如何使用的。

代码语言:javascript复制
const arr1 = [1, 2, 3];
const arr2 = [...arr1, 10, 20, 30];
 
 这样,arr2 就变成了[1, 2, 3, 10, 20, 30];

arr1中的值完全克隆到了arr2中(arr1改变arr2中还是最初的值)。当然,展开对象数据也是可以得到类似的结果

代码语言:javascript复制
const obj1 = {
  a: 1,
  b: 2, 
  c: 3
}
 
const obj2 = {
  ...obj1,
  d: 4,
  e: 5,
  f: 6
}
 
 结果类似于 const obj2 = Object.assign({}, obj1, {d: 4})

展开运算符还常常运用在解析结构之中,例如我们在Raect封装组件的时候常常不确定props到底还有多少数据会传进来,就会利用展开运算符来处理剩余的数据。

代码语言:javascript复制
这种方式在react中十分常用
const props = {
  size: 1,
  src: 'xxxx',
  mode: 'si'
}
props 设置了基础数据,后续数据根据展开运算符植入
 
 
const { size, ...others } = props;
 
console.log(others)
 
然后再利用暂开运算符传递给下一个元素,再以后封装react组件时会大量使用到这种方式,正在学习react的同学一定要搞懂这种使用方式
<button {...others} size={size} />

展开运算符还用在函数的参数中,来表示函数的不定参。只有放在最后才能作为函数的不定参,否则会报错。

代码语言:javascript复制
// 所有参数之和
const add = (a, b, ...more) => {
    return more.reduce((m, n) => m   n)   a   b
}
 
console.log(add(1, 23, 1, 2, 3, 4, 5)) // 39

ES6(…)展开运算符

es6展开运算符 …


0 人点赞