私はタグ付けプラグインを持っています。jquery UIインスタンスを破棄する
プラグインは、ajax経由で生成されたフォームの要素で使用されています。
すぐフォームが(AJAXによって)送信されたとき
...
success : function(data) {
$.lightbox(data);
$('#groups').tagit();
}
...
ようなライトボックスが除去され、従ってので形態です。
しかし、
私は、プラグインが#groupsは今、完全に新しいDOM要素であっても、その前の状態にある新しいフォームを作成するために、ボタンをクリックした場合。
これはなぜですか、どのように修正できますか?
が(同じ状態にすることにより、私は平均)
Iは変数を持っているプラグイン
_vars : {tags: []}
あり、これはタグとして取り込まれます追加されます。 新しい#groupsでプラグインを再度呼び出すと、tags変数には前のインスタンスのすべてのタグが含まれます。
どうすればこの問題を解決できますか?
あなたは
success : function(data) {
$.lightbox(data);
$('#groups').tagit("destroy").tagit();
}
は、あなたのクラスであなたの必要性のための
destroy: function() {
$.Widget.prototype.destroy.apply(this, arguments); // default destroy
// now do other stuff particular to this widget
}
を破壊メソッドをオーバーライドすることを忘れてはいけない次の操作を行うことができ、コード
$.widget("ui.tagit", {
// default options
options: {
tagSource: [],
allowSpace: true,
initialTags: [],
minLength: 1
},
//private variables
_vars: {
lastKey: null,
element: null,
input: null,
tags: []
},
_keys: {
backspace: 8,
enter: 13,
space: 32,
comma: 44
},
//initialization function
_create: function() {
var instance = this;
//store reference to the ul
this._vars.element = this.element;
//add class "tagit" for theming
this._vars.element.addClass("tagit");
//add any initial tags added through html to the array
this._vars.element.children('li').each(function() {
instance.options.initialTags.push($(this).text());
});
//add the html input
this._vars.element.html('<li class="tagit-new"><input class="tagit-input" type="text" /></li>');
this._vars.input = this._vars.element.find(".tagit-input");
//setup click handler
$(this._vars.element).click(function(e) {
if (e.target.tagName == 'A') {
// Removes a tag when the little 'x' is clicked.
$(e.target).parent().remove();
instance._popTag();
}
else {
instance._vars.input.focus();
}
});
//setup autcomplete handler
this.options.appendTo = this._vars.element;
this.options.source = this.options.tagSource;
this.options.select = function(event, ui) {
instance._addTag(ui.item.value, ui.item.id);
return false;
}
this._vars.input.autocomplete(this.options);
//setup keydown handler
this._vars.input.keydown(function(event) {
var lastLi = instance._vars.element.children(".tagit-choice:last");
if (event.which == instance._keys.backspace)
return instance._backspace(lastLi);
if (lastLi.hasClass('selected'))
lastLi.removeClass('selected');
// Comma/Space/Enter are all valid delimiters for new tags.
else if (event.which == instance._keys.comma || (event.which == instance._keys.space && !instance.options.allowSpace) || event.which == instance._keys.enter) {
event.preventDefault();
instance._addTag(this.value, 0);
}
instance._vars.lastKey = event.which;
})
//define missing trim function for strings
String.prototype.trim = function() {
return this.replace(/^\s+|\s+$/g, "");
};
this._initialTags();
},
_popTag: function() {
return this._vars.tags.pop();
},
_addTag: function(value, id) {
id = (id == null ? 0 : id);
this._vars.input.val("");
value = value.replace(/,+$/, "");
value = value.trim();
if (value == "" || this._exists(value))
return false;
var tag = "";
tag = '<li class="tagit-choice">' + value + '<a class="tagit-close">x</a></li>';
$(tag).insertBefore(this._vars.input.parent());
this._vars.input.val("");
this._vars.tags.push({id: id, value: value});
},
_exists: function(value) {
if (this._vars.tags.length == 0)
return false;
for (var i = 0; i <= this._vars.tags.length-1; i++)
if (this._vars.tags[i].value == value)
return true;
return false;
}
,
_oc: function(array) {
var object = {};
for (var i = 0; i < array.length; i++) {
object[array[i]] = '';
}
return object;
}
,
_backspace: function(li) {
if (this._vars.input.val() == "") {
// When backspace is pressed, the last tag is deleted.
if (this._vars.lastKey == this._keys.backspace) {
$(this)._tagger('remove');
li.remove();
this._vars.lastKey = null;
} else {
li.addClass('selected');
this._vars.lastKey = this._keys.backspace;
}
}
return true;
}
,
_initialTags: function() {
if (this.options.initialTags.length != 0) {
for (var i in this.options.initialTags)
if (!this._exists(this.options.initialTags[i]))
this._addTag(this.options.initialTags[i]);
}
}
,
tags: function() {
return this._vars.tags;
}
})
;
オーバーライドされたメソッドで何をする必要がありますか? – Hailwood
私の更新を見てください – Luke
@ルーク - 私はこの単純なプラグインの "破壊"を追加しようとしています:http://stackoverflow.com/questions/14940100/simple-jquery-draggable-implemention-without-jquery-ui-howターンオフすると、ここではどのように動作しますか? – user961627