当前位置: 移动技术网 > IT编程>开发语言>JavaScript > js中的call bind apply简单分析

js中的call bind apply简单分析

2019年04月06日  | 移动技术网IT编程  | 我要评论

js中的call bind apply简单分析

\

使用call()时,obj调用了test得的sum方法,这就相当于把sum方法写到了obj里,并向sum里传了两个参数,所以1,2两个alert()输出的是传进的两个参数;self.a和self.b取得的是obj内的a,b值为2,3,和为5.

bind函数将test.sum简化为另一个全局函数sum(b),sum(b)只需要传入一个参数即可。

三种方法中的第一个参数实际上代表了this的指向,比如说第二个apply() 中的意思就是说我要把test.sum中的方法指向obj,再转向test对象中,可以得到self = this =obj

var test = {
    a : 5,
    b : 6,
    sum : function (a,b) {
 console.log(a,b)      //4,5
        function geta(a) {
			this.a = a;    //定义全局作用域a ,值为4
            return this.a;            
        }
        function getb(b){
			this.b =b;	  //定义全局作用域b,值为5
            return this.b;
        }
        alert(a);
        alert(b);
        return geta(a) + getb(b);
    }
}
var obj = {a:2,b:3};
console.log(test.sum.call(obj,4,5));        //将this指向obj,并将4,5传递给函数sum,接收后
console.log(a,b)     //返回全局作用域

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网