web⽹页打印的⽅法(浏览器通⽤)
应⽤web化,不论对开发商,还是对⽤户来说,实在是⼀种很经济的选择,因为基于 web的应⽤,客户端的规则很简单,容易学习,容易维护,容易发布。但对程序员来说,因为浏览器的局限性,却要⾯对很多挑战。怎么样来进⾏基于web的套打,就是这么⼀个令多数程序员头痛不已的问题。
基于web的套打,难度在于要将浏览器中呈现的html,精确地打印到票据中,⽽且能够实现对分页位置的控制。下⾯就ie浏览器所能采⽤的套打解决⽅案,来个汇总分析,希望对⼤家有所帮助。
功能特点:
真正免费,不加⽔印,没有ip或域名限制,不限时间,兼容ie6+
⽆须注册,下载即⽤
提供经过微软数字签名的cab⾃动安装包,安装更⽅便
长期升级保障,免费论坛⽀持,让你⽆后顾之忧
稳定可靠,启动速度远胜同类产品
常⽤功能集于⼀⾝,简约⽽不简单,软件⼤⼩只有84k
本⽂主要介绍jatoolsPrinter打印控件来完成web的打印功能,这个控件已经把打印功能封装的⾮常好,主要是把这个控件引⼊,之后写⼀些简单的js代码就能完成相应的打印功能。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="/1999/xhtml">
<head runat="server">
<title></title>
<!-- 插⼊打印控件 -->
<object id="jatoolsPrinter" classid="CLSID:B43D3361-D075-4BE2-87FE-0571********"
codebase="jatoolsPrinter.cab#version=5,7,0,0">
</object>
<script type="text/javascript">
function doPrint(how) {
//打印⽂档对象
var myDoc = {
documents: document, // 打印页⾯(div)们在本⽂档中
copyrights: '杰创软件拥有版权 www.jatools' // 版权声明必须
};
// 调⽤打印⽅法
if (how == '打印预览...')
jatoolsPrinter.printPreview(myDoc); // 打印预览
else if (how == '打印...')
jatoolsPrinter.print(myDoc, true); // 打印前弹出打印设置对话框
else
jatoolsPrinter.print(myDoc, false); // 不弹出对话框打印
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div id='page1' style='width:300px;height:300px;'>
test
</div>
<input type="button" value="打印预览..." onclick="doPrint('打印预览...')"/>
<input type="button" value="打印..." onclick="doPrint('打印...')"/>
<input type="button" value="打印" onclick="doPrint('打印')"/>
</form>
</body>
</html>
主要分⼏个步骤:
⼀、引⼊打印控件jatoolsPrinter
<!-- 插⼊打印控件 --> <object id="jatoolsPrinter" classid="CLSID:B43D3361-D075-4BE2-87FE-0571********" codebase="jatoolsPrinter.cab#version=5,7,0,0"> </object>⼆、给要打印的div取id名
三、编写js代码实现打印div的功能
(注意:在同⼀页⾯中,有多个可打印⽂档,他们可以⽤page_div_prefix属性来区别page_div_prefix前缀+page+页序号构成可打印div的id,如前缀为 'report1' ,则到以 'report1page1'为id的div作为⽂档⾸页该属性,默认值为空)
注意事项:
1. 控件在打印指定div对象时,如果纸张太⼩不够打印时,超出部分将被截掉(clip)。
2. 被指定的div中的内容,可以是html任何可见对象,图⽚,flash,或⽂本等等。
3. 控件打印时,边距可设,不设则取打印机默认值。
4. div的id必须连续,如果你的div,存在 'page1'、'page2'、'page4',⽽不存在'page3',则控件只打印前两页,'page4'不会被打印。
5. div对象在页⾯中的位置,可以是随意的,⽐如,page1显⽰在page2后⾯,也是合法的。
6. 指定的div会被打印,没被指定的html元素将不会被打印,⽐如,本⽰例中的‘打印’按钮,不会被打印。
7. copyrights属性是版权信息,必须写。浏览web是什么意思
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论