0

「レールを使ったアジャイル Web 開発 第 4 版」という本から ruby​​ を学んでいます。Rails 3.2 と Ruby 1.9.2 を使用しています。

次のコードを使用して、カードの AJAX 関数を呼び出してみました。

 <%= button_to 'Add to Cart', line_items_path(product_id: product) , remote: true %>

次に、コントローラの「作成」アクション メソッドに line_item が追加されました

 respond_to do |format|
      if @line_item.save
       # format.html { redirect_to @line_item.cart,notice: 'Line item was successfully created.' }
        format.html { redirect_to store_url }
        format.js 

次に、line_items ビューで create.js.erb ファイルを作成し、コンテンツを追加しました

$('#cart').html("<%=j render @cart %>");

「カート」部分は

<div class="cart_title">Your Cart</div>
<table>
  <%= render(cart.line_items) %>

  <tr class="total_line">
    <td colspan="2">Total</td>
    <td class="total_cell"><%= number_to_currency(cart.total_price) %></td>
  </tr>
</table>
  <%= button_to 'Empty cart', cart, method: :delete, confirm: 'Are you sure?' %>

「line_item」パーシャルは

<tr>

  <td><%= line_item.quantity %>&times;</td>
  <td><%= line_item.product.title %></td>
  <td class="item_price"><%= number_to_currency(line_item.total_price) %></td>
</tr>

ページの通常の更新でこれを実行すると、カートの内容が更新され、正常に動作しますが、上記の「カートに追加」ボタンを使用して実行すると、AJAX 呼び出しが発生し、何らかの形でコントロールがcreate.js.erb ファイルまたは「line_items」パーシャルに到達していません。開発ログを見ると、次のメッセージが表示されました。

Started POST "/line_items?product_id=1" for 127.0.0.1 at 2012-07-24 22:04:24 +0530
Processing by LineItemsController#create as JS
  Parameters: {"authenticity_token"=>"+8jnhCPyLhj26JDuaP1LRUNhVGGlOpFyJcfVXoffX+U=", "product_id"=>"1"}
  [1m[35mCart Load (0.2ms)[0m  SELECT "carts".* FROM "carts" WHERE "carts"."id" = ? LIMIT 1  [["id", 14]]
  [1m[36mProduct Load (0.1ms)[0m  [1mSELECT "products".* FROM "products" WHERE "products"."id" = ? LIMIT 1[0m  [["id", "1"]]
  [1m[35mLineItem Load (0.3ms)[0m  SELECT "line_items".* FROM "line_items" WHERE "line_items"."cart_id" = 14 AND "line_items"."product_id" = 1 LIMIT 1
  [1m[36m (0.1ms)[0m  [1mbegin transaction[0m
  [1m[35m (0.8ms)[0m  UPDATE "line_items" SET "quantity" = 18, "updated_at" = '2012-07-24 16:34:24.620944' WHERE "line_items"."id" = 40
  [1m[36m (12.1ms)[0m  [1mcommit transaction[0m
  [1m[35mLineItem Load (0.2ms)[0m  SELECT "line_items".* FROM "line_items" WHERE "line_items"."cart_id" = 14
  [1m[36mProduct Load (0.2ms)[0m  [1mSELECT "products".* FROM "products" WHERE "products"."id" = 1 LIMIT 1[0m
  Rendered line_items/_line_item.html.erb (5.3ms)
  Rendered carts/_cart.html.erb (7.2ms)
  Rendered line_items/create.js.erb (8.4ms)
Completed 500 Internal Server Error in 30ms

ActionView::Template::Error (undefined method `title' for nil:NilClass):
    1: <tr>
    2: 
    3:   <td><%= line_item.quantity %>&times;</td>
    4:   <td><%= line_item.product.title %></td>
    5:   <td class="item_price"><%= number_to_currency(line_item.total_price) %></td>
    6: </tr>
    7: <!-- <%= debug(line_item) %> -->
  app/views/line_items/_line_item.html.erb:4:in `_app_views_line_items__line_item_html_erb__4463614436040447986_70300167607120'
  app/views/carts/_cart.html.erb:3:in `_app_views_carts__cart_html_erb___214977825009850242_70300164957540'
  app/views/line_items/create.js.erb:3:in `_app_views_line_items_create_js_erb___2733752682449914066_70300166787700'
  app/controllers/line_items_controller.rb:52:in `create'

エラーの特定にご協力ください。ありがとう

4

1 に答える 1

2

製品がないline_itemを取得しています。したがって、実行line_item.productするとaが表示され、nil実行nil.titleするとエラーがスローされるため、ビューはレンダリングされません。おそらく、作成アクションで(正しい)line_itemをフェッチするのを忘れましたか?

于 2012-07-24T18:54:12.383 に答える