ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

更改this指向的call() 、 apply()  和 bind()

2022-04-29 02:32:20  阅读:132  来源: 互联网

标签:obj name bind age call apply fn


首先,函数内部中的 this 指向谁,不是在函数定义时决定的谁调用,指向谁

1. call 方法

语法:函数名.call(调用者, 参数1, …)
作用:函数被借用时,会立即执行,并且函数体内的this会指向借用者或调用者

function fn(name, age) {
    this.name = name;
    this.age = age;
}
const obj = {}
// 经过call,this指向obj,obj开始有name、age属性
fn.call(obj, '李四', 100)
// 以下this均指向window,name:undefined,age:undefined
fn.call()
fn.call(null)
fn.call(undefined)

结果:普通函数的this指向window,利用call方法将this指向了obj

2. apply方法

语法:函数名.apply(调用者, [参数, …])
作用:函数被借用时,会立即执行,并且函数体内的this会指向借用者或调用者

function fn(name, age) {
    this.name = name;
    this.age = age;
}
const obj = {}
// 经过apply,this指向obj,obj开始有name、age属性
fn.apply(obj, ['李四', 100])
// 以下this均指向window,name:undefined,age:undefined
fn.apply()
fn.apply(null)
fn.apply(undefined)

结果:普通函数的this指向window,利用apply方法将this指向了obj

3. bind方法

语法:函数名.bind(调用者, 参数, …)
作用:函数被借用时,不会立即执行,而是返回一个新的函数。需要自己手动执行,一般用于不需要立即执行的时候

function fn(name, age) {
    this.name = name;
    this.age = age;
}
const obj = {}
// const newFn = fn.bind(obj, '李四', 100)
// newFn()
fn.bind(obj, '李四', 100)()

结果:普通函数的this指向window,利用bind方法将this指向了obj

总结:

  • 相同:三者都可以把一个函数应用到其他对象身上,注意不是自身对象
  • 不同:
    ○ call,apply是直接执行函数调用。bind是绑定,执行需要再次调用。
    ○ call,bind接收逗号分隔的无限个参数列表;apply接收数组作为参数。

 

标签:obj,name,bind,age,call,apply,fn
来源: https://www.cnblogs.com/suihung/p/16205224.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有