摘自Web:
http://www.z6688.com/info/29300-1.htm
1. 实现打印功能
1) ExecWB()
通过脚本程序来调用IE菜单下面的打印命令。实现的代码如下:
<script language="javascript">
function printsetup(){ // 打印页面设置
wb.execwb(8,1);
}
function printpreview(){ // 打印页面预览
wb.execwb(7,1);
}
function printit() { //打印
if (confirm('确定打印吗?')) {
wb.execwb(6,1)
}
}
</script>
<OBJECT classid=CLSID:8856F961-340A-11D0-A96B-00C04FD705A2 height=0 id=wb width=0></OBJECT>
<input type=button name=button_print value="打印" onclick="javascript:printit()">
<input type=button name=button_setup value="页面设置" onclick="javascript:printsetup();">
<input type=button name=button_show value="打印预览" onclick="javascript:printpreview();">
<input type=button name=button_fh value="关闭" onclick="javascript:window.close();">
这个Object 其实就是 IEWebBrowser 设定 Width 和 Height 以后,我们在界面上就看不到控件的形状了,然后,我们就可以使用 这个object 实现我们选纸和预览的功能了。
关于这个组件还有其他的用法,列举如下:
l wb.ExecWB(1,1) 打开
l wb.ExecWB(2,1) 关闭现在所有的IE窗口,并打开一个新窗口
l wb.ExecWB(4,1) 保存网页
l wb.ExecWB(6,1) 打印
l wb.ExecWB(7,1) 打印预览
l wb.ExecWB(8,1) 打印页面设置
l wb.ExecWB(10,1) 查看页面属性
l wb.ExecWB(15,1) 好像是撤销,有待确认
l wb.ExecWB(17,1) 全选
l wb.ExecWB(22,1) 刷新
l wb.ExecWB(45,1) 关闭窗体无提示
2) document.execCommand()
<a href="#" onclick=document.execCommand("print")>打印</a>
3) window.print()
使用:javascript:window.Print()
Prints the contents of the window.
方法源
Window
实现版本
Navigator 4.0
语法:print()
参数:无
2. 实现套打功能:使用css
要实现去掉触发打印命令的本身按钮,只需要添加以下代码:
<STYLE MEDIA="print">
#btn1 {display: none}
#btn2 {display: none}
#btn3 {display: none}
#btn4 {display: none}
</STYLE>
然后在以上四个按钮中加上id,分别为:btn1、btn2、btn3、btn4。
<input type=button name=button_print value="打印" onclick="javascript:print()" id="btn1">
<input type=button name=button_setup value="页面设置" onclick="javascript:printsetup();" id="btn2">
<input type=button name=button_show value="打印预览" onclick="javascript:printpreview();" id="btn3">
<input type=button name=button_fh value="关闭" onclick="javascript:window.close();" id="btn4">
3. 去掉页眉页脚:使用JavaScript
<script language="JavaScript">
var hkey_root,hkey_path,hkey_key
hkey_root="HKEY_CURRENT_USER"
hkey_path=\\Software\\Microsoft\\Internet Explorer\\PageSetup\\
//设置网页打印的页眉页脚为空
function pagesetup_null(){
try{
var RegWsh = new ActiveXObject("WScript.Shell")
hkey_key="header"
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"")
hkey_key="footer"
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"")
}catch(e){}
}
//设置网页打印的页眉页脚为默认值
function pagesetup_default(){
try{
var RegWsh = new ActiveXObject("WScript.Shell")
hkey_key="header"
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"&w&b页码,&p/&P")
hkey_key="footer"
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"&u&b&d")
}catch(e){}
}
<Script>
4. 分页问题:使用css
<style type="text/css">
div.pageEnd {page-break-before:always}
</style>
然后在需要强制分页的地方用:
<div class="pageEnd">
待定页的内容
</div>
如果使用的是page-break-before,那么div的内容在后一页,
如果使用的是page-break-after,那么div的内容在前一页
page-break-after:检索或设置对象后出现的页分割符
语法: page-break-after : auto | always | avoid | left | right | null
参数:
l auto : 假如需要在对象之后插入页分割符
l always : 始终在对象之后插入页分割符
l avoid : 避免在对象后面插入页分割符
l left : 在对象后面插入页分割符直到它到达一个空白的左页边
l right : 在对象后面插入页分割符直到它到达一个空白的右页边
l null : 空值。IE5用来取消页分割符设置
示例: p { page-break-after: always;}
page-break-before:检索或设置对象前出现的页分割符
语法: page-break-before : auto | always | avoid | left | right | null
参数:
l auto : 假如需要在对象之前插入页分割符
l always : 始终在对象之前插入页分割符
l avoid : 避免在对象前面插入页分割符
l left : 在对象前面插入页分割符直到它到达一个空白的左页边
l right : 在对象前面插入页分割符直到它到达一个空白的右页边
l null : 空值。IE5用来取消页分割符设置
示例: p { page-break-after: always;}
5. 不弹出打印对话框:设置ExecWB的参数
<object ID="WebBrowser1" WIDTH="0" HEIGHT="0" CLASSID="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2">
</object>
<script language="javascript">
function print(){
WebBrowser1.ExecWB(6,1);
}
</script>
然后在页面里加一个按扭:
<input type=button name=print value="print" onclick="print()">
这样做,在按下按扭时会弹出窗口提示,如果不要提示,将第二个参数1改为6。
6、打印分页问题(css中的pagebreak可以控制)
pagebreak:在打印的时候强迫在样式控制的对象前后换页。
before:设置对象前出现的页分割符。设置为always时,始终在对象之前插入页分割符。相对应的css属性是”page-break-before”。
after:设置对象后出现的页分割符。设置为always时,始终在对象之后插入页分割符。相对应的css属性是”>。
用page-break-after
page-break-after版本:css2 兼容性:ie4+ 继承性:无
语法:
page-break-after : auto | always | avoid | left | right | null
取值:
auto : 假如需要在对象之后插入页分割符
always : 始终在对象之后插入页分割符
avoid : 未支持。避免在对象后面插入页分割符
left : 未支持。在对象后面插入页分割符直到它到达一个空白的左页边
right : 未支持。在对象后面插入页分割符直到它到达一个空白的右页边
null : 空白字符串。取消页分割符设置
说明:
检索或设置对象后出现的页分割符。
此属性在打印文档时发生作用。此属性不作用于 br 或 hr 对象。
假如在浏览器已显示的对象上此属性和 page-break-before 属性的值之间发生冲突,则导致最大数目分页的值被使用。
页分隔符不允许出现在定位对象内部。
在ie6及之前版本浏览器中, left 和 right 值的作用结果等同于 always 。
此属性对于 currentstyle 对象而言是只读的。对于其他对象而言是可读写的。
对应的脚本特性为 pagebreakafter 。
示例:
p { page-break-after: always;}
分享到:
相关推荐
用Javascript打印网页指定标签的内容 用Javascript打印网页指定标签的内容是指在网页上选择指定的标签,然后将其内容导出到另一个页面上,最后进行打印的操作。这种方法可以灵活地控制打印的内容和格式。下面将详细...
这个主题关于“Javascript打印乘法表”是JavaScript初学者常见的编程练习,它旨在帮助理解控制流、循环和字符串操作等基本概念。 乘法表是数学教育中的基础工具,用于展示1到10之间任意两个数字的乘积。使用...
然而,当我们谈论JavaScript打印时,情况略有不同。JavaScript的打印功能主要依赖于浏览器的内置支持。通过`window.print()`函数,用户可以立即触发浏览器的打印对话框,但这个默认行为通常不提供足够的自定义选项。...
### JavaScript打印方法:基于浏览器的详细代码示例 在网页开发中,JavaScript提供了一系列方法来实现页面内容的打印功能,这对于需要用户能够方便地将页面信息打印出来的应用场景尤为重要。本文将深入探讨几种常见...
JavaScript 打印自定义纸张大小 本文档讨论了使用 JavaScript 实现自定义纸张大小的打印方法,并解决了页脚、页眉、横向和纵向的问题。同时,本文还介绍了使用 IE 的 WebBrowser控件来实现打印预览和设置打印纸张...
根据提供的文件信息,本文将详细解释如何在ASP.NET应用程序中通过JavaScript实现页面打印功能,并针对IE浏览器进行特别优化。此方法适用于需要用户直接从网页上打印特定内容的应用场景。 ### ASP.NET 调用 ...
### IE Javascript 打印功能详解 #### 一、引言 在B/S(浏览器/服务器)架构下,Web应用程序中的打印功能与传统的桌面应用程序存在显著差异。由于程序运行于浏览器中,而打印机位于用户端,这导致了打印文档时的...
javascript打印网页中指定部分的内容
JavaScript打印实现逻辑
JavaScript打印水仙花数
### JavaScript 打印功能自定义纸张大小及更多设置 #### 概述 本文档主要讲解如何使用JavaScript来实现网页内容的打印,并且能够自定义纸张大小、方向以及页眉页脚等设置。这对于需要精确控制打印效果的场景非常...
2. lodop:lodop是一个用于Web打印的JavaScript打印控件,支持在Web页面上实现套打和票据打印等功能。它提供了一个丰富的API,允许开发者在不弹出打印对话框的情况下,直接调用打印机进行打印。它支持多种操作系统和...
在文件中还提到了一个名为“factory.printing”的对象,这部分内容看起来是从一个名为“ScriptX”的第三方JavaScript打印控件中获取的。ScriptX是一个基于ActiveX的打印库,它允许开发者通过脚本进行更高级的打印...
JavaScript 实现页面打印 本文将介绍使用 JavaScript 实现页面打印的方法,并提供相关的代码示例。 一、使用 ExecWB() 函数实现打印 ExecWB() 函数是 IE 浏览器提供的一个函数,可以用来调用 IE 菜单下的打印命令...
JavaScript打印插件是一种用于网页应用中的工具,它允许开发者通过JavaScript代码来控制打印功能,而无需用户离开当前页面或打开新的浏览器窗口。这种技术在网页报告、文档预览和在线发票等场景中非常常见,因为它...
birt脚本调试代码,只需要将代码放进文档中说明的位置,所有javascript调试打印结果都可以看到,提供了两种方式javascript的调试打印,网上也有很多例子说需要放到tomcat里才能打印,其实在报表开发工具中也可以打印...
根据给定文件的信息,本文将详细介绍如何使用JSP与JavaScript来实现九九乘法表的打印功能,并分别探讨这两种方法的具体实现步骤。 ### JSP 表达式方式 #### 实现原理 在JSP(JavaServer Pages)中,可以通过内嵌...
### JavaScript 打印控制知识点详解 #### 一、引言 在Web开发中,经常会遇到需要为用户提供打印功能的需求。然而,在打印过程中如何隐藏页面上的一些元素(如导航栏、广告等),仅打印用户真正关心的信息,则是一...
JavaScript是Web开发中的一种重要脚本语言,它允许开发者在客户端执行动态操作,包括与用户的交互、数据处理以及,如本题所示,实现网页打印功能。网页打印是将网页内容输出到打印机或创建PDF文档的过程,这对于用户...
一个javascript函数,可打印出所有的对象(包括数组),方便页面调试