gpt4 book ai didi

ruby-on-rails - 我在 ajax 返回时收到 406 错误

转载 作者:行者123 更新时间:2023-12-04 04:56:06 24 4
gpt4 key购买 nike

我是 Rails 的新手,所以我可能以某种方式搞砸了(显然)。我有一个表单,通过 ajax 将提交发送回 Controller 。数据正在到达那里并进入数据库。目标是成功提交后,数据将以 html 格式返回,然后我可以将其添加到页面而不会导致页面刷新。

这是我的 Controller :

# POST /projects
# POST /projects.json
def create
@project = Project.new(params[:project])
@project.user_id = current_user.id

respond_to do |format|
if @project.save
#format.html { redirect_to @project, notice: 'Project was successfully created.' }
#format.json { render json: @project, status: :created, location: @project }
render :partial => "projects/project", :locals => { :project => @project }
else
format.html { render action: "new" }
format.json { render json: @project.errors, status: :unprocessable_entity }
end
end
end

我的 ajax 函数如下所示:
$('#new_project').submit(function(){

$.ajax({
type: 'post',
beforeSend: setHeader,
url:'/projects',
dataType: 'json',
data: $('#new_project').serialize(),
success: function(json) {
console.log(json);
parent.jQuery('#cboxClose').click();
}
});

return false;

});

最后,我的部分。部分是循环的一部分。循环效果很好,那里没有问题。循环如下所示:
  <% @projects.each do |project| %>

<%= render :partial => "project", :object => project %>

<% end %>

部分看起来像这样:
<section class="project">

<p class="name"><span>Name: </span> <%= project.name %></p>
<p class="title"><span>Title: </span><%= project.title %></p>
<p class="title"><span>User ID: </span><%= project.user_id %></p>
<article>
<span>Details:</span> <%= project.details %>
</article>
<article>
<p>Meta:</p>
<%= link_to 'Show', project %>
<%= link_to 'Edit', edit_project_path(project), :data => { :colorbox => true,:colorbox_height => '500px', :colorbox_width => '500px', :colorbox_iframe => true } %>
<%= link_to 'Destroy', project, method: :delete, data: { confirm: 'Are you sure?' } %>
</article>

</section>

所以就是这样。我以为我在正确的 rails 上,但 406 错误让我陷入了困境。

最佳答案

您发送 ajax 请求,您的应用程序应将 javascript(或 json)返回给浏览器。但是您调用“渲染”并且响应具有 html 类型。所以406错误是。

如果你想在成功的 ajax 调用后呈现部分,你应该稍微改变你的 Controller (考虑对 format.json 使用 format.js)。

Controller :

if @project.save
format.html { redirect_to @project, notice: 'Project was successfully created.' }
format.js #render create.js.erb
else
format.html { render action: "new" }
format.json { render json: @project.errors, status: :unprocessable_entity }
end

并且您应该在目录中创建文件 create.js.erb,其中包含该 Controller 的 View ,如下所示:
$("div#that_you_wat_to_update").html("<%= escape_javascript render(:partial => 'projects/project', :locals => { :project => @project }) %>");

附言如果你真的想用 json 响应,那么你应该更新你的 ajax 调用来处理 json 响应,但这是另一回事。

关于ruby-on-rails - 我在 ajax 返回时收到 406 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16736285/

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