ES6语法补充

本文详细解释了JavaScript中`bind()`函数的作用,探讨了函数内`this`指向的规则,以及箭头函数对`this`的保持原样。还介绍了对象解构、数组展开以及命名与默认导出的特性。
摘要由CSDN通过智能技术生成

使用bind()函数绑定this取值
在JavaScript中,函数里的this指向的是执行时的调用者,而非定义时所在的对象。

例如:

const person = {
  name: "yxc",
  talk: function() {
    console.log(this);
  }
}

person.talk();

const talk = person.talk;
talk();


运行结果:

{name: 'yxc', talk: ƒ}
Window
bind()函数,可以绑定this的取值。例如:

const talk = person.talk.bind(person);
箭头函数的简写方式

const f = (x) => {
  return x * x;
};

可以简写为:

const f = x => x * x;


箭头函数不重新绑定this的取值
例如:

const person = {
  talk: function() {
    setTimeout(function() {
      console.log(this);
    }, 1000);
  }
};

person.talk();  // 输出Window
const person = {
  talk: function() {
    setTimeout(() => {
      console.log(this);
    }, 1000);
  }
};

person.talk();  // 输出 {talk: f}

对象的解构
例如:

const person = {
  name: "yxc",
  age: 18,
  height: 180,
};
const {name : nm, age} = person;  // nm是name的别名

数组和对象的展开
例如:

let a = [1, 2, 3];
let b = [...a];  // b是a的复制
let c = [...a, 4, 5, 6];
const a = {name: "yxc"};
const b = {age: 18};
const c = {...a, ...b, height: 180};

Named 与 Default exports
Named Export:可以export多个,import的时候需要加大括号,名称需要匹配
Default Export:最多export一个,import的时候不需要加大括号,可以直接定义别名

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值