1

各位,能不能帮我解答一下这个问题。

var Module = function ( options ) {
var settings = {
    selector: 'body',
    declaration: function () {
        return{
            init: function () {
                console.log( 'nodule initialize' );
            },
            destroy: function () {
                console.log( ' module destroyed' );
            }
        }
     }
   };
this.declaration = options.declaration || settings.declaration;
this.selector = options.selector || settings.selector;
};

var Registration = function ( options ) {
   this.selector = options.selector || **strong text**;
   this.declaration = options.declaration
}
app.utils.extend( Module, Registration );
var m_registration = new Registration( {
   declaration: function ( f ) {
      return {
        init: function () {
        },
        destroy: function () {
        }
    }
  }
} );

我的主要问题是,如果我们在创建注册实例时不需要传递数量参数,我如何继承m_registration中的 Module.selector 属性

我的函数app.utils.extend()的实现:

var app.utils.extend = function ( from, to ) {
        var F = function () {
        };
        F.prototype = from.prototype;
        to.prototype = new F();
        to.prototype.constructor = to;
        to.superclass = from.prototype;
    }

更新

如果我们使用这些方法:

var Registration = function ( options ) {
       Module.call(this, { selector : options.selector });
       this.declaration = options.declaration
}

如果我们真的不知道这个类从哪个实例扩展或继承,我们如何使用继承。

4

2 回答 2

1
var Registration = function ( options ) {
   Module.call(this, { selector : options.selector || **strong text**});
   this.declaration = options.declaration
}

我不知道**strong text**你的情况是什么意思。但是如果你这样称呼它

var Registration = function ( options ) {
       Module.call(this, { selector : options.selector });
       this.declaration = options.declaration
    }

或者

var Registration = function ( options ) {
       Module.call(this, options );
       this.declaration = options.declaration
    }

在你的情况m_registration.selector'body'

于 2013-06-15T11:14:11.740 回答
1
var Module = function ( options ) {
    this.declaration = options.declaration;
    this.selector = options.selector;
}

Module.prototype = {
    selector: 'body',
    declaration: function () {
        return{
            init: function () {
                console.log( 'nodule initialize' );
            },
            destroy: function () {
                console.log( ' module destroyed' );
            }
        }
     }
   };

另一种方法是将要继承的所有属性放到prototype属性中。这就是javascript引擎处理继承的方式

于 2013-06-15T11:28:27.607 回答