我已经实现了这篇文章中概述的框架:How to use jquery-Tokeninput and Acts-as-taggable-on有一些困难。就预先填充适当的主题和 ajax 搜索而言,这是有效的,但是当我输入一个新标签时,它会在文本区域失去焦点时立即被删除。我不确定我做错了什么。这是我的一些相关代码:
用户模型(做标记):
class User < ActiveRecord::Base
[...]
# tagging
acts_as_tagger
商品型号(接受标签):
class Item < ActiveRecord::Base
attr_accessible :title, :tag_list
#tagging functionality
acts_as_taggable_on :tags
物品控制器:
def tags
@tags = ActsAsTaggableOn::Tag.where("tags.name LIKE ?", "%#{params[:q]}%")
respond_to do |format|
format.json { render :json => @tags.collect{|t| {:id => t.name, :name => t.name }}}
end
end
在我的部分表格上:
<%= f.input :tag_list, :label => "Tags", :input_html => { :class => "text_field short", "data-pre" => @item.tags.map(&:attributes).to_json }, :hint => "separate tags by a space" %>
我的路线:
get "items/tags" => "items#tags", :as => :tags
resources :items
[差不多好了!!!]
表单上的 js [注意:元素的 id 是动态分配的]:
<script type="text/javascript">
$(function() {
$("#item_tag_list").tokenInput("/art_items/tags", {
prePopulate: $("#item_tag_list").data("pre"),
preventDuplicates: true,
crossDomain: false,
theme: "facebook"
});
});
</script>