首页 > 移动平台 > 详细

call和apply,函数伴侣

时间:2019-09-19 19:01:43      阅读:108      评论:0      收藏:0      [点我收藏+]

Predefined:js中的this指向直接运行上下文。

  call和apply是ECMASCRIPT 3在函数原型上所定义的方法,目的在于改变或指定this的指向,从而改变函数直接执行上下文。两者的不同之处在于传参,call接受多个参数,而apply接受数组。

  1:隐藏的call和apply:     

1 var a = "hello";
2 
3 function foo(){
4    alert(this.a)  
5 }
6 
7 foo() ;                                //"hello"
8 foo.call(window);               // "hello"  
// window.foo() == foo.call(window);

  默认的,我们认为:若函数以函数名+小括号方式执行,那么会调用原型中的call方法(此处只讨论call方法),动态的指定直接执行上下文.

  2:常用技巧:

  

function superType(name){
    this.name = name;
}
function SubType(name){
    superType(name)
}
var instance = new SubType("lihua");
console.log(instance.name);           //undefined;
console.log(global.name);             //lihua

//在借用构造函数中
function superType(name){
    this.name = name;
}
function SubType(name){
    superType.call(this,name)
}
var instance = new SubType("lihua");
console.log(instance.name);           //lihua;
console.log(global.name);             //undefined
//使用apply改变传参方式

var countArr = [1,2,3,13,24,5,21];
Math.max(countArr);        //NaN(类型转换)
Math.max.apply(Math,countArr)         //24

 

 

 

 

 

 

call和apply,函数伴侣

原文:https://www.cnblogs.com/lh-zq/p/11551562.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!