gpt4 book ai didi

javascript - Ajax get 在第二次 get 调用时未返回成功或错误

转载 作者:行者123 更新时间:2023-11-28 08:16:55 24 4
gpt4 key购买 nike

我有“打印”按钮,它调用 ajax get 并在新窗口中打开页面进行打印。

<button type="button"  onclick="getPrint(event , 'Id')">Print</button>

function getPrint(e, Id) {
var url = '/PrintController/Print/' + "?Id=" + id;

$.ajax({
url: url,
async: false,
success: function (data) {
if (data.success == true) {
var mywindow = window.open('', 'Print', 'height=500,width=600,menubar=yes');
mywindow.document.write('<html><head><title></title>');
mywindow.document.write('</head><body >');
mywindow.document.write($('<div></div>').append(data.viewBody).clone().html());
mywindow.document.write('</body></html>');
mywindow.focus();
mywindow.print();
mywindow.close();
}
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
alert(textStatus);
}
});
return;
}

Controller 返回如下:-

return Json(new { success = true, viewBody = viewPrintSub }, JsonRequestBehavior.AllowGet);

我第一次单击“打印”按钮时,效果很好。它执行 ajax get 并控制转到操作方法并返回成功,然后返回查看并进入成功函数并打开新窗口,

但是在第二次单击时,它会转到 Controller 操作方法,然后返回成功,然后这次它根本不会成功或出错。

最佳答案

你解决这个问题了吗?我建议您将缓存设置为 false,当然还要确保浏览器不会阻止网站打开多个窗口。

function getPrint(e, Id) {        
var url = '/PrintController/Print/' + "?Id=" + id;

$.ajax({
cache: false, // Do not cache
url: url,
async: false,
success: function (data) {
if (data.success == true) {
var mywindow = window.open('', 'Print', 'height=500,width=600,menubar=yes');
mywindow.document.write('<html><head><title></title>');
mywindow.document.write('</head><body >');
mywindow.document.write($('<div></div>').append(data.viewBody).clone().html());
mywindow.document.write('</body></html>');
mywindow.focus();
mywindow.print();
mywindow.close();
}
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
alert(textStatus);
}
});
return;

}

关于javascript - Ajax get 在第二次 get 调用时未返回成功或错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23482237/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com