リファクタリングしているタグ付けプラグインがあります。
毎回作成するオブジェクトを渡し続けるので、代わりに値を渡す関数があり、オブジェクトを返します。プラグインの変数の1つにアクセスする必要がある場合を除いて、これは正常に機能します。
下部を見ると、内部が表示されます。_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