我有一个标记插件,我正在重构它。
我一直在传递我每次构造的对象,所以,我现在有一个函数,我传递值并返回对象。这工作正常,除了现在我需要访问插件中的一个变量。
如果您查看底部,您会在里面看到_addTag
我调用了this.tag
并且我想将元素的数量存储在其中,tagArray
但我的调用this
不会调用小部件。
(function ($) {
$.widget("ui.tagit", {
// default options
options:{},
//initialization function
_create:function () {
var self = this;
this.tagsArray = [];
...
...
this._addTag('label', 'value');
}
},
_addTag:function (label, value) {
...
//THIS IS WHERE THE TAG OBJECT IS CREATED
var tag = new this.tag(label, (value === undefined ? label : value));
tag.element = $('<li class="tagit-choice"'
+ (value !== undefined ? ' tagValue="' + value + '"' : '')
+ '>' + label + '<a class="tagit-close">x</a></li>');
...
},
tag: function (label, value, element) {
var self = this;
return {
label:label,
value:value,
element:element,
index: self.tagsArray.length
}
}
});
})(jQuery);
改为this
:
$.widget.tag
__proto__: Object
constructor: function (label, value, element) {
__proto__: Object