Web系统页面打印技术实现与分析

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

Web系统页面打印技术实现与分析1Web页面打印概述应用WEB化,不论对开发商,还是对用户来说,实在是一种很经济的选择,因为基于WEB的应用,客户端的规则很简单,容易学习,容易维护,容易发布。在WEB系统中,打印的确是个烦人的问题。要么自己开发打印控件,如果项目时间紧,肯定来不及。这对程序员来说,因为浏览器的局限性,却要面对很多挑战。怎么样来进行基于WEB的套打,就是这么一个令多数程序员头痛不已的问题。基于WEB的套打,难度在于要将浏览器中呈现的HTML,精确地打印到票据中,而且能够实现对分页位置的控制。本文将介绍常用的Web打印与套打方案,同时提供一些免费的打印控件,供大家学习参考。2常用Web页面打印方案2.1浏览器的打印功能这种方案的优势是不需要对浏览器作任何扩充,是最简单的办法,但问题也最多,如:1.不能精确分页。浏览器一般是根据用户设置的页面大小,web页面的内容多少,来自行决定分页位置,程序员很难控制。会有页脚页眉干扰。2.不能准确对齐边边距及打印文字。3.不能解决连续打印。比如,不是仅打印一张票据,而是连续一次打印若干个票据。2.2使用PDF文件用这种方式,就是从服务器端下载一个pdf文件流,在IE中用adobe插件打开,然后用adobe的打印菜单进行打印,虽然这种方案,也能实现精确套打,但需要下载adobe插件。这是国外报表工具经常推荐的一种打印方法,但在pdf不那么普及的中国,这种方案不是最好选择。2.3采用Applet方式采用Applet方式,分页或精确打印,都可以做到完美,但缺点也很明显,表现在:1.安装Applet成本巨大。需要下载十几M的文件。Applet本身可能并不大,但运行Applet所需的jre一般至少10几M(jre1.4.2,15.45M)。用户需要极大的耐心,来进行打印。2.打印报表时,需要重新向服务器检索数据,效率低。因为Applet方案,一般采用html方式呈现数据,打印时Applet必须向服务器检索同一张票据的数据,看上去,是打印了当前页的票据,实际上,Applet根本不会用当前html页的数据来打印,而是向服务器下载数据到Applet中来打印。也就是说,打印的话,必须两次请求,一次html呈现,一次用来打印。市场上java类的报表工具,一般推荐Applet方式来实现打印。2.4IEWebBrowser+Javascript这实际上,是浏览器打印功能菜单的一种程序调用,与打印功能菜单没什么两样。分页的问题仍然存在,只不过,可以让用户不用去点菜单,直接在网页中的一个按钮,或一个链接里面调用罢了。2.5利用word或excel来实现先将需要打印的数据导入到word或者excel中,再利用word或者excel的打印功能来实现web打印。2.6使用第三方控件这种方案就是下载一个控件,票据的数据不再以html方式呈现,而是呈现在ActiveX中。这种方案的优点是打印的精确度高,分页的可控性好,但缺点也是很明显的,嵌入ActiveX控件破坏了web应用的整体html风格,且这样的控件比较大(一般超过1M),下载颇费时间)。市场上的非java类报表产品,一般都采用这种方案。3Web打印控件介绍3.1ScriptXScriptX是一个叫MeadCo的国外公司的产品,它分为基础版(免费)和高级版(收费),基础版可以对页眉,页脚,页边距,纸张方向进行设置。高级版有一些额外的功能,由于是收费的,需要付费以后才能用到你系统中.3.2DLPrinterDLPrinter打印控件完全免费,界面大方、使用简单、但无签名,支持打印预览、直接打印,可设置页眉、页脚、页边距、打印份数、纸张大小等信息。遗憾的是作者不知道是什么原因,从2007年至今没的更新。作者博客:下载地址:打印组件第2次更新2007-10-30:Bugfixed:1、在某些时候在调用PrintDirect的时候会出现错误,然后导致无限循环;2、不能正确的控制打印份数;3、在预览模式下,如果更改纸张走向,必须连续2次应用才可以显示最后1页。Newfunction:1、增加了CopyCount属性以控制打印份数;2、增加了预览模式下的性能。单击DLPrinter.cab以下载DLPrinter组件,请各位在下载后,把DLPrinter.cab.rar的文件名改为DLPrinter.cab,然后在使用,一下是应用示例:OBJECTID=DLPrinterCLASSID=CLSID:5C230622-45E5-4e3c-893C-3BFDDC4DB5E4codebase=DLPrinter.cabheight=0width=0/OBJECTscriptDLPrinter.MarginLeft=20;DLPrinter.MarginRight=20;DLPrinter.MarginTop=20;DLPrinter.MarginBottom=20;DLPrinter.CopyCount=2;DLPrinter.PageHeader=这是测试的页眉;DLPrinter.PageFooter=这是测试的页脚;DLPrinter.IsLandScape=1;//DLPrinter.ContentURL==buttonid=btnPrintvalue=PrintPreviewonclick=DLPrinter.PrintPreview()/inputtype=buttonid=btnPrintvalue=Printwithpromptonclick=DLPrinter.Print()/inputtype=buttonid=btnPrintvalue=Printwithoutpromptonclick=DLPrinter.PrintDirect()/3.3墙外打印控件墙外打印控件(QWPrint)是一款小巧的打印辅助软件,能够帮助众多制作B/S类程序的程序员更加灵活的控制客户端打印。功能特点:1)小巧轻便,客户端在第一次使用时只要下载一个ActiveX控件即可使用。2)控制多种打印设置。程序员可以通过控件进行多项设置,包括设置打纸的页边距,页眉页脚,纸张大小等参数。3)精确控制打印。可以方便实现web下的套打操作。作者博客:下载地址:墙外打印控件.rar3.4Lodop对于这个打印控件,用一个词来形容:强大!不仅调用方便,而且功能比你想像中要强大得多。更多介绍大家到作者博客详细了解。作者博客:下载地址:(商业)webprint使用简单,灵活.能满足绝大多数页面打印的需要.它内含一个在vc7.0上开发的ATL小控件(只有74k),这个小控件主要实现对IE浏览器中文档打印格式的控制,可以定制打印纸型,纸张来源,打印方向,设置表头,表尾,表格,表格列宽,打印预览,分页,缩放等等用户经常关心的属性。webprint使用户通过脚本可以控制自定义纸张,打印方向,页边距等等属性达到定制打印的目的,这些定制属性的设置不会改变IE浏览器的默认打印机属性。也可以通过服务器端的页面调用WebPrint生成客户端的页面达到设置打印参数的目的。技术特点:1)基于表格的页面打印解决方案2)采用了VC7.0开发的设置打印参数的小组件(仅75K),实现打印纸张,方向,页边距等等的自定义。3)采用了DHTML,不仅实现分页,换页重新打印标题,表头表尾等等,而且还实现了精确的放缩功能。4)因为将数据接口层定在标准的HTML元素这一层,所以适合所有在IE下运行的互联网程序,包括ASPJSPPHP和VS.net等等..5)使用简单方便,需要学习的东西很少.6)无须为webprint重新组织要打印的数据和样式,直接将显示的页面传入webprint即可实现数据和样式的打印.7)支持横向分页,分页时固定列重复打印.8)可以动态改变每页的标题.9)支持批打印,即一次打印多个打印作业.10)在同一个页面上可以打印多个报表.11)支持大数据量的打印.12)可以设置打印到某些行时强行分页.13)支持图片的打印.14)可以导出为Excel文件。4Web页面打印应用实例4.1Javascript自带函数ahref=javascript:window.print();打印/a4.2IEWebBrowser组件详细介绍参考:=kb%3BEN-US%3BQ267240#top=CLSID:8856F961-340A-11D0-A96B-00C04FD705A2height=0id=WebBrowserwidth=0/OBJECTinputname=ButtononClick=document.all.WebBrowser.ExecWB(1,1)type=buttonvalue=打开inputname=ButtononClick=document.all.WebBrowser.ExecWB(2,1)type=buttonvalue=关闭所有inputname=ButtononClick=document.all.WebBrowser.ExecWB(4,1)type=buttonvalue=另存为inputname=ButtononClick=document.all.WebBrowser.ExecWB(6,1)type=buttonvalue=打印inputname=ButtononClick=document.all.WebBrowser.ExecWB(6,6)type=buttonvalue=直接打印inputname=ButtononClick=document.all.WebBrowser.ExecWB(7,1)type=buttonvalue=打印预览inputname=ButtononClick=document.all.WebBrowser.ExecWB(8,1)type=buttonvalue=页面设置inputname=ButtononClick=document.all.WebBrowser.ExecWB(10,1)type=buttonvalue=属性inputname=ButtononClick=document.all.WebBrowser.ExecWB(17,1)type=buttonvalue=全选inputname=ButtononClick=document.all.WebBrowser.ExecWB(22,1)type=buttonvalue=刷新inputname=ButtononClick=document.all.WebBrowser.ExecWB(45,1)type=buttonvalue=关闭4.3通过Excel实现页面打印将网页中数据导入excel中的方法有很多,这里先介绍一种,利用ActiveX控件的方式,即Excel.Application,这个控件是MS为excel提供的编程接口,在很多种编程语言种都可以通过该

1 / 14
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功