有一个类作为例子:
var Class = {
initialize: function(data){
this.data = data;
},
add: function(node){
//add object
},
remove: function(node){
//remove object
},
findByIndex: function(id){
},
}
等等。
问题:如何将上下文导入findByIndex
?
例如,我需要在另一个类中使用findByIndex
作为函数。
我知道它应该是bind
,但如何在我的班级中使用它?
findByIndex:function(id, ???context???){
????
}
/////////////////////// ADD ////////////////// 这是方法
L.Bookmarks = L.Class.extend({
findByIdRecursive: function(idNumber) {
var data = this.childNodes;
var returnItems = {};
function callback(node) {
if (parseInt(node.id) === idNumber)
returnItems = node;
};
for (var i = data.length - 1; i >= 0; i--) {
this.iterator(data[i], callback, this);
};
return returnItems;
},
iterator: function(node, callback, context) {
console.log(this)
callback.call(this, node);
var nodes = node.childNodes;
if (nodes === undefined) {
return;
};
for (var i = 0; i < nodes.length; i++) {
var iterNode = nodes[i];
this.iterator(iterNode, callback, this);
};
},
});
这是另一个使用方法迭代器的类:
L.Book = L.Class.extend({
findByIdRecursive: function(idNumber) {
var data = this.childNodes;
var returnItems = {};
function callback(node) {
console.log(this)
if (parseInt(node.id) === idNumber)
returnItems = node;
};
for (var i = data.length - 1; i >= 0; i--) {
var itertator = L.Book.iterator.call(L.Bookmarks, data[i], callback)
};
return returnItems;
},
});
正如您所看到的,第二类没有方法迭代器。但最终它应该使用迭代器,就像所有者(带上下文(this - L.Book))
答案 0 :(得分:0)
您可以使用call
:
var b = new OtherClass();
// find Index 1 in b (OtherClass)
var element = Class.findByIndex.call(b,1);
在MDN
上查看更多示例此外,如果您使用ES6类(请参阅MDN),则可以使用extends
定义新类,以便继承前一类中的方法:
class NewClass extends Class {
//...
}
答案 1 :(得分:0)
使用.bind
功能,您可以通过这种方式多次重复使用findByIndex
var Utils = {
findByIndex: function(id){
return this.data[id];
}
}
var FirstObject = {
data : {
a : 'aaa',
b : 'bbb'
}
}
var SecondObject = {
data : {
d : 'ddd',
e : 'eee'
}
}
console.log(Utils.findByIndex.call(SecondObject, 'd'))
console.log(Utils.findByIndex.call(FirstObject, 'a'))