请求

时间:2018-02-24 15:46:40

标签: ruby-on-rails activerecord controller ruby-on-rails-5.1

对于我的生活,我无法弄清楚为什么我的控制器没有进行SQL调用然后将其传递给视图。

在我的应用程序的每个其他部分,包括同一个控制器中的其他方法,不用担心。但无论出于何种原因,我都无法做到这一点。

应用/控制器/ referrals_controller.rb

class ReferralsController < ApplicationController

    def index # <- This works fine. 
        @referrals = Referral.all
        @referral = Referral.first 
        @reminder = Reminder.first 
        respond_to(:js, :html)
    end 

    def category_path # <- This doesn't work
        @referrals = Referral.where(:category => :option)
        @referral = @referrals.first 
        respond_to :js 
    end 

    def fetch_content # <- This works fine. 
        @referral = Referral.find(params[:follow_id])
        respond_to :js 
    end 
    ...
end 

配置/ routes.rb中

Rails.application.routes.draw do
  ...
  resources :referrals

  get '/referrals' => 'referrals#index'
  get '/category_path' => 'referrals#category_path', as: 'category'
  get '/fetch_content' => 'referrals#fetch_content', as: 'fetch_content'
end 

以下是我视图中调用这些路径的部分。

应用/视图/下线/ index.html.erb

<%= link_to 'Immigration Referral', category_path(:option => 'Immigration Referral'), remote: true, class: 'category-links' %> - 
...
<%= link_to referral.title, fetch_content_path(:follow_id => referral.id), remote: true %>

尽管category_pathfetch_content的设置几乎相同,fetch_content工作正常,category_path甚至不进行SQL查询。我使用fetch_content的日志显示

Started GET "/fetch_content?follow_id=1" for 127.0.0.1 at 2018-02-24 09:22:16 -0600
Processing by ReferralsController#fetch_content as JS
  Parameters: {"follow_id"=>"1"}
  User Load (0.3ms)  SELECT  "users".* FROM "users" WHERE "users"."id" = $1 LIMIT $2  [["id", 1], ["LIMIT", 1]]
  Referral Load (0.3ms)  SELECT  "referrals".* FROM "referrals" WHERE "referrals"."id" = $1 LIMIT $2  [["id", 1], ["LIMIT", 1]]
  Rendering referrals/fetch_content.js.erb
  Rendered referrals/_content.html.erb (0.3ms)
  Rendered referrals/fetch_content.js.erb (2.6ms)
Completed 200 OK in 19ms (Views: 14.9ms | ActiveRecord: 0.5ms)

然而,当我使用category_path时,结果如下:

Started GET "/category_path?option=Immigration+Referral" for 127.0.0.1 at 2018-02-24 09:22:22 -0600
Processing by ReferralsController#category_path as JS
  Parameters: {"option"=>"Immigration Referral"}
  User Load (0.2ms)  SELECT  "users".* FROM "users" WHERE "users"."id" = $1 LIMIT $2  [["id", 1], ["LIMIT", 1]]
  Rendering referrals/category_path.js.erb
  Rendered referrals/_titles.html.erb (0.7ms)
  Rendered referrals/_content.html.erb (0.4ms)
  Rendered referrals/category_path.js.erb (32.6ms)
Completed 200 OK in 80ms (Views: 62.1ms | ActiveRecord: 0.2ms)

在我看来@referrals.nil?正在返回true,如果它没有进行SQL调用,我会期待它。我的问题是,为什么?!为什么我的控制器没有进行SQL调用。我甚至尝试更改为更简单的内容,如@referrals = Referral.all,但仍然不会触发SQL调用。发生了什么?

1 个答案:

答案 0 :(得分:1)

似乎后缀&#34;路径&#34;对于控制器内的任何操作都不是有效的,可能是因为它应该与Rails管理的路由冲突,如@apneadiving所指出的那样。

如果您使用后缀路径设置操作,并尝试列出该控制器的操作方法,您将看到该操作不存在:

class ReferralsController < ApplicationController
  ...

  def category_path # <- This doesn't work
    ...
  end 

  def fetch_content_path # <- This works fine. 
    ...
  end 
end

控制器有两个以*_path结束的操作。现在要求你采取行动方法:

ReferralsController.action_methods
=> #<Set: {"new", "index", "update", "create", "edit", "destroy", "show"}>

如果删除最后一个&#34; h&#34;会发生什么?动作名称中的字符?:

ReferralsController.action_methods
=> #<Set: {"new", "index", "update", "create", "edit", "destroy", "show", "category_pat"}>

此处显示操作,这就是为什么可以达到fetch_content操作而类别1没有的原因。解决方案就是重命名操作方法。