所以我一直在主动管理中玩acts_as_taggable_on
,并且在大多数情况下一切都如预期的那样工作。
然而,每当我搜索标签,并将现有的标签添加到模型中时,它似乎将其保存为ID,而不是名称。创建新标记将返回名称,并且当我再次编辑对象时,标记仍然使用名称标记。但是当我尝试添加另一个标签时,一个已经存在于数据库中,它返回表单中的名称,并且似乎保存OK,但是当我回到编辑对象时,标签再次显示为ID,而不是名称。
In admin/gift.rb
:
controller do
def autocomplete_gift_tags
@tags = ActsAsTaggableOn::Tag
.where("name LIKE ?", "#{params[:q]}%")
.order(:name)
respond_to do |format|
format.json { render json: @tags , only: [:id, :name], root: false }
end
end
end
In tag-autocomlete.js
:
$(document).ready(function() {
$('.tagselect').each(function() {
var placeholder = $(this).data('placeholder');
var url = $(this).data('url');
var saved = $(this).data('saved');
$(this).select2({
tags: true,
placeholder: placeholder,
minimumInputLength: 1,
initSelection: function(element, callback) {
saved && callback(saved);
},
ajax: {
url: url,
dataType: 'json',
data: function(term) {
return {
q: term
};
},
results: function(data) {
return {
results: data
};
}
},
createSearchChoice: function(term, data) {
if ($(data).filter(function() {
return this.name.localeCompare(term) === 0;
}).length === 0) {
return {
id: term,
name: term
};
}
},
formatResult: function(item, page) {
return item.name;
},
formatSelection: function(item, page) {
return item.name;
}
});
});
});
在我的_gift_form.html.erb
中:
<%= f.input :tag_list, label: "Tags", input_html: { data: { placeholder: "Enter tags", saved: f.object.tags.map{|t| {id: t.name, name: t.name}}.to_json, url: autocomplete_gift_tags_path }, class: 'tagselect' } %>
不知道为什么新的标签可以工作,而现有的标签不能。
改变这个:
respond_to do |format|
format.json { render json: @tags , only: [:id, :name], root: false }
end
:
respond_to do |format|
format.json { render :json => @tags.collect{|t| {:id => t.name, :name => t.name }}}
end