我写了一个使用原型的jQuery插件。
示例:
function MyWidgetConstructor(element) {
this.id = 'test';
this.$element = $(element);
this.$element.data('instance', this);
}
MyWidgetConstructor.prototype.sayHello = function() {
alert('Hello, my ID is: ' + this.id);
}
$.fn.myWidget= function() {
return this.each(function() {
new MyWidgetConstructor(this);
});
};
我使用data属性来保存对窗口小部件的引用。这样我可以用实例变量调用原型方法,如下所示:
jQuery('#myInstance').myWidget();
jQuery('#myInstance').data('instance').test();
但是,这并不总是有效。是否有另一种方法来获取引用(可能没有使用数据属性)?
答案 0 :(得分:3)
我找到了另一种方法!可以使用全局实例数组来管理不同的实例。
示例:强>
(function ($) {
window.InstanceCollection = window.InstanceCollection || {};
$.fn.myWidget = function () {
return this.each(function () {
new MyWidgetConstructor(this);
});
};
function MyWidgetConstructor(element) {
this.id = 'test';
window.InstanceCollection[this.id] = this;
}
MyWidgetConstructor.prototype.sayHello = function () {
alert('Hello, my ID is: ' + this.id);
}
})(jQuery)
jQuery(function ($) {
$('#myInstance').myWidget();
window.InstanceCollection['test'].sayHello();
})