bind,call,apply的使用以及不同之处

function fn(...args) {
  console.log(this.uname)
  console.log(args)
}

// bind,改变this指向,返回函数,可传参
let obj1 = {
  uname: '小明',
}
fn.bind(obj1)('我是小明参数')

// call,改变this指向,并执行函数,普通传参
let obj2 = {
  uname: '小王',
}
fn.call(obj2, '我是小王的参数', 123)

// apply,改变this指向,并执行函数,数组传参
let obj3 = {
  uname: '小刚',
}

fn.apply(obj3, ['我是小刚的第一个参数', '我是小刚的第二个参数'])

// [ '我是小明参数' ]
// 小明
// [ '我是小王的参数' ]
// 小王
// [ '我是小刚的第一个参数', '我是小刚的第二个参数' ]
// 小刚

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值