私はRailsアプリケーションでコメント機能を開発しています。投稿ボタンをクリックした直後にコメントをユーザーに表示したいと思います。 ボタンを作成するためのフォームがあり、JQuery_ujsを使用してコメントを表示したいとします。それをする最善の方法は何ですか?jquery_ujsを使って同じページにコメントを表示
このコメントアクションの作成です:作成するための
<div id="comments">
<%@article.comments.each do |comm|%>
<div class="well">
<p class="text-muted">Added by <strong><%=comm.commentor%></strong> on
<%= l(comm.created_at, format: '%B, %d %Y %H:%M:%S') %></p>
<blockquote>
<p><%=comm.content%></p>
</blockquote>
</div>
<%end%>
</div>
形式:
def create_comment
params.permit!
@article = Article.find(params[:article][:id])
@comment = Comment.create(params[:comment])
@comment.article_id = @article.id
if @comment.save
render :text => 'created', :status => 202 and return
else
render :text => "not created", :status => 203 and return
end
end
これはjqueryのスクリプトです:
$(document).ready(function(){
$('#submit').click(function (e) {
e.preventDefault();
var commentor =this.comment_commentor.val();
var comment =this.comment_content.val();
$.ajax({
type: "POST",
url: '<%=create_comment_comment_index_path%>',
// send the last id to our rails app
data: {
commentor: commentor,
comment: content,
},
complete: function(jqXHR, textStatus){
if(jqXHR.status == "203"){
//invalid
}else if(jqXHR.status == "202"){
//valid
$('#comments').append("<div class='well'>
<p class='text-muted'>Added by <strong><%[email protected]%></strong> on <%= l(@comment.created_at, format: '%B, %d %Y %H:%M:%S') %>
</p>
<blockquote>
<p><%=comm.content%></p>
</blockquote>
</div>");
}
}
});
});
});
これは私がコメントを表示する方法ですがコメント:
<%= form_for(:comment, :url => create_comment_comment_index_path) do |f| %>
<input type="hidden" value="<%=params[:id]%>" name="article[id]">
<div class="field">
<%= f.text_field :commentor,:class=>"form-control", :required=>"true"%>
</div>
<br>
<div class="field">
<%= f.text_area :content,:class=>"form-control", :required=>"true"%>
</div>
<br>
<div class="actions">
<%= f.submit "create",:id=>"submit",:class=>"btn btn-lg btn-primary "%>
</div>
<% end %>
は、あなたのHTML –
を表示してくださいコードは、私はまだテストしていません大丈夫であればi'amわからない、私の質問を編集しました。 – Joma
あなたのアプローチは正しいです。最善の方法はAjaxを使用して、成功したコールバック関数でサーバーが返すデータを渡すことです。ここには2つのオプションがあります。サーバー側で新しいコメントHTMLを生成し、それをテキストとして返し、要素にデータを追加するか、今行っていることを実行します。ブラウザのコンソールを使用してJavaScriptをデバッグできます。 –