从jQuery原型函数($ .fn)获取实例/引用

时间:2013-11-11 00:30:25

标签: jquery reference prototype instance custom-data-attribute

我写了一个使用原型的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();

但是,这并不总是有效。是否有另一种方法来获取引用(可能没有使用数据属性)?

1 个答案:

答案 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();
})