ScaffoldPlusAnswerTwo » 履歴 » リビジョン 15
リビジョン 14 (Yuumi Yoshida, 2011-08-07 10:50) → リビジョン 15/20 (Yuumi Yoshida, 2011-08-07 11:33)
h1. 演習2解答例
h2. 作業手順
<pre>
ruby generate migration AddMemoToTodo memo:text
rake db:migrate
</pre>
h2. 変更点
h3. 1. app/helpers/todos_helper.rb
改行を<br/>タグに変換する new_lineメッソドを追加
<pre><code class="color">
module TodosHelper
##(
def new_line(s)
raw(html_escape(s).gsub(/\n/, "<br>"))
end
)##
end
</code></pre>
h3. 2. app/views/todos/show.html.erb
memoカラム表示用のコードを追加
<pre><code class="color">
<p>
<b>Due:</b>
<%25=h @todo.due %25>
</p>
<p>
<b>Task:</b>
<%25=h @todo.task %25>
</p>
##(<p>
<b>Memo:</b><br/>
<%25=new_line(@todo.memo) <%25=new_line(h(@todo.memo)) %25>
</p>)##
<%25= link_to 'Edit', edit_todo_path(@todo) %25> |
<%25= link_to 'Back', todos_path %25>
</code></pre>
h3. 3. app/views/todos/_form.html.erb app/views/todos/edit.html.erb
memoカラム入力用のコードを追加
<pre><code class="color">
<h1>Editing todo</h1>
<%25= error_messages_for :todo %25>
<%25 form_for(@todo) do |f| %25>
<%25 if @todo.errors.any? <p>
<b>Due</b><br />
<%25= f.date_select :due %25>
</p>
<p>
<div id="error_explanation">
<h2><%25= pluralize(@todo.errors.count, "error") <b>Task</b><br />
<%25= f.text_field :task %25> prohibited this todo from being saved:</h2>
<ul>
<%25 @todo.errors.full_messages.each do |msg|
</p>
##(<p>
<b>Memo</b><br />
<%25= f.text_area :memo %25>
<li><%25= msg %25></li>
<%25 end
</p>)##
<p>
<%25= f.submit "Update" %25>
</ul>
</div>
</p>
<%25 end %25>
<div class="field">
<%25= link_to 'Show', @todo %25> |
<%25= link_to 'Back', todos_path %25>
</code></pre>
h3. 4. app/views/todos/new.html.erb
memoカラム入力用のコードを追加
<pre><code class="color">
<h1>New todo</h1>
<%25= error_messages_for :todo %25>
<%25 form_for(@todo) do |f| %25>
<p>
<%25= f.label :due %25><br <b>Due</b><br />
<%25= f.date_select :due %25>
</div>
<div class="field"> </p>
<p>
<%25= f.label :task %25><br <b>Task</b><br />
<%25= f.text_field :task %25>
</div>
##(<div class="field"> </p>
##(<p>
<%25= f.label :memo %25><br <b>Memo</b><br />
<%25= f.text_area :memo %25>
</div>)##
<div class="actions"> </p>)##
<p>
<%25= f.submit "Create" %25>
</div> </p>
<%25 end %25>
<%25= link_to 'Back', todos_path %25>
</code></pre>
</code></pre>