在rails中搜索带有标签的产品时无法找到Tag

时间:2017-04-24 11:26:12

标签: html ruby-on-rails

我的rails项目中的每个产品都有多个标签,我想通过标签搜索我的产品,我搜索时遇到以下错误:

ProductsController #index

中的ActiveRecord :: RecordNotFound

无法找到标记

我使用了标签模型来存储标签和标签模型来连接标签和产品表(具有多对多的关系)

PRODUCTS_CONTROLLER

class ProductsController < ApplicationController
  # before_action :authenticate_user!
  before_action :set_product, only: [:show, :edit, :update, :destroy]

  # GET /products
  # GET /products.json
  def index
     if params[:tag]
    @products = Product.tagged_with(params[:tag])
  else
    @products = Product.all
  end
  end

  # GET /products/1
  # GET /products/1.json
  def show
  end

  # GET /products/new
  def new
    @product = Product.new
  end

  # GET /products/1/edit
  def edit
  end

  # POST /products
  # POST /products.json
  def create
    @product = current_user.products.new(product_params)

    respond_to do |format|
      if @product.save
        format.html { redirect_to @product, notice: 'Product was successfully created.' }
        format.json { render :show, status: :created, location: @product }
      else
        format.html { render :new }
        format.json { render json: @product.errors, status: :unprocessable_entity }
      end
    end
  end

  # PATCH/PUT /products/1
  # PATCH/PUT /products/1.json
  def update
    respond_to do |format|
      if @product.update(product_params)
        format.html { redirect_to @product, notice: 'Product was successfully updated.' }
        format.json { render :show, status: :ok, location: @product }
      else
        format.html { render :edit }
        format.json { render json: @product.errors, status: :unprocessable_entity }
      end
    end
  end

  # DELETE /products/1
  # DELETE /products/1.json
  def destroy
    @product.destroy
    respond_to do |format|
      format.html { redirect_to products_url, notice: 'Product was successfully destroyed.' }
      format.json { head :no_content }
    end
  end

  private
    # Use callbacks to share common setup or constraints between actions.
    def set_product
      @product = Product.find(params[:id])
    end

    # Never trust parameters from the scary internet, only allow the white list through.
    def product_params
      params.require(:product).permit(:filetype, :title, :img_url, :description, :all_tags, :price, :uploaded_by, :tutorial_url)
    end
end

产品型号

class Product < ActiveRecord::Base
    belongs_to :user
    has_many :taggings, dependent: :destroy
    has_many :tags, through: :taggings
    has_many :comments, dependent: :destroy

    has_attached_file :img_url, styles: { large: "800x600>", medium: "320x200>", thumb: "100x80#" }, validate_media_type: false
    validates_attachment_content_type :img_url, :content_type => ["image/jpg", "image/jpeg", "image/png", "image/gif"]

    def self.tagged_with(name)
        Tag.find_by!(name: name).products
    end

    def all_tags=(names)
        # names="music, spotify"
        self.tags = names.split(',').map do |name|
            Tag.where(name: name).first_or_create!
        end
    end
    def all_tags
        tags.map(&:name).join(", ")
    end
end

标签模型

class Tag < ActiveRecord::Base
    has_many :taggings, dependent: :destroy
    has_many :products, through: :taggings
end

TAGGINGS MODEL

class Tagging < ActiveRecord::Base
  belongs_to :product
  belongs_to :tag
end

这就是我搜索标签的方式

<div id="search-bar">
<%= form_tag products_path, :action=>"index", :method=>"get" do %>
<%= text_field_tag :tag, params[:tag], :name=>"tag", :placeholder=>"   Search Anything", :id=>"s-bar" %>
<%= submit_tag "Search",:name=>"tag", :value=>"search", :style=>"width: 100px; border: none; background: #eee; font-size: 25px; position: relative; top: 5px; display: none;"%>
<%end%>
</div>

1 个答案:

答案 0 :(得分:0)

在您的产品型号中

def self.tagged_with(name)
 tags = Tag.where('LOWER(name) like ?', "#{name.downcase}")
 products = []
 tags.each do |tag|
  products << tag.products
 end
 return products
end

这将返回一系列产品,其标签与文本框中搜索的标签类似。