要求js init不要被调用

时间:2013-11-05 09:32:11

标签: javascript class requirejs

我根据john resig关于在javascript中使用类的想法来定义一个类。

define('class', function() {

    var initializing = false, fnTest = /xyz/.test(function(){xyz;}) ? /\b_super\b/ : /.*/;
    Class.extend = function(prop) {
        var _super = this.prototype;
        initializing = true;
        var prototype = new this();
        initializing = false;
        for (var name in prop) {
            prototype[name] = typeof prop[name] == "function" &&
                typeof _super[name] == "function" && fnTest.test(prop[name]) ?
                (function(name, fn){
                    return function() {
                        var tmp = this._super;
                        this._super = _super[name];
                        var ret = fn.apply(this, arguments);
                        this._super = tmp;
                        return ret;
                    };
                })(name, prop[name]) :
                prop[name];
        }
        function Class() {
            this.self = this;
            if ( !initializing && this.init )
                this.init.apply(this, arguments);
        }
        Class.prototype = prototype;

        Class.constructor = Class;
        Class.extend = arguments.callee;
        return Class;
    };
    return Class;
   });

然后我尝试在我的requirejs文件中使用它,如下所示

define('popup',['class'],
    function (Class) {

        var popup = Class.extend({

            init: function () {
                console.log('init');
            }

        });
     return popup;
    });

我根据requirejs definition

从简单的html运行代码
<script data-main='script/popup.js' src="script/require.js" ></script>

但它永远不会运行我的构造函数,即init方法

我的所有文件都在脚本文件夹中,因此我没有定义任何路径配置。 代码命中class.js和popup.js但它永远不会转到init方法。

1 个答案:

答案 0 :(得分:0)

Popup不是一个对象,而是一个函数,用于获取新的对象调用:

var p = new popup();

Class.extend返回一个新的构造函数而不是实例化的对象。

ps:之前

Class.extend = function(prop) {

添加

this.Class = function() {};

否则Class未定义。