プロジェクト

全般

プロフィール

ScaffoldPlusAnswerThree » 履歴 » バージョン 7

Yuumi Yoshida, 2008-01-13 18:00

1 1 Yuumi Yoshida
2 7 Yuumi Yoshida
h1. 演習3解答例
3
4
5
6
h2. 作業手順
7
8
<pre>
9 1 Yuumi Yoshida
ruby script/generate model user name:string user_id:integer
10 7 Yuumi Yoshida
ruby script/generate migration [[AddUserIdToTodo]] user_id:integer
11 1 Yuumi Yoshida
rake db:migrate
12 5 Yuumi Yoshida
ruby script/console      # usersデータの作成,todos.user_id更新
13 6 Yuumi Yoshida
  User.new(:id=>1, :name=>'山田')
14
  u.save
15
  u = User.new(:id=>2, :name=>'川田')
16 1 Yuumi Yoshida
  u.save
17
  Todo.update_all("user_id=1")
18
  User.find(:all)       # users の確認
19
  Todo.find(:all)      # todos の確認
20
  quit
21 7 Yuumi Yoshida
</pre>
22 1 Yuumi Yoshida
23
24 7 Yuumi Yoshida
h2. 変更点
25
26
27
28
h3. 1.  app/models/user.rb
29
30 1 Yuumi Yoshida
Todoとの一対多の関連を記述
31 7 Yuumi Yoshida
<pre>
32 1 Yuumi Yoshida
#!html
33 7 Yuumi Yoshida
<pre class="wiki">class User &lt; [[ActiveRecord]]::Base
34 1 Yuumi Yoshida
  <font color="red">has_many :todos</font>
35
end
36
</pre>
37 7 Yuumi Yoshida
</pre>
38 1 Yuumi Yoshida
39 7 Yuumi Yoshida
40
h3. 2.  app/models/todo.rb
41
42 1 Yuumi Yoshida
Userとの多対一の関連(従属)を記述
43 7 Yuumi Yoshida
<pre>
44 1 Yuumi Yoshida
#!html
45 7 Yuumi Yoshida
<pre class="wiki">class Todo &lt; [[ActiveRecord]]::Base
46 2 Yuumi Yoshida
  <font color="red">belongs_to :user</font>
47
end
48
</pre>
49 7 Yuumi Yoshida
</pre>
50 2 Yuumi Yoshida
51 7 Yuumi Yoshida
52
h3. 3. app/views/todos/index.html.erb
53
54 1 Yuumi Yoshida
user.nameカラム表示用のコードを追加
55 7 Yuumi Yoshida
<pre>
56 3 Yuumi Yoshida
#!html
57
<pre class="wiki">&lt;h1&gt;Listing todos&lt;/h1&gt;
58
59
&lt;table&gt;
60
  &lt;tr&gt;
61
    &lt;th&gt;Due&lt;/th&gt;
62 1 Yuumi Yoshida
    <font color="red">&lt;th&gt;Name&lt;/th&gt;</font>
63 3 Yuumi Yoshida
    &lt;th&gt;Task&lt;/th&gt;
64
  &lt;/tr&gt;
65 1 Yuumi Yoshida
66
&lt;%25 for todo in @todos %25&gt;
67
  &lt;tr&gt;
68
    &lt;td&gt;&lt;%25=h todo.due %25&gt;&lt;/td&gt;
69
    <font color="red">&lt;td&gt;&lt;%25=h todo.user.name %25&gt;&lt;/td&gt;</font>
70 3 Yuumi Yoshida
    &lt;td&gt;&lt;%25=h todo.task %25&gt;&lt;/td&gt;
71
    &lt;td&gt;&lt;%25= link_to 'Show', todo %25&gt;&lt;/td&gt;
72
    &lt;td&gt;&lt;%25= link_to 'Edit', edit_todo_path(todo) %25&gt;&lt;/td&gt;
73
    &lt;td&gt;&lt;%25= link_to 'Destroy', todo, :confirm =&gt; 'Are you sure?', :method =&gt; :delete %25&gt;&lt;/td&gt;
74
  &lt;/tr&gt;
75
&lt;%25 end %25&gt;
76
&lt;/table&gt;
77
78
&lt;br /&gt;
79 1 Yuumi Yoshida
80 3 Yuumi Yoshida
&lt;%25= link_to 'New todo', new_todo_path %25&gt;
81
</pre>
82 7 Yuumi Yoshida
</pre>
83 1 Yuumi Yoshida
84 7 Yuumi Yoshida
85
h3. 4. app/views/todos/show.html.erb
86
87 3 Yuumi Yoshida
user.nameカラム表示用のコードを追加
88 7 Yuumi Yoshida
<pre>
89 3 Yuumi Yoshida
#!html
90
<pre class="wiki">&lt;p&gt;
91 1 Yuumi Yoshida
  &lt;b&gt;Due:&lt;/b&gt;
92 3 Yuumi Yoshida
  &lt;%25=h @todo.due %25&gt;
93
&lt;/p&gt;
94 1 Yuumi Yoshida
95
&lt;p&gt;
96
  &lt;b&gt;Task:&lt;/b&gt;
97
  &lt;%25=h @todo.task %25&gt;
98
&lt;/p&gt;
99 3 Yuumi Yoshida
100
<font color="red">&lt;p&gt;
101 1 Yuumi Yoshida
  &lt;b&gt;Name:&lt;/b&gt;
102 3 Yuumi Yoshida
  &lt;%25=h @todo.user.name %25&gt;
103
&lt;/p&gt;</font>
104
105
&lt;p&gt;
106 1 Yuumi Yoshida
  &lt;b&gt;Memo:&lt;/b&gt;&lt;br/&gt;
107 3 Yuumi Yoshida
  &lt;%25=new_line(h(@todo.memo)) %25&gt;
108
&lt;/p&gt;
109
110
111 1 Yuumi Yoshida
&lt;%25= link_to 'Edit', edit_todo_path(@todo) %25&gt; |
112
&lt;%25= link_to 'Back', todos_path %25&gt;
113 3 Yuumi Yoshida
</pre>
114 7 Yuumi Yoshida
</pre>
115 3 Yuumi Yoshida
116 7 Yuumi Yoshida
117
h3. 5. app/views/todos/edit.html.erb
118
119 3 Yuumi Yoshida
user.name入力表示用のコードを追加
120 7 Yuumi Yoshida
<pre>
121 3 Yuumi Yoshida
#!html
122 1 Yuumi Yoshida
<pre class="wiki">&lt;h1&gt;Editing todo&lt;/h1&gt;
123 3 Yuumi Yoshida
124
&lt;%25= error_messages_for :todo %25&gt;
125
126
&lt;%25 form_for(@todo) do |f| %25&gt;
127
  &lt;p&gt;
128 1 Yuumi Yoshida
    &lt;b&gt;Due&lt;/b&gt;&lt;br /&gt;
129 3 Yuumi Yoshida
    &lt;%25= f.date_select :due %25&gt;
130
  &lt;/p&gt;
131
132 1 Yuumi Yoshida
  &lt;p&gt;
133
    &lt;b&gt;Task&lt;/b&gt;&lt;br /&gt;
134
    &lt;%25= f.text_field :task %25&gt;
135
  &lt;/p&gt;
136
137 3 Yuumi Yoshida
  <font color="red">&lt;p&gt;
138 1 Yuumi Yoshida
    &lt;b&gt;Name&lt;/b&gt;&lt;br /&gt;
139 3 Yuumi Yoshida
    &lt;%25= f.select :user_id, User.find(:all).collect {|u| [ u.name, u.id ] } %25&gt;
140
  &lt;/p&gt;</font>
141
142
  &lt;p&gt;
143 1 Yuumi Yoshida
    &lt;b&gt;Memo&lt;/b&gt;&lt;br /&gt;
144 3 Yuumi Yoshida
    &lt;%25= f.text_area :memo %25&gt;
145
  &lt;/p&gt;
146
147
  &lt;p&gt;
148 1 Yuumi Yoshida
    &lt;%25= f.submit "Update" %25&gt;
149 3 Yuumi Yoshida
  &lt;/p&gt;
150
&lt;%25 end %25&gt;
151
152 1 Yuumi Yoshida
&lt;%25= link_to 'Show', @todo %25&gt; |
153 3 Yuumi Yoshida
&lt;%25= link_to 'Back', todos_path %25&gt;
154
</pre>
155 7 Yuumi Yoshida
</pre>
156 1 Yuumi Yoshida
157 7 Yuumi Yoshida
158
h3. 6. app/views/todos/new.html.erb
159
160 3 Yuumi Yoshida
user.name入力表示用のコードを追加
161 7 Yuumi Yoshida
<pre>
162 1 Yuumi Yoshida
#!html
163 3 Yuumi Yoshida
<pre class="wiki">&lt;h1&gt;New todo&lt;/h1&gt;
164 1 Yuumi Yoshida
165 3 Yuumi Yoshida
&lt;%25= error_messages_for :todo %25&gt;
166
167
&lt;%25 form_for(@todo) do |f| %25&gt;
168
  &lt;p&gt;
169 1 Yuumi Yoshida
    &lt;b&gt;Due&lt;/b&gt;&lt;br /&gt;
170
    &lt;%25= f.date_select :due %25&gt;
171
  &lt;/p&gt;
172
173 3 Yuumi Yoshida
  &lt;p&gt;
174 1 Yuumi Yoshida
    &lt;b&gt;Task&lt;/b&gt;&lt;br /&gt;
175 3 Yuumi Yoshida
    &lt;%25= f.text_field :task %25&gt;
176
  &lt;/p&gt;
177
178
  <font color="red">&lt;p&gt;
179 1 Yuumi Yoshida
    &lt;b&gt;Name&lt;/b&gt;&lt;br /&gt;
180 3 Yuumi Yoshida
    &lt;%25= f.select :user_id, User.find(:all).collect {|u| [ u.name, u.id ] } %25&gt;
181
  &lt;/p&gt;</font>
182
183
   &lt;p&gt;
184 1 Yuumi Yoshida
    &lt;b&gt;Memo&lt;/b&gt;&lt;br /&gt;
185 3 Yuumi Yoshida
    &lt;%25= f.text_area :memo %25&gt;
186
  &lt;/p&gt;
187
188
 &lt;p&gt;
189 1 Yuumi Yoshida
    &lt;%25= f.submit "Create" %25&gt;
190 3 Yuumi Yoshida
  &lt;/p&gt;
191
&lt;%25 end %25&gt;
192
193
&lt;%25= link_to 'Back', todos_path %25&gt;
194 1 Yuumi Yoshida
</pre>
195 7 Yuumi Yoshida
</pre>
196 3 Yuumi Yoshida
197 7 Yuumi Yoshida
198
h2. ソースコード 
199
200 4 Yuumi Yoshida
201
 解答例のソースコードは http://www.ey-office.com/trac/rails/browser/tags/todo_q3で参照できます。