call,apply,bind的区别

call

php

apply

数组

bind

方法的共同点和区别:app

apply

 、 函数

call

 、this

bind

 三者都是用来改变函数的this对象的指向的;code

apply

 、 对象

call

 、blog

bind

 三者第一个参数都是this要指向的对象,也就是想指定的上下文(函数的每次调用都会拥有一个特殊值——本次调用的上下文(context)——这就是get

this

关键字的值。);it

apply

 、 

call

 、

bind

 三者均可以利用后续参数传参;

bind

 是返回对应函数,便于稍后调用;

apply

 、

call

 则是当即调用 。
用一个实例来讲明吧。
已知函数 fn 执行须要 3 个参数。请实现函数 partial,调用以后知足以下条件:
一、返回一个函数 result,该函数接受一个参数
二、执行 result(str3) ,返回的结果与 fn(str1, str2, str3) 一致
输入:

var sayIt = function(greeting, name, punctuation) {     return greeting + ', ' + name + (punctuation || '!'); }; 
partial(sayIt, 'Hello', 'Ellie')('!!!');

输出:

Hello, Ellie!!!
 call和apply必须显式地调用str3,当即执行
 bind不是当即执行,未传入str3时,并未执行,只是返回一个函数,等待参数传入
// call
function partial(fn, str1, str2) {
    function result(str3) {
        return fn.call(this, str1, str2, str3);
//指定上下文为this,以后参数挨个依次传入
    }
 
     return result;
}
// apply
function partial(fn, str1, str2) {
    function result(str3) {
        return fn.apply(this, [str1, str2, str3]);
//参数以数组的形式传入
    }
 
    return result;
}

bind不加后面的括号返回的是函数,加上后面的括号返回的是函数值,这也是bind和call和apply的主要区别,bind须要二次调用,而call和apply返回的是函数值,是直接调用。这道题让我更理解了三者的区别。

function partial(fn, str1, str2) {
    
    var result=function(str3){
        return fn.bind(this,str1,str2)(str3);
    };
    return result;
}

 
 

转载于猿2048:➺《call,apply,bind的区别》

相关文章
相关标签/搜索