我正在使用MVC3和evopdf(http://www.evopdf.com/)在用户点击打印按钮时创建pdf。
我的初始视图包含一个表单和打印按钮以及专为打印而设计的第二个视图。
单击打印按钮调用javascript以提交表单,该表单调用打印操作。
我想要发生的是,一旦点击了打印按钮,就会显示“处理”消息。 生成pdf后,我希望删除该消息。
这是javascript(我没有包含所有的javascript,因为有些部分不相关)
$(document).ready(function () {
$(".btn").click(function () {
var delay = 10;
$("#AjaxDelay").val(delay);
$.blockUI();
$('#printForm').submit();
});
$('#printForm').submit(function () {
$.blockUI();
$.ajax({
url: this.action,
type: this.method,
success: function (data) {
$.unblockUI();
//I need to open the pdf in appropriate app, adobe pdf viewer or similar
},
failure:function(data) {
alert("error");
$.unblockUI();
}
});
return false;
});
});
表格
@using (Html.BeginForm("PrintView", "Index", new { format = "pdf/", id = Model.ID, AjaxDelay = Model.AjaxDelay }, FormMethod.Get, new { id="printForm" }))
{
@Html.HiddenFor(m=>m.AjaxDelay)
<button type="button" class="btn print" >Print</button>
}
的IndexController
public ActionResult PrintView(int id)
{
var model = GetData(id);
return View(model);
}
这是我的HttpHandler
public void ProcessRequest(HttpContext context)
{
if (!context.Request.IsAuthenticated) return;
ProducePDF(context, "pdf title", 20);
}
private void ProducePDF(HttpContext context, string title,int delay)
{
var pdfConverter = GetPdfConverter();
// set the license key
pdfConverter.LicenseKey = "licence key here";
pdfConverter.JavaScriptEnabled = true;
var pdfBytes = pdfConverter.GetPdfBytesFromUrl(context.Request.Url.ToString().Replace(".pdf/", ""));
// send the PDF document as a response to the browser for download
var response = HttpContext.Current.Response;
response.Clear();
response.AddHeader("Content-Type", "application/pdf");
response.AddHeader("Content-Disposition", String.Format("attachment; filename=" + title + ".pdf; size={0}", pdfBytes.Length));
response.BinaryWrite(pdfBytes);
response.End();
}
感谢。
答案 0 :(得分:0)
我发现了一个使用jquery cookie插件并在响应中添加cookie的解决方案,如此stackoverflow文章中所述。
Hide image using Javascript after controller action is complete MVC3
我必须做一个小改动,因为我必须在删除cookie时指定路径。