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で参照できます。