我的 GSP 中有这个 ajax 调用:
$.ajax({
url: '${request.contextPath + '/Ticket/passAll'}',
type: 'POST',
data: data,
success: function() {
alert("Success");
}
});
这是我的控制器操作中的代码块:
response.setHeader("Content-disposition", "attachment; filename=sample.csv")
response.contentType = "application/vnd.ms-excel"
def outs = response.outputStream
def cols = [:]
tickets.each() {
outs << it.ticketNo + ";" + it.subject
outs << "\n"
}
outs.flush()
outs.close()
我通过 $.Ajax 方法从视图中传递的数据中获取票证列表。比我将该数据格式化为 CSV 并且比我想将该数据导出为 CSV 文件但没有任何反应。数据被发送到客户端,但没有文件可供下载,因为内容配置格式不正确。我错过了什么?我试图做类似的事情:
$.ajax({
url: '${request.contextPath + '/Ticket/passAll'}',
type: 'POST',
data: aoData,
dataType: 'text',
success: function(result) {
var uri = 'data:application/csv;charset=UTF-8,' + encodeURIComponent(result);
window.open(uri, 'tiketi.csv');
}
});
在控制器中我生成纯字符串,但是这样我得到一个没有扩展名的文件,这是不可接受的。
我怎样才能做到这一点?谢谢你。