美文网首页
fn.call()、fn.apply()区别

fn.call()、fn.apply()区别

作者: 紫诺_qiu | 来源:发表于2017-02-21 17:03 被阅读633次
    • 两者的语法基本完全相同,唯一的区别在于,call()方法接受的是一个参数列表,而apply()方法接受的是一个包含多个参数的数组(或类数组对象)。
    obj.call(thisObj,arg1,arg2,...);
    obj.apply(thisObj,[arg1,arg2,...]);
    
    • 简单实例
    var array = [1,2,3];
    var fn = array.forEach;
    fn(item => console.log(item));
    
    fn.call(array,item => console.log(item));      //1 2 3
    fn.apply(array,[item => console.log(item)]);  // 1 2 3
    
    • fn.bind()用法

    bind()方法会创建一个新函数,当这个新函数被调用时,它的this值是传递给bind()的第一个参数,它的参数是bind()的其他参数和其原本的参数。
    语法如下:

    fn.bind(fn,arg1,arg2,...);
    
    • 简单实例
    fn = _.bind(fn,array)    或
    var _fn = fn.bind(array,item => console.log(item));
    
    _fn.call();
    _fn.apply();
    fn(item => console.log(item));      //三者输出结果相同,均为 1 2 3
    

    相关文章

      网友评论

          本文标题:fn.call()、fn.apply()区别

          本文链接:https://www.haomeiwen.com/subject/dtxbbttx.html