使用call方法自定义接受者来调用方法

来源:互联网 发布:淘宝 企业店铺 编辑:程序博客网 时间:2024/05/16 11:53

当某个对象调用一个并不属于自己的属性的函数时,可以使用函数对象具有的一个内置的方法call来自定义接收对象,也就是说,某个对象可以通过函数对象的call方法来调用不属于自己属性的函数对象。

1.使用call方法自定义接收对象来调用函数:

f.call(obj,arg1,arg2,arg3);//obj为调用f方法后的接收对象,arg1、arg2、arg3为传入f中的参数

2.使用call方法可以调用在给定的对象中不存在的方法:

JavaScript中的hasOwnProperty方法可以被任意的对象调用,但当这个对象为字典对象时,查找hasOwnProperty属性会得到该字典的属性值,而不是继承过来的方法。

例如:

dict.hasOwnProperty = 1;dict.hasOwnProperty("foo");//这里应该调用hasOwnProperty方法,但是却报错“error:1 is not a function”
此时应该使用hasOwnProperty方法的call方法使调用字典对象中的方法成为可能,即使hasOwnProperty方法并有存储在该对象中。

var hasOwnProperty = {}.hasOwnProperty;dict.foo = 1;delete dict.hasOwnProperty;hasOwnProperty.call(dict,"foo");//truehasOwnProperty.call(dict,"goo");//false


3.使用call方法定义高阶函数允许使用者给回调函数指定接受者:

高阶函数是指那些将函数作为参数或返回值的函数,而其中作为高阶函数的参数的函数被称为回调函数。高阶函数的一个惯用法是接收一个可选的参数作为该函数的接收者。例如,表示键值对列表的对象可能提供一个名为forEach的方法:

var table = {    entries: [];    addEntry: function(){        this.entries.push({key: key, value: value});    }    forEach: function(f,thisArg){        var entries = this.entries[i];        for(var i = 0,n = entries.length;i<n;i++){            var entry = entries[i];            f.call(thisArg,entry.key,entry.value,i);        }    }};
上述例子允许table对象的使用者将一个方法作为table.forEach的回调函数f,并为该方法提供了 接受者,所以可以很方便的将一个table的内容复制到另一个table中:

table1.forEach(table2.addEntry,table2);

这段代码从table2中提取addEntry方法,forEach方法将table2作为接收者,并反复调用该addEntry方法。




原创粉丝点击