Web系统页面打印技术实现与分析_第1页
Web系统页面打印技术实现与分析_第2页
Web系统页面打印技术实现与分析_第3页
Web系统页面打印技术实现与分析_第4页
Web系统页面打印技术实现与分析_第5页
已阅读5页,还剩9页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

Web系统页面打印技术实现与分析1 Web页面打印概述应用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.4 IEWebBrowser+Javascript这实际上,是浏览器打印功能菜单的一种程序调用,与打印功能菜单没什么两样。分页的问题仍然存在,只不过,可以让用户不用去点菜单,直接在网页中的一个按钮,或一个链接里面调用罢了。2.5 利用word或excel来实现先将需要打印的数据导入到word或者excel中,再利用word或者excel的打印功能来实现web打印。2.6 使用第三方控件这种方案就是下载一个控件,票据的数据不再以html方式呈现,而是呈现在ActiveX中。这种方案的优点是打印的精确度高,分页的可控性好,但缺点也是很明显的,嵌入ActiveX控件破坏了web应用的整体html风格,且这样的控件比较大(一般超过1M),下载颇费时间)。市场上的非java类报表产品,一般都采用这种方案。3 Web打印控件介绍3.1 ScriptXScriptX是一个叫MeadCo的国外公司的产品,它分为基础版(免费)和高级版(收费),基础版可以对 页眉,页脚,页边距,纸张方向进行设置。高级版有一些额外的功能,由于是收费的,需要付费以后才能用到你系统中.3.2 DLPrinterDLPrinter打印控件完全免费,界面大方、使用简单、但无签名,支持打印预览、直接打印,可设置页眉、页脚、页边距、打印份数、纸张大小等信息。遗憾的是作者不知道是什么原因,从2007年至今没的更新。作者博客:/Yahong111/下载地址:/panshenglu/DLPrinter.rarLPrinter WEB打印组件第2次更新2007-10-30: Bug fixed: 1、在某些时候在调用PrintDirect的时候会出现错误,然后导致无限循环; 2、不能正确的控制打印份数; 3、在预览模式下,如果更改纸张走向,必须连续2次应用才可以显示最后1页。 New function: 1、增加了CopyCount属性以控制打印份数; 2、增加了预览模式下的性能。 单击DLPrinter.cab以下载DLPrinter组件,请各位在下载后,把DLPrinter.cab.rar的文件名改为DLPrinter.cab,然后在使用,一下是应用示例: DLPrinter.MarginLeft=20; DLPrinter.MarginRight=20; DLPrinter.MarginTop=20; DLPrinter.MarginBottom=20; DLPrinter.CopyCount=2; DLPrinter.PageHeader=这是测试的页眉; DLPrinter.PageFooter=这是测试的页脚; DLPrinter.IsLandScape=1; /DLPrinter.ContentURL=/Yahong111/archive/2007/09/19/898326.html;3.3 墙外打印控件墙外打印控件(QWPrint)是一款小巧的打印辅助软件,能够帮助众多制作B/S类程序的程序员更加灵活的控制客户端打印。功能特点:1) 小巧轻便,客户端在第一次使用时只要下载一个ActiveX控件即可使用。2) 控制多种打印设置。程序员可以通过控件进行多项设置,包括设置打纸的页边距,页眉页脚,纸张大小等参数。3) 精确控制打印。可以方便实现web下的套打操作。作者博客:/下载地址:/panshenglu/墙外打印控件.rar3.4 Lodop对于这个打印控件,用一个词来形容:强大!不仅调用方便,而且功能比你想像中要强大得多。更多介绍大家到作者博客详细了解。作者博客:/caoyanqingwebsite/下载地址:/panshenglu/lodop4.0.zip3.5 WebPrint(商业)webprint使用简单,灵活.能满足绝大多数页面打印的需要.它内含一个在vc7.0上开发的ATL小控件(只有74k),这个小控件主要实现对IE浏览器中文档打印格式的控制,可以定制打印纸型,纸张来源,打印方向,设置表头,表尾,表格,表格列宽,打印预览,分页,缩放等等用户经常关心的属性。 webprint使用户通过脚本可以控制自定义纸张,打印方向,页边距等等属性达到定制打印的目的,这些定制属性的设置不会改变IE浏览器的默认打印机属性。也可以通过服务器端的页面调用WebPrint生成客户端的页面达到设置打印参数的目的。技术特点:1) 基于表格的页面打印解决方案2) 采用了VC7.0开发的设置打印参数的小组件(仅75K),实现打印纸张,方向,页边距等等的自定义。3) 采用了DHTML, 不仅实现分页,换页重新打印标题,表头表尾等等,而且还实现了精确的放缩功能。4) 因为将数据接口层定在标准的HTML元素这一层,所以适合所有在IE下运行的互联网程序,包括ASP JSP PHP和VS.net等等.5) 使用简单方便,需要学习的东西很少.6) 无须为webprint重新组织要打印的数据和样式,直接将显示的页面传入webprint即可实现数据和样式的打印.7) 支持横向分页,分页时固定列重复打印.8) 可以动态改变每页的标题.9) 支持批打印,即一次打印多个打印作业.10) 在同一个页面上可以打印多个报表.11) 支持大数据量的打印.12) 可以设置打印到某些行时强行分页.13) 支持图片的打印.14) 可以导出为Excel文件。4 Web页面打印应用实例4.1 Javascript自带函数打印4.2 IEWebBrowser组件详细介绍参考:/default.aspx?scid=kb%3BEN-US%3BQ267240#top/kb/q247671/#appliesto4.3 通过Excel实现页面打印将网页中数据导入excel中的方法有很多,这里先介绍一种,利用ActiveX控件的方式,即 Excel.Application, 这个控件是MS为excel提供的编程接口,在很多种编程语言种都可以通过该接口来操纵excel表格。下面用javascript脚本来实现一个简单的例子。function ExcelPrint()var excelApp;/存放Excel对象var excelBook;/存放Excel工件簿文件var excelSheet;/存放Excel活动工作表tryexcelApp = new ActiveXObject(Excel. Application);/创建Excel对象catch(e)alert(请启用ActiveX控件设置!);return;excelBook = excelApp.Workbooks.Add();/创建Excel工作簿文件excelSheet = excelBook.ActiveSheet;/激活Excel工作表var rowLen = printTable.rows.length;/table对象的行数for (var i=0;i rowLen;i+)var colLen = printTable.rows(i).cells.length;/table对象的列数for (var j=0;j colLen;j+)/为Excel表的单元格赋值excelSheet.Cells(i+1,j+1).value = printTable.rows(i).cells(j).innerText; /将表格中的每个单元格的innerText导入到excel的单元格中excelApp.Visible = true;/设置Excel对象可见excelSheet.PrintOut(); /打印工作表excelBook.Close(true); /关闭文档excelApp.Quit(); /结束excel对象excelApp=null; /释放excel对象注意:运行该程序的前提是 IE要允许对没有标记为安全的Activex控件进行初始化和脚本运行。设置方法如下:打开控制面板Internet选项安全性自定义级别对没有标记为安全的ActiveX控件进行初始化和脚本运行选中启用,这样我们的程序就可以 运行了。如果没有启用该ActiveX控件设置,那么程序在执行创建Excel对象时会抛出一个异常,这时可以通过catch()语句来捕获这个异常,并 且做出相应的处理。 运行该程序必须客户端安装了MS EXCEL,否则Activex驱动不了。4.4 使用ScriptX控件1. 下载ScriptX.cab控件官网地址:/scriptx/index.asp2. 使用object元素,修改codebase,classid的值,调用控件ScriptX.cab这段代码用来加载cab文件,clsid和codebase必须要和你下载的cab中的信息对应,否则组件会加载错误,这两项其实不难找,只要你用winrar打开你下载的cab文件,然后找到扩展名是.inf的文件,然后打开之,就能看到了。3. 调用控件JS脚本function setPrintBase(headerText,footerText,rootUrl) / - advanced features ,未曾使用过,有待确认。/factory.printing.SetMarginMeasure(2); / measure margins in inches/factory.SetPageRange(false, 1, 3);/ need pages from 1 to 3/factory.printing.printer = HP DeskJet 870C;/factory.printing.copies = 2;/factory.printing.collate = true;/factory.printing.paperSize = A4;/factory.printing.paperSource = Manual feedvar header = (headerText=null|headerText=)?默认页眉:headerText;var footer = (footerText=null|footerText=)?默认页角:footerText;factory.printing.header = &b+header+&b ;factory.printing.footer = &b+footer;factory.printing.portrait = true;factory.printing.leftMargin =10.00;factory.printing.topMargin =10.00;factory.printing.rightMargin =10.00;factory.printing.bottomMargin =10.00;4. 应用实例.Noprint DISPLAY: none;打印测试function window.onload() setPrintBase(页眉,页脚);内容5 Web页面打印技巧5.1 隐藏打印的Web元素web打印去掉页眉页脚,以及不想打印出的页面元素function printpr() /预览函数document.all(qingkongyema).click();/打印之前去掉页眉,页脚document.all(dayindiv).style.display=none; /打印之前先隐藏不想打印输出的元素(此例中隐藏“打印”和“打印预览”两个按钮)var olecmdid = 7;var prompt = 1;var webbrowser = ;document.body.insertadjacenthtml(beforeend, webbrowser);webbrowser1.execwb(olecmdid, prompt);webbrowser1.outerhtml = ;document.all(dayindiv).style.display=;/打印之后将该元素显示出来(显示出“打印”和“打印预览”两个按钮,方便别人下次打印)function printture() /打印函数document.all(qingkongyema).click();/同上document.all(dayindiv).style.display=none;/同上window.print();document.all(dayindiv).style.display=;function dopage()layloading.style.display = none;/同上dim hkey_root,hkey_path,hkey_keyhkey_root=hkey_current_userhkey_path=softwaremicrosoftinternet explorerpagesetup/设置网页打印的页眉页脚为空function pagesetup_null()on error resume nextset regwsh = createobject(wscript.shell)hkey_key=headerregwsh.regwrite hkey_root+hkey_path+hkey_key,hkey_key=footerregwsh.regwrite hkey_root+hkey_path+hkey_key,end function/设置网页打印的页眉页脚为默认值function pagesetup_default()on error resume nextset regwsh = createobject(wscript.shell)hkey_key=headerregwsh.regwrite hkey_root+hkey_path+hkey_key,&w&b页码,&p/&phkey_key=footerregwsh.regwrite hkey_root+hkey_path+hkey_key,&u&b&dend function你希望打印的内容.5.2 实现简单的页面局部打印5.2.1 Javascript实现function preview(oper).if (oper 10).bdhtml=window.document.body.innerHTML;/获取当前页的html代码sprnstr=;/设置打印开始区域eprnstr=;/设置打印结束区域prnhtml=bdhtml.substring(bdhtml.indexOf(sprnstr)+18); /从开始代码向后取htmlprnhtml=prnhtml.substring(0,prnhtml.indexOf(eprnstr);/从结束代码向前取htmlwindow.document.body.innerHTML=prnhtml;window.print();window.document.body.innerHTML=bdhtml; else .window.print();使用很简单 将页面内要打印的内容加入中间XXXXX再加个打印按纽 onclick=preview(1)5.2.2 WebBrowser实现1. WebBrowser控件2. WebBrowder控件的方法/打印WebBrowser1.ExecWB(6,1);/打印设置WebBrowser1.ExecWB(8,1);/打印预览WebBrowser1.ExecWB(7,1);关于这个组件还有其他的用法,列举如下:WebBrowser.ExecWB(1,1) 打开Web.ExecWB(2,1) 关闭现在所有的IE窗口,并打开一个新窗口Web.ExecWB(4,1) 保存网页Web.ExecWB(6,1) 打印Web.ExecWB(7,1) 打印预览Web.ExecWB(8,1) 打印页面设置Web.ExecWB(10,1) 查看页面属性Web.ExecWB(15,1) 好像是撤销,有待确认Web.ExecWB(17,1) 全选Web.ExecWB(22,1) 刷新Web.

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论