我在頁面上有一個「加入」按鈕,當點擊時,用戶joins
模型。類似於按鈕。在我的join.js.erb
文件中,我在用戶加入後呈現部分內容,如部分顯示不加入按鈕以及他們現在可以評論模型的表單。這是它的外觀。rails ajax渲染表格
*join.js.erb*
$("#restaurant-<%= @restaurant.id %>").html("<%= escape_javascript render :partial => 'restaurants/join_button', :locals => { :restaurant => @restaurant } %>");
$("#restaurantCommentForm").html("<%= escape_javascript render :partial => 'restaurants/comments_form', :locals => { :restaurant => @restaurant } %>");
下面是評論部分
<% if current_user.voted_on?(restaurant) %>
<div class="section-wrapper section-wrapper-two">
<h4 class="text-muted text-center" style="margin: 0 0 10px;">Write a review</h4>
<%= render :partial => "comments/form", :locals => { :comment => @comment } %>
</div>
<% end %>
所以JS文件被渲染的部分,這是渲染另一部分,無論是當地人。
我得到的錯誤就是First argument in form cannot contain nil or be empty
ActionView::Template::Error (First argument in form cannot contain nil or be empty):
1: <%= form_for([@commentable, @comment]) do |f| %>
我想這是我在comment_partial當地人的問題。有誰知道這個適當的解決方案? 感謝
我已經試過這已經在comments_form部分
<%= render :partial => "comments/form", :locals => { :restaurant => @commentable, :comment => @comment } %>
您在哪裏設置了@ @ commentable'和'@ comment'的值? –
在控制器中。 '@commentable = @ restaurant',因爲這裏的可評論模型是餐廳模型。 '@comment = Comment.new' –