要求 js 初始化不要被调用
require js init do not get called
我根据 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定义从一个简单的html运行代码
<script data-main='script/popup.js' src="script/require.js" ></script>
但它从未运行我的构造函数,即 init 方法
我的所有文件都在脚本文件夹中,因此我没有定义任何路径配置。代码命中类.js和弹出窗口.js但它永远不会转到 init 方法。
Popup 不是一个对象,而是一个函数,用于获取新的对象调用:
var p = new popup();
Class.extend 返回一个新的构造函数,而不是一个实例化的对象。
PS:之前
Class.extend = function(prop) {
加
this.Class = function() {};
否则,类是未定义的。
相关文章:
- 如何从Java/scala调用js美化程序
- 是否可以在使用headerphp函数后自动调用JS函数
- 全局窗口热键在最小化chrome窗口时调用js函数
- 当用户点击动态创建的链接时,如何调用JS方法.JQuery,ASP.NET MVC
- 从PHP调用JS函数不起作用
- 如何从构造函数中调用js原型方法
- 从加载的页面调用js页面
- 在shtml中调用js函数
- 当调用JS函数具有alert()时,应用程序将被冻结
- 无法从onclick事件调用JS函数
- 如何在自动完成更新时调用JS函数
- 在单击浏览器选项卡上调用 js 函数
- 从 PHP 文件调用 js 函数
- 尝试在 PHP 代码中调用 js 函数
- 同时调用js函数yui
- 提交按钮的点击元素不调用JS函数
- 使用onclick和javascript函数,在参数中调用js-var
- 在另一个.js文件中调用js函数
- 使用grunt在angular指令中调用js文件
- 在JS文件中设置延迟以调用JS文件