Javascript使用props扩展类?

时间:2013-11-14 17:14:37

标签: javascript jquery class oop

我将课程定义为:

function MyClass() {

}

MyClass.prototype = {
       init: function() {
                 alert('My parent class!');
       },
       method1: function() {},
       method2: function() {}
};

和属性对象:

{
     init: function() {
               MySubClass.superclass.init.apply(this, arguments);
               alert('test!');
     },

     test: function() {
               alert();
     }
}

我需要使用props(对象)扩展基类(MyClass)并返回NEW扩展子类(到MySubClass)的函数:

MySubclass = extend(MyClass, {
     init: function() {
               MySubClass.superclass.init.apply(this, arguments);
               alert('test!');
     },

     test: function() {
               alert();
     }
});

构造函数必须替换为新的构造函数(来自init)。

我需要一个正确的方法。

为什么它不能正常工作?

extend: function(bc, o) {
        // result class (apply only first constructor)
        var cls = function() {};
        cls.prototype = bc.prototype;

        for (var k in o)
            cls.prototype[k] = o[k];

        cls.superclass = bc.prototype;

        return cls;
    }

4 个答案:

答案 0 :(得分:2)

你的extend函数必须看起来像这样 - 现在这比你应该如何实现它简单得多但它应该有效:

var extend = function(Super, props) {
   var sinstance = new Super()
   var sclass = props.constructor || sinstance.constructor;
   sclass.prototype.super = sinstance;
   sclass.prototype.constructor = Super;

   //use underscore extend prototypes cause im too lazy to type it out
   _.extend(sclass.prototype, sinstance, props);
   return sclass;
}

调用subclass.super.call(this, props...)可以访问被覆盖的超级方法。

刚刚测试过,如果下划线js在页面上,则此方法有效:

function MyClass() {

}
MyClass.prototype = {
       init: function() {
                 alert('My parent class!');
       },
       method1: function() {},
       method2: function() {}
};

MySubclass = extend(MyClass, {
     init: function() {
               this.super.init.apply(this, arguments);
               alert('test!');
     },

     test: function() {
               alert();
     }
});

var test = new MySubclass();
test.init("yo"); //alerts My parent class

您的更新也可以执行此操作:

MySubclass2 = extend(MyClass, {
     constructor: function() {
        this.init();
     },

     init: function() {
               this.super.init.apply(this, arguments);
               alert('test!');
     },

     test: function() {
               alert();
     }
});

var test2 = new MySubclass2();//alerts My parent class

答案 1 :(得分:0)

如果您愿意使用库,请使用underscore.js中的_.extend。否则,请将此代码添加到您的代码库中:

extend = function(obj) {
    each(slice.call(arguments, 1), function(source) {
      if (source) {
        for (var prop in source) {
          obj[prop] = source[prop];
        }
      }
    });
    return obj;
  };

答案 2 :(得分:0)

我看到你用jQuery标记了 - 如果你确实在使用jQuery,你可能会对使用$.extend感兴趣。

答案 3 :(得分:0)

看看这个:https://github.com/haroldiedema/joii

var BaseClass = function() 
{
    this.some_var = "foobar";

    /**
     * @return string
     */
    this.someMethod = function() {
        return this.some_var;
    }
};

var MyClass = new Class({ extends: BaseClass }, function()
{
    /**
     * @param string value
     */
    this.__construct = function(value)
    {
        this.some_var = value;
    }

})

用法:

var obj = new MyClass("Hello World!");
console.log( obj.someMethod() ); // Hello World!