ASP.NET之Web打印-终极解决篇

本文详细介绍了在ASP.NET中实现Web打印的三种常见方法:1)IE直接打印,适用于简单的打印需求;2)ActiveX控件,提供更灵活但需要客户端安装;3)利用.NET组件,通过XML描述打印文件,需要客户端安装.NET Framework。文章重点讨论了如何在服务器端编写的打印组件中访问客户端资源,包括设置打印机名称和模拟用户身份进行打印,以实现不受限制的Web打印。
摘要由CSDN通过智能技术生成
ASP.NET之Web打印-终极解决篇

作者:陈缘
联系:luandao2000@gamil.com
博客:http://blog.csdn.net/luandao2000
主页:http://www.spbase.com

        做过bs开发的同志应该都深有体会,在web程序中打印不再象应用程序中那样便于控制了,web程序天生的一些特性造成了这个缺点,如:打印机在本地,而文件确可能在服务器上;格式如何控制和定制等等。都给我们开发中带来了很多问题,虽说有水晶报表等控件来解决但总归是不方便。当然有了问题就会有人来研究解决,这里我先对目前流行的几种方式做个简单介绍:

1、IE直接打印

        这个不用多说,直接调用window.print或者webrower控件的ExecWB方法来打印。方便快捷,客户端无需任何设置即可。利用一些办法也可以实现简单的定制,比如做一个模板htm文件,然后在js中动态创建一个隐藏帧来,用脚本来生成其中的数据,再把最后的结果文件写入到隐藏帧打印处理。如果处理的好,实际上效果也是不错。对于简单的打印需求应该是够了。这里我举个实际中的例子来说明这种方式:
        开发中经常需要打印一些统计的结果给用户,比如说一个常见的功能是营业报表类的打印:操作员先输入查询条件,然后提交得到查询的结果,点击打印后,按照定义好的格式打印报表。
        我们实现上大部分情况会把查询的结果绑定到DataGrid上来,然后打印DataGrid。这种情况的打印一般来说格式比较固定简单,确定后基本不会再作更改。所以可以采用IE直接打印,但若直接调用window.print来打印结果页面,页面上别的无关元素也会被打印出来,页头页尾的格式也不好控制,所以采用把需要打印的数据动态写入到隐藏帧中打印的方式来实现
        代码示例:ASP.NET中打印指定的DataGrid内容
        其中借用来自微软的一段js代码,整个js代码如下:

//以下脚本实现:打印指定的datagrid

var vGridContent;  //DataGrid的内容
var vHeaderInfo;  //打印的表头
var vTailerInfo;  //打印的表尾

/*
目的:在页面写入隐藏帧并打印
参数:
vDataGrid  所要打印的DataGrid句柄

备注:
 代码中调用如下
 btPrint.Attributes.Add("onclick","return PrintDataGrid(document.all('SheetList'))");
 
 SheetList为待打印的DataGrid的ID
*/

function PrintDataGrid(vDataGrid)
{
  PickupHeaderInfo();
  
  document.body.insertAdjacentHTML("beforeEnd",
    "<iframe name=printHiddenFrame width=0 height=0></iframe>");
 
  var doc = printHiddenFrame.document;
  doc.open();
  doc.write("<body οnlοad=/"setTimeout('parent.onprintHiddenFrame()', 0)/">");
  doc.write("<iframe name=printMe width=0 height=0 ></iframe>");
  doc.write("</body>");
  doc.close();
 
  CreateHtmlReport(printHiddenFrame.printMe,vDataGrid);
  return false;
    
}
     

/*
目的:在隐藏帧中写入DataGrid的内容,并重写DataGrid的格式
参数:
vHideFrame 隐藏帧的句柄<

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值