1

我希望帮助解决问题。我已经从这里安装 gem rails3-jquery-autocomplete

和 gem "acts-as-taggable-on" 从这里

这是我的历史:

我的模型是

class Article <ActiveRecord::Base
       acts_as_taggable_on :tags
       attr_accessible :title, :body, :tag_list

我的控制器是

class ArticlesController < ApplicationController
     autocomplete :tag, :name, :class_name => 'ActAsTaggableOn::Tag'
     def tag_cloud
            @tags ||=Article.tag_counts_on(:tags)
     end
     def all
        @tags = Article.tag_counts_on(:tags).limit(8).order('count desc')
        klass = Article
        klass = klass.tagged_with(@tag) if (@tag = params[:tag]).present?
        @articles = klass.where(:state => '4').paginate(:page => params[:page])
        respond_to do |format|
            format.html  # index.html.erb
            format.xml  { render :xml => @articles }
        end
    end

我的路线是

resources :articles do
    collection do
    get 'autocomplete_tag_name' 
    get 'about'
    get 'all'
    get 'myarticles'
    delete 'destroy'
            end
end

我的 _form.html.erb

<div class="field">
           <label for="tag_list">Κατηγορία (Μπορείτε να προσθέσετε διαφορετικές κατηγορίες διαχωρίζοντάς τες με κόμμα)</label><br />
           <%= f.autocomplete_field :tag_list, autocomplete_tag_name_articles_path, :"data-delimiter" => ', ' %>
</div>

我的 index.html.erb

<div class='tag-box'>
          <% @tags.sort_by(&:count).reverse.each do |k| %>
                    <% url_opts = {:action => "all", :controller => "articles"}
                    link_name = "#{k.name} (#{k.count})" %>
                    <% if @tag == k.name %>
                             <%= link_to link_name, url_opts.merge(:tag => nil), :class => "tag current_tag", :title => "Κλικ για εμφάνιση όλων" %>
                    <% else %>
                             <%= link_to link_name,  url_opts.merge(:tag => k.name), :class => "tag", :title => "Κλικ για εμφάνιση άρθρων στην κατηγορία #{k.name}" %>
                    <% end %>
          <% end %>
</div>

我的 application.html.erb

<%= stylesheet_link_tag :all %>
<%= javascript_include_tag :defaults %>
<%= javascript_include_tag 'jquery-1.7.2.min.js', 'jquery-ui-1.8.19.custom.min.js', 'autocomplete-rails.js', 'rails.js'  %>
<%= stylesheet_link_tag 'jquery-ui-1.8.19.custom.css' %>

最后我的 Gemfile

gem 'rails', '3.0.11'
gem 'pg'
gem 'jquery-rails', '>= 1.0.12'
gem 'rails3-jquery-autocomplete'
gem 'acts-as-taggable-on', '~> 2.2.2'

在应用程序中可以使用标记系统,但不能使用自动完成功能。

也许我的问题出在文件 _form.html.erb 上。我在文件 new.html.erb 上有代码

<section id="myarticles">
     <h2>Νέο άρθρο</h2>
      <%= render 'form' %>
</section>

是关于一起渲染和自动完成而自动完成不起作用吗?

4

1 回答 1

3

最后,我的问题的解决方案可以帮助遇到同样情况的人,这很简单。从jQuery UI-Autocomplete的下载主题中复制文件 jquery-ui-1.8.19.custom.csspublic/stylesheets/ui-lightness或从依赖项中复制public/stylesheets/smoothness

并粘贴到 public/stylesheets/ 并自动消失路由错误并瞧瞧自动完成功能。

我已按照此处的说明进行操作

将 css 文件夹中的文件复制到应用程序的 public/stylesheets 文件夹中。请注意,这些文件可能位于 css 文件夹的下一层,位于名为“ui-lightness”的文件夹中。

但正确的位置在目录 public/stylesheets 上。还从 mycontroller 中删除以下代码:class_name => 'ActAsTaggableOn::Tag',现在代码看起来像

class ArticlesController < ApplicationController
          autocomplete :tag, :name
于 2012-05-03T17:31:11.923 回答