作为给定项目列表中我当前任务的一部分,用户可以选择其中一些并调用“打印”而不是选定的项目。
对于每个选定的项目,我们需要打印详细信息。它类似于在销售系统中打印选定项目的发票。
我创建了一个局部视图来编写每个记录详细信息,但我不确定如何根据我的要求使用它。
我可以在 document.ready 上调用 jQuery print 来满足我的要求吗?
正如@Levib 建议的那样,在我的 PrintView 中调用部分视图。而PrintView的document.reay函数正在调用window.print。但是当我尝试调用“打印”时,我看不到打印对话框。
这是我的看法,
@section Styles
{
<link rel="stylesheet" href="AdminStyle.css" type="text/css" media="all" />
<link rel="stylesheet" href="AdminPrintOrder.css" type="text/css" media="print" />
}
@foreach (var item in Model)
{
<div id="content" style="page-break-before: always">
@{Html.RenderPartial("_OrderDetailView", item);}
</div>
}
@section scripts
{
<script type="text/javascript">
$(document).ready(function () {
debugger;
window.print();
});
</script>
}
我的打印调用者视图是
function printInvoices(){
$.ajax({
type: 'POST',
url: '/Batch/PrintInvoices',
data: '{ "allocationId" : "' + unSelected.toString() + '"}',
contentType: "application/json; charset=utf-8",
traditional: true,
success: printedView,
error: errorInSubscribing
});
}
我是否需要处理 ajax reposne 来填充打印对话框。
function printedView() {
unSelected = [];
}
控制器动作是
[HttpPost]
public ActionResult PrintInvoices(string allocationId)
{
var context = new BatchContext();
var orderDetails = context.GetOrderDetails(RetriveList(allocationId));
return View(orderDetails);
}