我有以下部分文件
_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个文件。但是,单击“提取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已被渲染,但没有渲染任何东西。我想念什么?
最佳答案
您需要指定'partial'选项以使用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调用的控制器操作)使用相同的部分模板。默认情况下,不使用当前布局。
有关渲染的更多信息
https://apidock.com/rails/ActionController/Base/render