码迷,mamicode.com
首页 > Web开发 > 详细

DIFramework.NET ━ Web中打印的各种方案参考-欢迎补充

时间:2015-01-09 12:47:31      阅读:241      评论:0      收藏:0      [点我收藏+]

标签:c#   工作流   开发框架   报表   rdiframework.net   

  RDIFramework.NET ━ Web中打印的各种方案参考-欢迎补充

  

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

一、IE直接打印  

  这个不用多说,直接调用window.print或者webrower控件的ExecWB方法来打印。方便快捷,客户端无需任何设置即可。利用一些办法也可以实现简单的定制,比如做一个模板htm文件,然后在js中动态创建一个隐藏帧来,用脚本来生成其中的数据,再把最后的结果文件写入到隐藏帧打印处理。如果处理的好,实际上效果也是不错,对于简单的打印需求应该是够了。比如下面的这个实现,我们要打印待办任务,如下图所示:

技术分享

  用户单击打印按钮,即可弹出打印效果,如下图所示:

技术分享

  实现上面的效果非常的简单,这对简单的要求不高的打印非常有用。实现方式如下,首先我们需要设置一个我们要打印的范围,如下面代码: 

 <!--startprint--> 
 <table id="list"></table>    
 <!--endprint-->

上面的Id=List是我们数据展示的区域,这样用户单击时就可以打印这个范围内的数据,打印代码如下:

$(‘#btnPrint‘).click(
       function preview() {
           var bdhtml = window.document.body.innerHTML;
           var sprnstr = "<!--startprint-->";
           var eprnstr = "<!--endprint-->";
           var prnhtml = bdhtml.substr(bdhtml.indexOf(sprnstr) + 17);
           prnhtml = prnhtml.substring(0, prnhtml.indexOf(eprnstr));
           window.document.body.innerHTML = prnhtml;
           window.print();
           window.history.go(0);
       });

二、使用水晶报表做打印支持


  水晶报表我相信做.NET开发的朋友都有听过,水晶报表有很多优点,比如:快速的报表开发、能够导出成为复杂的交互性图表 、可以与其它控件一起在WebForm中使用 、能够动态地将报表导出成为.pdf,.doc,xls,html,rtf等多种格式。如何制作水晶报表网上有很多现成的文章可以供参考,这儿就不介绍了。下面我们用水晶报表来做打印的实现。效果图如下,我们要打印产品管理的数据,如下图所示:

技术分享

  我们单击打印,即可打印产品管理报表,如下图所示: 

技术分享

  代码非常的简单,先要制作好水晶报表(报表的数据源可以为DataTable,也可以是实体),如何制作可以参考相关的文章,网上很多。制作好后,新建一个WebForm页面,将CrystalReportViewer添加到页面中,再指定其对应的报表即可,再加上下面这段代码,一个简单的报表就完成了。

        protected void Page_Load(object sender, EventArgs e)
        {
            if (!Page.IsPostBack)
            {
                DataTable dtReportData = new DataTable("dsProductInfo");
                IDbProvider dbProvider = DbFactoryProvider.GetProvider(SystemInfo.RDIFrameworkDbConection);
                dtReportData =dbProvider.Fill("SELECT TOP 100 PRODUCTCODE,PRODUCTNAME,PRODUCTMODEL,PRODUCTSTANDARD,PRODUCTUNIT,PRODUCTPRICE,PRODUCTDESCRIPTION FROM " +CASE_PRODUCTINFOTable.TableName);
                ReportDataSource rds = new ReportDataSource("dtCaseProductInfo", dtReportData);
                ReportViewer1.LocalReport.DataSources.Clear();
                ReportViewer1.LocalReport.DataSources.Add(rds);
                ReportViewer1.LocalReport.Refresh();
            }
        }

三、使用jqprint进行打印

  jqprint,一个通过单击页面按钮,便实现页面打印的jQuery插件jqprint。jqprint的使用方法非常的简单,但比我们介绍的方法一更好用一些,更专业一些。要使用jqprint,首先要引用相应的js文件。

<script language="javascript" src="jquery-1.4.4.min.js"></script>
<script language="javascript" src="jquery.jqprint-0.3.js"></script>

    比如,我们要打印如下html的内容:

<div id="ddd">
    <table>
        <tr>
            <td>test</td>
            <td>test</td>
            <td>test</td>
            <td>test</td>
            <td>test</td>
        </tr>
    </table>
</div>

     只需调用这行代码即可实现:

$("#ddd").jqprint();

        如果需要使用jqprint,可以在这儿下载,点击下载

  下面我们打印一个复杂一点的,打印角色列表,效果果如下所示:  

技术分享

  单击打印按钮,打印效果如下图所示:

技术分享

四、其他方法 

  1、我们可以使用导出Excel或PDF等方式来进行打印。

  2、使用商业打印控件进行打印,如Grid++ Report控件。

       3、lodop打印控件。

  4、本文只是抛砖引玉的作用,欢迎大家补充。

作者: EricHu
出处: http://blog.csdn.net/chinahuyong
Email: 406590790@qq.com
QQ 交流:406590790 
QQ群:237326100
平台博客: 【CSDN】http://blog.csdn.net/chinahuyong
         【CNBLOGS】http://www.cnblogs.com/huyong
关于作者:高级工程师、信息系统项目管理师、DBA。专注于微软平台项目架构、管理和企业解决方案,多年项目开发与管理经验,曾多次组织并开发多个大型项目,精通DotNet,DB(SqlServer、Oracle等)技术。熟悉Java、Delhpi及Linux操作系统,有扎实的网络知识。在面向对象、面向服务以及数据库领域有一定的造诣。现从事DB管理与开发、WinForm、WCF、WebService、网页数据抓取以及ASP.NET等项目管理、开发、架构等工作。
如有问题或建议,请多多赐教!
本文版权归作者和CNBLOGS博客共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,如有问题,可以通过邮箱或QQ 联系我,非常感谢。

技术分享

本文出自 “.NET快速开发框架” 博客,请务必保留此出处http://yonghu.blog.51cto.com/8166136/1600936

DIFramework.NET ━ Web中打印的各种方案参考-欢迎补充

标签:c#   工作流   开发框架   报表   rdiframework.net   

原文地址:http://yonghu.blog.51cto.com/8166136/1600936

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!