dra*_*ago 4 ajax jquery grails download
我在我的GSP中有这个ajax调用:
$.ajax({
url: '${request.contextPath + '/Ticket/passAll'}',
type: 'POST',
data: data,
success: function() {
alert("Success");
}
});
Run Code Online (Sandbox Code Playgroud)
这是我的控制器操作的代码块:
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()
Run Code Online (Sandbox Code Playgroud)
我通过$ .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');
}
});
Run Code Online (Sandbox Code Playgroud)
并在控制器中我生成纯字符串,但这样我得到一个没有扩展名的文件是不可接受的.
我怎样才能做到这一点?谢谢.
我猜url属性应该固定,因为你的引号是碰撞的.
试试:
$.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');
}
});
Run Code Online (Sandbox Code Playgroud)
据我所知,不可能通过AJAX触发文件下载.相反,你可以做这样的事情(例如使用jQuery):
function downloadComplete(){ hideSpinner();}
function downloadStart(){ showSpinner();}
function download(){
downloadStart()
var urlParams = data // or e.g. $(form).serialize()
var downloadUrl = "${request.contextPath}/Ticket/passAll?" + urlParams
$("#download-iframe").remove()
$('<iframe style="display:none" id="download-iframe" src="' + downloadUrl + '" onreadystatechange="downloadComplete()" onload="downloadComplete()">').appendTo('body');
}
Run Code Online (Sandbox Code Playgroud)
您可能遇到问题,因为它是GET请求:"安全性"或参数太多.但在正常情况下应该没问题.
归档时间: |
|
查看次数: |
18716 次 |
最近记录: |