Использование jquery tokeninput и acts_as_taggable_on - PullRequest
3 голосов
/ 21 ноября 2011

Я реализовал структуру, описанную в этом посте: Как использовать jquery-Tokeninput и 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в форме [примечание: идентификатор элемента назначается динамически]:

<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>

1 Ответ

3 голосов
/ 09 декабря 2011

Если вы все еще хотите использовать Jquery TokenInput и добавлять теги, есть разные способы сделать это.

1.Это на самом деле из моего же вопроса;самый новый ответ: Как использовать jquery-Tokeninput и Acts-as-taggable-on

Это может пойти в вашем контроллере.

 def tags
    query = params[:q]
    if query[-1,1] == " "
      query = query.gsub(" ", "")
      Tag.find_or_create_by_name(query)
    end

    #Do the search in memory for better performance

    @tags = ActsAsTaggableOn::Tag.all
    @tags = @tags.select { |v| v.name =~ /#{query}/i }
    respond_to do |format|
      format.json{ render :json => @tags.map(&:attributes) }
    end
  end

This will create the tag, whenever the space bar is hit.

You could then add this search setting in the jquery script:

noResultsText: 'No result, hit space to create a new tag',

It's a little dirty but it works for me.

2,Проверьте метод этого парня: https://github.com/vdepizzol/jquery-tokeninput

Он сделал специальную способность входа:

$(function() {
  $("#book_author_tokens").tokenInput("/authors.json", {
    crossDomain: false,
    prePopulate: $("#book_author_tokens").data("pre"),
    theme: "facebook",
    allowCustomEntry: true
  });
});

3.Не уверен насчет этого, но это может помочь: Rails: Использование jquery tokeninput (railscast # 258) для создания новых записей


4.Это тоже кажется вполне законным: https://github.com/loopj/jquery-tokeninput/pull/219

Мне лично нравится первый, кажется, что его проще всего найти и установить.

...