我想开发一个应用程序。 每个用户都创建自己的日程安排。
我希望将数据显示如下;
schedule title (user name)
day1(mm/dd,yyyy)
09:00 Math
11:00 Science
Room name A
day2(mm/dd,yyyy)
10:00 Physics
13:00 Music
Room name B
虽然我可以显示日程标题和用户名,但我无法显示日期(mm / dd,yyyy)和房间名称。 (我还没有为课程名称和时间制作模型)
如果你能给我任何建议,我将不胜感激。
user.rb
class User < ActiveRecord::Base
has_many :schedlues
...
schedule.rb
class Schedule < ActiveRecord::Base
belongs_to :user
has_many :rooms
...
room.rb
class Room < ActiveRecord::Base
belongs_to :schedlue
模式
create_table "users", force: :cascade do |t|
t.string "name"
t.string "email"
...
end
create_table "schedules", force: :cascade do |t|
t.string "title"
t.integer "user_id"
...
end
create_table "rooms", force: :cascade do |t|
t.date "date"
t.string "room_name"
t.integer "schedule_id"
...
end
我还没有为课程名称建立一个时间模型。
users_controller.rb
class UsersController < ApplicationController
def show
@user = User.find(params[:id])
@schedules = @user.schedules.paginate(page: params[:page])
end
...
show.html.erb
<% if @user.schedules.any? %>
<ol class="schedules">
<%= render @schedules %>
</ol>
<%= will_paginate @schedules %>
<% end %>
_schedule.html.erb
<li>
<span class="content"><%= schedule.title %>(<%= schedule.user.name %>)</span>
#Although I tried to display date and room name here, I couldn't.
</li>
答案 0 :(得分:1)
您需要在此处使用has_many
+ through
关系。
请参阅用户has_many
时间表,并且一个时间表包含许多会议室。所以间接地也是用户has_many
个房间。你必须在User
模型中编写以下代码行:
class User < ActiveRecord::Base
has_many :schedules
has_many :rooms, through: :schedules
end
现在,您可以直接在用户对象上调用rooms
,如下所示:
user = User.last
user.rooms.each do |room|
puts room.room_name # calling it simply `name` would be more appropriate.
end