首页 > 开发 > 综合 > 正文

WEB打印的相关技术分析

2024-07-21 02:21:16
字体:
来源:转载
供稿:网友
web打印的相关技术分析

现有的web打印控制技术分成几种方案

  自定义控件完成打印

  利用ie自带的webbrowser控件实现打印

  利用第三方控件实现打印

以下主要谈前两个方面的内容



一、 自定义控件方式

自定义控件方式就是利用vb或vc等工具生成com组件,用定义好的打印格式来分析打印源文件从而实现打印。只有将生成的组件下载并注册到客户机上,才能实现在客户端的打印。

难点主要是定义打印格式、如何来分析打印源文件。现有的比较好的方法是利用xml技术来全面的解决问题,利用xml可以非常容易地定义打印目标的文本、表格等内容的格式。但对程序员的开发要求高,难度比较大。



二、 利用webbrowser实现web打印

webbrowser是ie内置的浏览器控件,无需用户下载。本文档所讨论的是有关ie6.0版本的webbrowser控件技术内容。与其相关的技术要求有:打印文档的生成、页面设置、打印操作的实现等几个环节。



(一)、 打印文档的生成

1、 客户端脚本方式

客户端脚本分为vbscript、javascript、jscript几种脚本语言。在ie下开发应用使用的语法为jscript的语法,由于它和javascript几乎没有什么区别,所以也可以称其为javascript(下面简写为js)。一般情况下,主要使用js来实现dom文档的分析,dom为微软提出的一种web文档模型,主要用来实现web脚本编程。

利用js可以分析源页面的内容,将欲打印的页面元素提取出来,实现打印。通过分析源文档的内容,可以生成打印目标文档。



优点:客户端独立完成打印目标文档的生成,减轻服务器负荷;

缺点:源文档的分析操作复杂,并且源文档中的打印内容要有约定;



2、 服务器端程序方式

服务器端程序方式,主要是利用后台代码从数据库中读取打印源,生成打印目标文档。当的页面生成时,还应适当考虑使用css来实现强制分页控制。



优点:可以生成内容非常的丰富的打印目标文档,目标文档的内容的可控性强。由于打印内容是从数据库中获取的,所以生成操作相对简单;

缺点:服务器端负载比较大;



(二)、 页面设置

页面设置主要是指设置打印文档的页边距、页眉、页脚、纸张等内容。页面设置将直接影响到打印文档版面的生成效果,所以它和打印文档的生成有着密切的关系。比如:表格的行数、大小、位置、字体的大小等。

现有的技术是利用ie6.0内置的打印模板方式来控制页面设置,其可以对打印目标文档产生非常大的影响。打印模板可以控制页边距、页眉、页脚、奇偶页等内容,并可以将用户的设置取得,还可以将设置发送到服务器端。

打印模板技术可以自定预览窗口和打印格式,最大限度地影响目标文档和打印效果。



(三)、 打印操作的实现

此功能的实现主要是利用webbrowser控件的函数接口来实现打印、打印预览(默认的)、页面设置(默认的)。

<object id='webbrowser1' width=0 height=0

classid='clsid:8856f961-340a-11d0-a96b-00c04fd705a2'>

//打印

webbrowser1.execwb(6,1);

//打印设置

webbrowser1.execwb(8,1);

//打印预览

webbrowser1.execwb(7,1);



三、 本项目采用的打印方案

服务器端程序方式、打印预览接口调用,下面为例,主要参考项目中的:pageerrorprint.aspx.vb文件

主调用页

function printpage(ipageindex,strquery)

{

var strurl;

strurl = "pageerrorprint.aspx?pageindex=" + ipageindex + "&querystring=" + strquery;

winprint=window.open(strurl,"","left=2000,top=2000,fullscreen=3");

}



打印页html源中的预览控制

<script language="javascript">

document.write("<object id='webbrowser' width=0 height=0

classid='clsid:8856f961-340a-11d0-a96b-00c04fd705a2'></object>");

webbrowser.execwb(7,1);

window.opener=null;

window.close();

</script>





程序头

'首先声明表格容器

protected withevents phcontainer as system.web.ui.webcontrols.placeholder

'每个表格中的记录数量

private const itempertable as integer = 20





关键的实现部分

'创建一个符合打印要求的表格

tabpageprint = newprinttable()

'将表头添加到此表格中

call addtabletitle(tabpageprint)



'初始化记录器

i = 0

iitemindex = istartpoint

for each clsitem in clsalldata.errorcollection

if i > 0 and i mod itempertable = 0 then

'添加表格控件到页面中

phcontainer.controls.add(tabpageprint)

'在页面中添加一个换行符

call addpagebreak()



'创建新一轮的表格

tabpageprint = newprinttable()

call addtabletitle(tabpageprint)

end if



'将记录添加到表格中

call additemtotable(iitemindex, tabpageprint, clsitem)

iitemindex = iitemindex + 1

i = i + 1

next



'添加表格控件到页面中

phcontainer.controls.add(tabpageprint)





支持函数

'功能:添加页的换行符

private sub addpagebreak()

dim ltbreak as literalcontrol



ltbreak = new literalcontrol("<p style='page-break-before:always'>")

phcontainer.controls.add(ltbreak)

end sub



'功能:创建一个符合打印要求的表格

private function newprinttable() as table

dim tabsrc as new table()



tabsrc.width = unit.percentage(100)

tabsrc.attributes("border") = "1"

tabsrc.cellpadding = 4

tabsrc.cellspacing = 0

tabsrc.borderwidth = unit.pixel(2)

tabsrc.bordercolor = color.black

tabsrc.style.add("font-size", "12px")

newprinttable = tabsrc

end function


摘自csdn论坛

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表