js【详解】call()、apply()、bind()方法

简介: js【详解】call()、apply()、bind()方法

call()、apply()、bind()都是Function原型上的方法(所有的函数都是Function的实例,所以所有函数都支持这三种方法

用途都是改变this的指向

var name="张三",age=18;
 
var obj = {
  name:"李四",
  oldAge:this.age,
  myFn:function(a, b){
    console.log( this.name+"年龄"+this.age,"来自"+a+"去往"+b )
  }
}
 
var newObj = {
    name:"王五",
    age:22
}
 
obj.myFn.call(newObj,'北京','上海'); // 王五年龄22 来自北京去往上海
obj.myFn.apply(newObj,['北京','上海']);  // 王五年龄22 来自北京去往上海 
obj.myFn.bind(newObj,['北京','上海'])(); //王五年龄22 来自北京,上海去往undefined
obj.myFn.bind(newObj,'北京','上海')(); // 王五年龄22 来自北京去往上海

call()、apply()、bind()的相同点:

第一个参数相同,都是this要绑定的对象

call()、apply()、bind()的不同点:

  • call 的第二、第三……第 N 个参数,全都用逗号分隔  obj.myFn.call(newObj,'北京','上海')
  • apply 的第二、第三……第 N 个参数,全都放在一个数组 obj.myFn.apply(newObj,['北京','上海'])
  • bind 的传参方法与call相同,但因bind会返回一个新的函数,所以必须再次调用才会执行,即还需加上(),如obj.myFn.bind(newObj,'北京','上海')();
目录
相关文章
|
2天前
|
JavaScript
js 获取并解析 url 中参数的三种方法
js 获取并解析 url 中参数的三种方法
6 0
|
5天前
|
JavaScript 前端开发 Java
JavaScript中的hasOwnProperty方法详解
JavaScript中的hasOwnProperty方法详解
|
5天前
|
JavaScript
|
6天前
|
Web App开发 JavaScript iOS开发
技术笔记:js数组定义和方法(包含ES5新增数组方法)
技术笔记:js数组定义和方法(包含ES5新增数组方法)
|
6天前
|
JavaScript BI
技术笔记:JS获取子节点、父节点和兄弟节点的方法实例总结
技术笔记:JS获取子节点、父节点和兄弟节点的方法实例总结
10 0
|
16天前
|
JavaScript 前端开发 开发者
【JavaScript】JavaScript中call、apply与bind的区别:进阶特性与应用场景
【JavaScript】JavaScript中call、apply与bind的区别:进阶特性与应用场景
14 0
|
2月前
|
前端开发 JavaScript
【Web 前端】 js中call、apply、bind有什么区别?
【4月更文挑战第22天】【Web 前端】 js中call、apply、bind有什么区别?
【Web 前端】 js中call、apply、bind有什么区别?
|
2月前
|
JavaScript 前端开发
关于javascript中call(),apply(),bind()的介绍,初步
关于javascript中call(),apply(),bind()的介绍,初步
|
2月前
|
JavaScript
JS中call()、apply()、bind()改变this指向的原理
JS中call()、apply()、bind()改变this指向的原理
|
12月前
|
JavaScript 前端开发
JavaScript call、apply 和 bind 的区别
JavaScript call、apply 和 bind 的区别