首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >基于Ajax的微博评论( Rails)

基于Ajax的微博评论( Rails)
EN

Stack Overflow用户
提问于 2012-03-15 07:29:49
回答 1查看 581关注 0票数 2

我在用户页面上有基于ajax的微博评论。它起作用了,但不正确。当我向任何一个微博提交一个新的评论时,它总是发布到最后一个微博。然后,如果我用"F5“刷新页面,所有的内容都就位了--新的评论出现在正确的微博上。提前谢谢。

comment.rb

代码语言:javascript
复制
class Comment < ActiveRecord::Base
  attr_accessible :comment_content
  belongs_to :user
  belongs_to :micropost
end

comments_controller.rb

代码语言:javascript
复制
class CommentsController < ApplicationController
  before_filter :signed_in_user, only: [:create, :destroy]

   def create
    @micropost = Micropost.find(params[:micropost_id])
    @comment = Comment.new(params[:comment])
    @comment.micropost = @micropost
    @comment.user = current_user
      respond_to do |format|
      @comment.save
           format.html { redirect_to current_user }
           format.js
      end
   end 
end

_micropost.html.erb

代码语言:javascript
复制
<tr>
  <td class="micropost">
    <span class="content"><%= wrap(micropost.content) %></span>
    <span class="timestamp">
    Posted <%= time_ago_in_words(micropost.created_at) %> ago.
    </span>
    <%= render 'shared/comment_form', micropost: micropost %>
   <div id="comments">
     <%= render micropost.comments %>
   </div>
  </td>
</tr>

_comment_form.html.erb

代码语言:javascript
复制
<%= form_for ([micropost, @comment]), :remote => true do |f| %>
<%= render 'shared/error_messages', object: f.object %>
<%= f.text_area :comment_content, :size => "40x2" %>
  <button class="btn" type="submit">
    Comment
  </button>
<% end %>

_comment.html.erb

代码语言:javascript
复制
<span style="width: 100%; background:#dff0d8"><%= wrap(comment.comment_content) %></span>
<span class="timestamp">
 Posted by <%= comment.user.name %> <%= time_ago_in_words(comment.created_at) %> ago.
</span>

create.js.erb

代码语言:javascript
复制
$('#comments').html("<%= escape_javascript(render(:partial => @micropost.comments)) %>");
EN

回答 1

Stack Overflow用户

发布于 2012-03-15 09:25:49

也许你可以改变

代码语言:javascript
复制
@comment = Comment.new(params[:comment])
@comment.micropost = @micropost

代码语言:javascript
复制
@comment = @micropost.comments.build(params[:comment])
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9715506

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档