Rails - 将注释编辑为部分

时间:2017-02-16 12:54:04

标签: ruby-on-rails ruby ruby-on-rails-4 model-view-controller

我正在使用Rails构建一个Events应用程序,并在Event show页面的底部有一个评论部分。我希望用户能够在同一个节目页面上创建/更新(编辑)/删除他们自己的评论。我该怎么做呢?

我已将一些代码放在一起,但我对rails很新,我的代码试图让用户远离显示页面并创建“评论”显示页面,而不是仅仅在事件显示页面上编辑表单。我有正确的模型关联has_many / belongs_to,我的评论嵌套在我的事件路线中。这是我到目前为止的代码 -

Comments_controller.rb

   class CommentsController < ApplicationController


def create
    @event = Event.find(params[:event_id])
    @comment = @event.comments.create(params[:comment].permit(:user_id, :body))


    redirect_to event_path(@event)
end

def show
    @comment = Comment.find(params[:id])
    @comment = @event.comments.find(params[:id])
end

def edit
    @comment.user = current_user

end

def update
    if @comment.update(comment_params)
        redirect_to event_path(@event)
    else
        render 'edit'
    end
end


def destroy
    @event = Event.find(params[:event_id])
    @comment = @event.comments.find(params[:id])
    @comment.destroy

    redirect_to event_path(@event)
end

private

    def comment_params
        params.require(:comment).permit(:body, :event_id, :user_id)
    end
end

Event.show.erb

  # some code for Events show...

    # Comments code - 
                <% if user_signed_in?  %>

                <div id="comments">
                    <%= render 'comments/form', commentable: @event %>
                    <% if @event.comments.any? %>
                        <h2><%= @event.comments.size %> Comment</h2>
                        <%= render @event.comments %>
                    <% else %>
                    <h2>There are no comments yet</h2>
                <% end %>

                </div>  

                <% end %>

Comments._comment.html.erb

  <div class="comment clearfix">


 <div class="comment_content">
    <p class="comment_user"><strong><%= comment.user %></strong></p>
    <p class="comment_body"><%= comment.body %></p>
    <p class="comment_time"><%= time_ago_in_words(comment.created_at) %> Ago</p>
  </div>

  <% if user_signed_in? and current_user %>
    <p><%= link_to 'Delete', [comment.event, comment],
                                  method: :delete,
                                  class: "button",
                                    data: { confirm: 'Are you sure?' } %></p>
    <p><%= link_to 'Edit', [comment.event, comment] %> </p>                                 
 <% end %>

</div>

comments_form.html.erb

  <%= simple_form_for([commentable, Comment.new ]) do |f| %>

<%= f.label :comment, label:  'Add a comment' %><br> 
<%= f.text_area :body %><br>
<br>
<%= f.button :submit, "Create", class: "btn btn-primary" %>
<% end %>

1 个答案:

答案 0 :(得分:0)

在停留在您需要添加remote: true的同一页面上执行操作 到您的表单并通过JS提交。您可以在Rails / JS Docs中阅读更多相关信息。 http://edgeguides.rubyonrails.org/working_with_javascript_in_rails.html 比,标准导轨方式是引导您到另一条路线。 要禁止它,并在同一个视图页面上执行所有操作,您可以使用JS。

要将操作限制为当前用户,您需要确保注释属于current_user。好像......     if user_signed_in?和comment.user_id == current_user.id (以防上面的代码不是防弹。)