Rails 4 - 如何在使用collection_select后在索引视图中显示记录名而不是其id

时间:2016-03-03 10:38:57

标签: ruby-on-rails collection-select

我有两个模型,SubjectCourseCourse属于_ SubjectSubject has_many Courses。在创建新课程时,我使用collection_select来获取数据库中的所有主题,以便我可以选择课程所属的主题。这工作正常,但是我在index.html页面中显示subject.name时遇到问题,而我只能显示其id。我试过做<%= course.subject.name%>这给了我一个错误:nil的未定义方法`name':NilClass。如何在课程视图页面中显示subject.name?

这是我的代码:

当然_form:

  <div class="field">
    <%= f.label "Subject" %>
    <%= collection_select :course, :subject_id, Subject.all, :id, :name %>
  </div>

的index.html:

<div class="courses">
  <div class="semesters">
    <h3>Courses</h3>
    <% @grade.courses.each do |course| %>
    <div class="course_group">
      <div class="course_list">
        <h3><%= course.subject.name %></h3>
        <p><%= course.title %></p>
        <%= link_to "View Course", [@grade, course], :class => "button button_orange" %>
        <div class="course_links">
        <% if can? :update, @course %>
          <%= link_to 'Edit', edit_grade_course_path(@grade, course) %> |
        <% end %>
        <% if can? :destroy, @course %>
          <%= link_to 'Destroy', [@grade, course], method: :delete, data: { confirm: 'Are you sure?' } %>
        <% end %>
        </div>
      </div>
      </div>
    <% end %>
  </div>
  <div class="create_course">
    <% if can? :create, @course %>
    <%= link_to 'Add New Course', new_grade_course_path(@grade, @course), :class => "button button_orange" %>
    <% end %>
  </div>
</div>

courses_controller.rb:

class CoursesController < ApplicationController
  before_action :set_course, only: [:show, :edit, :update, :destroy]
  before_action :set_grade
  load_and_authorize_resource
  respond_to :html

  def index
   @grade = Grade.find(params[:grade_id])
   @subjects = Subject.all
   @courses = @grade.courses.all
   # respond_with(@course)
  end
.
.
.
  def course_params
      params.require(:course).permit(:title, :period, :description, :semester, :grade, :grade_id, :video_url, :chapter_id, :subject_id)
  end
end

course.rb:

class Course < ActiveRecord::Base
    # TODO: add validations
    resourcify
    belongs_to :grade
    has_many :chapters
    has_many :packages
    belongs_to :subject
end

subject.rb中:

class Subject < ActiveRecord::Base
    has_many :courses
end

2 个答案:

答案 0 :(得分:1)

试试这段代码

<%= course.subject.name if course.subject and course.subject.name %>

由于我们正在研究关系数据库,在从关系中获取数据时我们首先需要检查与该表的关系是否存在,还需要检查该关系表中的字段是否为空/空。 您也可以使用try方法。

结帐链接

http://www.rubydoc.info/docs/rails/Object%3Atry

答案 1 :(得分:1)

我会说要进行验证而不是检查每个列的存在;这简直是​​多余的。

class Subject < ActiveRecord::Base
  validates :name, presence: true
end

这样,在具有名称之前,主题无法保存在数据库中,然后在您的视图中,您无需检查是否存在name字段。

或者,如果你想进行存在检查,Rails也提供了一种方法。方法如下:

course.try(:subject).try(:name) # this code won't crash even if the `name` or `subject` is `nil`.