提问人:Sandro Palmieri 提问时间:3/22/2020 更新时间:3/23/2020 访问量:1541
尝试呈现 js.erb 部分模板时出现问题
Issue when trying to render a js.erb partial template
问:
Rails 版本 6.0.2.1 Ruby 版本 2.6.5
我正在尝试使用jquery在我的应用程序的显示视图中呈现部分。
这是我的javascript文件:
import $ from "jquery";
$(() =>
$("a#test-button").on("click", ev => {
ev.preventDefault;
$("div#teacher-form").html("<%= j render(partial: 'teacher_form') %>");
})
);
然后,我在视图模板中引用了javascript,如下所示:
<%= javascript_pack_tag 'test_button' %>
<%= link_to 'Test', stakeholder_student_school_year_path, data: { type: :html }, remote: true, id: 'test-button', class: 'btn btn-info' %>
<div id="teacher-form"></div>
在我的控制器中也是如此:
def show
@teachers = @year.teachers
respond_to do |format|
format.html
format.js {
render 'student_school_years/_teacher_form',
layout: false
}
end
end
当我单击测试按钮添加部分时,它会在视图中呈现以下代码片段 <%= j render(partial: 'teacher_form') %>而不是实际的部分模板。无法弄清楚发生了什么。
答:
1赞
max
3/22/2020
#1
您似乎完全误解了 JS.erb 模板的工作原理。
不要使用 引用模板。用于引用资产管道中的资产。而且,您无法在资产管道中渲染部分,因为它们是在部署时编译的。.js.erb
javascript_pack_tag
你只得到一个文字字符串的原因是资产不是通过 webpack 中的 ERB 发送的。链轮会这样做并引发错误。"<%= j render(partial: 'teacher_form') %>"
相反,您将编写模板,以便它更改页面:js.erb
def show
@teachers = @year.teachers
respond_to do |format|
format.html
format.js # renders show.js.erb
end
end
// You can't use imports since this is not run in the assets pipeline
// you have to make jQuery a global
$("#teacher-form").html("<%= j render(partial: 'teacher_form' %>");
当您单击链接时,Rails ujs 驱动程序实际上只是加载该脚本并在页面上对其进行评估。前提是,这允许你在没有 SPA 框架或实际编写请求处理程序的情况下执行 ajax 请求和类似 SPA 的东西。这是否是一个好主意是值得商榷的。
我不明白的是,为什么您不首先将表单放在视图中,然后切换其可见性,而不是让服务器参与其中,这只是客户端转换。
评论
js.erb