プロジェクト

全般

プロフィール

ScaffoldPlusAnswerTwo » 履歴 » バージョン 4

Yuumi Yoshida, 2008-01-13 11:41

1 1 Yuumi Yoshida
= 演習2解答例 =
2
3 4 Yuumi Yoshida
== 作業手順 ==
4
{{{
5
script/generate migration AddMemoToTodo memo:text
6
rake db:migrate
7
}}}
8
9 1 Yuumi Yoshida
== 変更点 ==
10
11 3 Yuumi Yoshida
=== 1. helpers/todos_helper.rb ===
12
改行を<br/>タグに変換する new_lineメッソドを追加
13
{{{
14
#!ruby
15
  def new_line(s)
16
    s.gsub(/\n/, "<br />")
17
  end
18
}}}
19 1 Yuumi Yoshida
20 3 Yuumi Yoshida
=== 2. app/views/todos/show.html.erb ===
21
22 1 Yuumi Yoshida
memoカラム表示用の
23
{{{
24
<p>
25
  <b>Memo:</b><br/>
26
  <%25=new_line(h(@todo.memo)) %25>
27
</p>
28
}}}
29
のコードを追加、全体では以下のようになります。
30
{{{
31
<p>
32
  <b>Due:</b>
33
  <%25=h @todo.due %25>
34
</p>
35
36
<p>
37
  <b>Task:</b>
38
  <%25=h @todo.task %25>
39
</p>
40
41
<p>
42
  <b>Name:</b>
43
  <%25=h @todo.user.name %25>
44
</p>
45
46
<p>
47
  <b>Memo:</b><br/>
48
  <%25=new_line(h(@todo.memo)) %25>
49
</p>
50
51
52
<%25= link_to 'Edit', edit_todo_path(@todo) %25> |
53 2 Yuumi Yoshida
<%25= link_to 'Back', todos_path %25>
54 1 Yuumi Yoshida
}}}
55 2 Yuumi Yoshida
56 3 Yuumi Yoshida
=== 3. app/views/todos/edit.html.erb ===
57 2 Yuumi Yoshida
58
memoカラム入力用の
59
{{{
60
  <p>
61
    <b>Memo</b><br />
62
    <%25= f.text_area :memo %25>
63
  </p>
64
}}}
65
のコードを追加、全体では以下のようになります。
66
{{{
67
<h1>Editing todo</h1>
68
69
<%25= error_messages_for :todo %25>
70
71
<%25 form_for(@todo) do |f| %25>
72
  <p>
73
    <b>Due</b><br />
74
    <%25= f.date_select :due %25>
75
  </p>
76
77
  <p>
78
    <b>Task</b><br />
79
    <%25= f.text_field :task %25>
80
  </p>
81
82
  <p>
83
    <b>Name</b><br />
84
    <%25= f.select :user_id, User.find(:all).collect {|u| [ u.name, u.id ] } %25>
85
  </p>
86
87
  <p>
88
    <b>Memo</b><br />
89
    <%25= f.text_area :memo %25>
90
  </p>
91
92
  <p>
93
    <%25= f.submit "Update" %25>
94
  </p>
95
<%25 end %25>
96
97
<%25= link_to 'Show', @todo %25> |
98 1 Yuumi Yoshida
<%25= link_to 'Back', todos_path %25>
99 2 Yuumi Yoshida
}}}
100
101 3 Yuumi Yoshida
=== 4. app/views/todos/new.html.erb ===
102 2 Yuumi Yoshida
103
memoカラム入力用の
104
{{{
105
  <p>
106
    <b>Memo</b><br />
107
    <%25= f.text_area :memo %25>
108
  </p>
109
}}}
110
のコードを追加、全体では以下のようになります。
111
{{{
112
<h1>New todo</h1>
113
114
<%25= error_messages_for :todo %25>
115
116
<%25 form_for(@todo) do |f| %25>
117
  <p>
118
    <b>Due</b><br />
119
    <%25= f.date_select :due %25>
120
  </p>
121
122
  <p>
123
    <b>Task</b><br />
124
    <%25= f.text_field :task %25>
125
  </p>
126
127
  <p>
128
    <b>Memo</b><br />
129
    <%25= f.text_area :memo %25>
130
  </p>
131
132
  <p>
133
    <%25= f.submit "Create" %25>
134
  </p>
135
<%25 end %25>
136
137
<%25= link_to 'Back', todos_path %25>                                                                                          
138 1 Yuumi Yoshida
}}}
139
140
141
== ソースコード  ==
142
143
 解答例のソースコードは http://www.ey-office.com/trac/rails/browser/tags/todo_q2で参照できます。