ScaffoldPlusAnswerTwo » 履歴 » リビジョン 7
リビジョン 6 (Yuumi Yoshida, 2008-01-13 14:16) → リビジョン 7/20 (Yuumi Yoshida, 2008-01-13 15:44)
= 演習2解答例 =
== 作業手順 ==
{{{
ruby script/generate migration AddMemoToTodo memo:text
rake db:migrate
}}}
== 変更点 ==
=== 1. helpers/todos_helper.rb ===
改行を<br/>タグに変換する new_lineメッソドを追加
{{{
#!html
<pre class="wiki">module TodosHelper
<font color="red">def #!ruby
def new_line(s)
s.gsub(/\n/, "<br>") "<br />")
end</font>
end
</pre>
}}}
=== 2. app/views/todos/show.html.erb ===
memoカラム表示用のコードを追加 memoカラム表示用の
{{{
#!html <p>
<b>Memo:</b><br/>
<%25=new_line(h(@todo.memo)) %25>
<pre class="wiki"><p> </p>
}}}
のコードを追加、全体では以下のようになります。
{{{
<p>
<b>Due:</b> <b>Due:</b>
<%25=h <%25=h @todo.due %25> %25>
</p> </p>
<p> <p>
<b>Task:</b> <b>Task:</b>
<%25=h <%25=h @todo.task %25> %25>
</p> </p>
<font color="red"><p> <p>
<b>Memo:</b><br/> <b>Memo:</b><br/>
<%25=new_line(h(@todo.memo)) %25> <%25=new_line(h(@todo.memo)) %25>
</p></font>
<%25= </p>
<%25= link_to 'Edit', edit_todo_path(@todo) %25> %25> |
<%25= <%25= link_to 'Back', todos_path %25>
</pre> %25>
}}}
=== 3. app/views/todos/edit.html.erb ===
memoカラム入力用の
{{{
<p>
<b>Memo</b><br />
<%25= f.text_area :memo %25>
</p>
}}}
のコードを追加、全体では以下のようになります。
{{{
<h1>Editing todo</h1>
<%25= error_messages_for :todo %25>
<%25 form_for(@todo) do |f| %25>
<p>
<b>Due</b><br />
<%25= f.date_select :due %25>
</p>
<p>
<b>Task</b><br />
<%25= f.text_field :task %25>
</p>
<p>
<b>Memo</b><br />
<%25= f.text_area :memo %25>
</p>
<p>
<%25= f.submit "Update" %25>
</p>
<%25 end %25>
<%25= link_to 'Show', @todo %25> |
<%25= link_to 'Back', todos_path %25>
}}}
=== 4. app/views/todos/new.html.erb ===
memoカラム入力用の
{{{
<p>
<b>Memo</b><br />
<%25= f.text_area :memo %25>
</p>
}}}
のコードを追加、全体では以下のようになります。
{{{
<h1>New todo</h1>
<%25= error_messages_for :todo %25>
<%25 form_for(@todo) do |f| %25>
<p>
<b>Due</b><br />
<%25= f.date_select :due %25>
</p>
<p>
<b>Task</b><br />
<%25= f.text_field :task %25>
</p>
<p>
<b>Memo</b><br />
<%25= f.text_area :memo %25>
</p>
<p>
<%25= f.submit "Create" %25>
</p>
<%25 end %25>
<%25= link_to 'Back', todos_path %25>
}}}
== ソースコード ==
解答例のソースコードは http://www.ey-office.com/trac/rails/browser/tags/todo_q2で参照できます。