我有以下部分文件
_report.html.erb
<h5>REPORT</h5>
<hr/>
<%= link_to "Extract REPORT", "#", :class => 'btn btn-primary', id: 'load_panel' %>
<br/>
<br/>
<div class="row">
<% rand = Time.now.to_i - Random.new.rand(1..Time.now.to_i) %>
<div class="col-md-12">
<input type="hidden" id="randValue" value="<%= rand %>" data-validate="false" data-hidden="true"/>
<div>
<b>File Name</b>
<hr/>
</div>
<div id="application-attachments-<%= rand %>" class="col-xs-12">
<%= render partial: 'report_attachment', locals: {application_attachments: f.object.application_attachments} %>
</div>
</div>
</div>
_report_attachment.html.erb
<% application_attachments.each do |attachment| %>
<div class="fields">
<%= render "report_attachment_fields", rep_attachment: attachment, instalment: true, type: 'application_assignment' %>
</div>
<% end %>
_report_attachment_fields.html.erb
<div class="row attachment_display">
<% if rep_attachment.attachment? && rep_attachment.attachment.model.share_file %>
<% if @action == "show" && @account_type %>
<div class="col-md-6 ellipis">
<%= link_to File.basename(rep_attachment.attachment.path), rep.attachment.url, target: "_blank", id: 'view_file', :data => { application_attachment_id: rep_attachment.id } %>
<%= rep_attachment.active %>
</div>
<% end %>
<% end %>
</div>
初次加载时,会相应地加载所有3个文件。但是点击Extract CTOS后,它会发出一个javascript请求
application.js
$('body').on('click', '#load_panel', function(event) {
object_selected = $(this)
$(this).attr('disabled', 'disabled');
$.ajax({
type: 'GET',
url: '/applications/generate_report?application_id='+$(this).attr('data-application-id')+'&rand_value='+$(this).attr('data-rand-value'),
dataType: 'json',
success: function(data) {
object_selected.removeAttr('disabled');
}
})
})
在调用GET请求时,它将调用此方法
def generate_report
@rand_value = params[:rand_value]
@rep_application_attachment = @application.rep_attachment
respond_to do |format|
format.js
end
end
应该调用此js.erb文件
generate_report.js.erb
$("#application-attachments-#{@rand_value}").html("<%= escape_javascript(render 'report_attachment', application_attachments: @rep_application_attachment) %>");
现在的问题是我没有收到错误,它表示generate_report.js.erb已被渲染,但它不会渲染任何东西。我错过了什么?
答案 0 :(得分:0)
render
方法呈现模板的选项。<强> generate_report.js.erb 强>
$("#application-attachments-#{@rand_value}").html("<%= escape_javascript(render partial: 'report_attachment', application_attachments: @rep_application_attachment) %>");
您的原始代码:
$("#application-attachments-#{@rand_value}").html("<%= escape_javascript(render 'report_attachment', application_attachments: @rep_application_attachment) %>");
渲染部分
控制器中的部分呈现最常与Ajax调用一起使用,它只更新页面上的一个或几个元素而不重新加载。从控制器渲染部分可以在整页渲染中使用相同的部分模板(通过在模板内调用它)和子页面更新发生时(从响应Ajax调用的控制器操作)。默认情况下,不使用当前布局。
有关渲染的详细信息
答案 1 :(得分:0)
我认为问题是当你需要使用ERB "#{}"
时,你试图以错误的方式插入你的ruby实例变量(你正在使用Ruby的字符串插值语法"<%= %>"
)。
这应该有效:
$("#application-attachments-<%= @rand_value %>").html("<%= escape_javascript(render 'report_attachment', application_attachments: @rep_application_attachment) %>");
答案 2 :(得分:0)
解决了它。这与我的ajax电话有关。
$.ajax({
type: 'GET',
url: '/applications/generate_report?application_id='+$(this).attr('data-application-id')+'&rand_value='+$(this).attr('data-rand-value'),
dataType: 'json',
success: function(data) {
object_selected.removeAttr('disabled');
}
})
应该是这个。通过不包括datatype ='script'
和正确的格式,即使我的js.erb被调用,它也没有被执行。
$.ajax({
type: 'GET',
url: '/applications/generate_report?application_id='+$(this).attr('data-application-id')+'&rand_value='+$(this).attr('data-rand-value'),
data: {
format: 'js'
},
dataType: 'script',
success: function(data) {
object_selected.removeAttr('disabled');
}
})