类方法中的上下文为变量

时间:2016-04-21 16:36:00

标签: javascript oop function-binding

有一个类作为例子:

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))

2 个答案:

答案 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'))