JavaScript 中 call()、apply()、bind() 的用法理解

JavaScript 中 call()、apply()、bind() 的用法

JavaScript 中 call()、apply()、bind()的区别很好理解,先看例子

栗子1:
一般情况下this的指向:

var name = '小帅',age = 20
var obj = {
	name:'小憨',
	objAge:this.age,
	myfun:function(){
		console.log(this.name+"年龄"+this.age)
	}
}

obj.objAge;  // 20
obj.myFun()  // 小憨年龄 undefined

栗子2:

var fahai = '法海'
function shows(){
	console.log(this.fahai)
}
shows()  // 法海 

比较一下这两者 this 的差别,第一个打印里面的 this 指向 obj,第二个全局声明的 shows() 函数 this 是 window ;
扩展一下关于this指向:

  • 全局作用域或者普通函数中 this 指向全局对象 window
  • 方法调用中谁调用 this 指向谁
  • 在构造函数或者构造函数原型对象中 this 指向构造函数的实例
  • 箭头函数中指向外层作用域的 this

下边言归正传

1,call()、apply()、bind() 都是用来重定义 this 这个对象的!

还是直接上代码

var name = '小帅',age = 20
var obj = {
	name:'小憨',
	objAge:this.age,
	myfun:function(){
		console.log(this.name+"年龄"+this.age)
	}
}
var mei = {
	name:'小美',
	age:19
}
obj.myFun.call(mei);    // 小美年龄19
obj.myFun.apply(mei);    // 小美年龄19
obj.myFun.bind(mei)();   // 小美年龄19

以上出了 bind 方法后面多了个 () 外 ,结果返回都一致!
由此得出结论,bind 返回的是一个新的函数,你必须调用它才会被执行。

2,对比call 、bind 、 apply 传参情况下
var name = '小帅',age = 20
var obj = {
	name:'小憨',
	objAge:this.age,
	myfun:function(){
		console.log(this.name+"年龄"+this.age+"来自"+fm+"去往"+goto)
	}
}
var mei = {
	name:'小美',
	age:19
}
obj.myFun.call(mei,'成都','上海');    // 小美年龄19来自成都去往上海
obj.myFun.apply(mei,['成都','上海']);    // 小美年龄19来自成都去往上海
obj.myFun.bind(mei,'成都','上海')();   // 小美年龄19来自成都去往上海
obj.myFun.bind(mei,['成都','上海'])();   // 小美年龄19成都, 上海去往undefined

微妙的差距!

从上面四个结果不难看出:
call 、bind 、 apply 这三个函数的第一个参数都是 this 的指向对象,第二个参数差别就来了:
call 的参数是直接放进去的,第二第三第 n 个参数全都用逗号分隔,直接放到后面 obj.myFun.call(db,‘成都’, … ,‘string’ )。
apply 的所有参数都必须放在一个数组里面传进去 obj.myFun.apply(db,[‘成都’, …, ‘string’ ])。
bind 除了返回是函数以外,它 的参数和 call 一样。
当然,三者的参数不限定是 string 类型,允许是各种类型,包括函数 、 object 等等

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值