gpt4 book ai didi

javascript - rails 5 + Ajax : Comment appended only if a comment exists

转载 作者:行者123 更新时间:2023-11-29 23:31:40 26 4
gpt4 key购买 nike

我正在尝试创建一个功能,用户可以在其中使用 Ajax 创建对文章的评论。但是,我不明白为什么只有存在一个评论才能通过 ajax 成功呈现评论。评论提交到数据库,没有任何回滚。

如果我重新加载页面并创建第二条评论,那么新评论才会被附加。

Started POST "/articles/veniam-ipsum-eos-quas-aut-rerum-consequatur-at-velit-perferendis-odio/comments" for 103.252.202.198 at 2017-11-03 16:50:14 +0000
Processing by CommentsController#create as JS
Parameters: {"utf8"=>"✓", "comment"=>{"content"=>"comment only appended if a comment exists"}, "commit"=>"Add Comment", "article_id"=>"veniam-ipsum-eos-quas-aut-rerum-consequatur-at-velit-perferendis-odio"}
User Load (0.4ms) SELECT "users".* FROM "users" WHERE "users"."id" = $1 ORDER BY "users"."id" ASC LIMIT $2 [["id", 1], ["LIMIT", 1]]
Article Load (0.6ms) SELECT "articles".* FROM "articles" WHERE "articles"."slug" = $1 LIMIT $2 [["slug", "veniam-ipsum-eos-quas-aut-rerum-consequatur-at-velit-perferendis-odio"], ["LIMIT", 1]]
(0.2ms) BEGIN
SQL (0.6ms) INSERT INTO "comments" ("content", "article_id", "user_id", "created_at", "updated_at") VALUES ($1, $2, $3, $4, $5) RETURNING "id" [["content", "comment only appended if a comment exists"], ["article_id", 189], ["user_id", 1], ["created_at", "2017-11-03 16:50:14.291049"], ["updated_at", "2017-11-03 16:50:14.291049"]]
(2.5ms) COMMIT

评论 Controller

class CommentsController < ApplicationController
before_action :authenticate_user!
before_action :set_article

def create
@comment = @article.comments.build(comment_params)
@comment.user = current_user
if @comment.save
respond_to do |format|
format.html do
flash[:success] = "Your comment was created successfully"
redirect_to @comment.article
end
format.js
end
unless @comment.article.user == current_user
Notification.create!(recipient: @article.user, actor: current_user, action: "posted", notifiable: @comment)
end
else
respond_to do |format|
format.html { redirect_to @comment.article, flash[:error] = "Unable to submit comment."}
end
end
end

private

def set_article
@article = Article.friendly.find(params[:article_id])
end

def comment_params
params.require(:comment).permit(:content)
end

end

文章 Controller

  def show
@comments = @article.comments.order("created_at DESC")
@new_comment = @article.comments.new
end

文章/show.html.erb

  <%= render 'comments/comment_form' %>
<% if @comments.exists? %>
<div id= "comment" >
<%= render @comments %>
</div>
<% else %>
<div class ="no-comments">
<p> There are no comments yet.</p>
</div>
<% end %>

评论/_comment_form.html.erb

  <%= form_for [@article, @new_comment], remote: true do |f| %>
<div class="form-group">
<div class = "row">
<div class= "col-md-9 col-sm-9 col-xs-12">
<%= f.text_area :content, rows: 2, placeholder: "Write your comment...", class: 'form-control' %>
</div>
<div class= "col-md-3 col-sm-3 col-xs-12">
<%= f.submit 'Add Comment', class: 'btn btn-md btn-default' %>
</div>
</div>
</div>
<% end %>

评论/_comment.html.erb

<%= comment.content %>

comments/create.js.erb

$('#comment').append("<%= escape_javascript (render partial: @comment) %>");

路线:

  resources :articles do
resources :comments
end

解决方案:

用户 PlanB 在下面给出了一个可行的解决方案,但我稍微调整了答案以便 <p> There are no comments yet.</p>提交评论表后将被删除。

文章/show.html.erb

  <div id="comment-form">
<%= render 'comments/comment_form' %>
</div>
<div id = "comment-list" >
<% if @comments.exists? %>
<%= render @comments %>
<% else %>
<div id = "no-comments">
<p> There are no comments yet.</p>
</div>
<% end %>
</div>

comments/create.js.erb

$('#comment-list').append("<%= escape_javascript (render partial: @comment) %>");
$('#no-comments p').html('');

最佳答案

尝试这样的事情:

  <%= render 'comments/comment_form' %>
<% if @comments.exists? %>
<div class= "comment" >
<%= render @comments %>
</div>
<% else %>
<div class= "comment">
<p> There are no comments yet.</p>
</div>
<% end %>

和:

$('.comment').append("<%= escape_javascript (render partial: @comment) %>");

因为你的if语句不创建 div#comment如果现在有评论,那么

$('#comment').append("<%= escape_javascript (render partial: @comment) %>");不能将任何内容附加到 #comment因为它不存在于 HTML 中。

关于javascript - rails 5 + Ajax : Comment appended only if a comment exists,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47101211/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com