我已经关注了这个铁路广播公司通过 Ajax 提交表单并更新 div 而不重新加载页面,但我在处理其中一部分时遇到了问题。
瑞安有$("#products").html("<%= escape_javascript(render(@products)) %>");
in an index.js.erb
文件来更新#products
div 提交表单时。我正在努力了解实例变量是否像@products
与我的情况相关,或者我是否可以简单地将其替换为 URL。
我试图在这个截屏视频中做与 Ryan 相同的事情,但我只想显示更新后的值,而不是显示搜索结果。
在 show.html.erb 我有:
<% @project.project_todos.order("created_at DESC").where(:status => false).each do |todo|%>
<%= form_for todo, :remote => true, :"data-replace" => "#dueon" do |f| %>
<%= f.text_field :due %>
<%= f.submit :class => "primary", :value => "Add" %>
<% end %>
<div id="dueon">
<%= render "duedate", :todo => todo %>
</div>
<% end %>
部分_duedate.html.erb
其中有一行:<%= todo.due %>
所以在我的index.js.erb中我目前有这个:$("#dueon").html("<%= escape_javascript(render("_duedate")) %>");
但它显然不起作用。我是否必须在此处使用变量来代替_duedate
?如果是这样,我该如何在控制器中进行设置?我的意思是变量代表什么?
另外,就其价值而言,部分渲染正确并显示todo.due
值...它只是在我提交表单时没有更新。
项目控制器:
def show
@project = Project.find(params[:id])
# Display the form to create a new todo
@project_todo = ProjectTodo.new
respond_to do |format|
format.html # show.html.erb
format.json { render :json => @project }
end
end