js控制web打印(局部打印)方法整理


Posted in Javascript onMay 29, 2013

首先定义css样式:

@media print { 
.noprint { display: none;color:green } 
}

对于不想打印的内容只用在标签中加上 class=noprint即可,打印的时候客户也不会看到页面任何变化。
打印时调用 window.print();

另外几种js局部打印的方法:
移花接木:
打印的时候,把需要打印的内容替换成整个body内容(用户会在打印的时候看到变化,客户体验不太好)

function preview(oper) 
......{ 
if (oper < 10)......{ 
bdhtml=window.document.body.innerHTML;//获取当前页的html代码 
sprnstr="<!--startprint"+oper+"-->";//设置打印开始区域 
eprnstr="<!--endprint"+oper+"-->";//设置打印结束区域 
prnhtml=bdhtml.substring(bdhtml.indexOf(sprnstr)+18); //从开始代码向后取html 
prnhtml=prnhtml.substring(0,prnhtml.indexOf(eprnstr));//从结束代码向前取html 
window.document.body.innerHTML=prnhtml; 
window.print(); 
window.document.body.innerHTML=bdhtml; 
} else ......{ 
window.print(); 
} 
}

使用很简单 将页面内要打印的内容加入中间<!--startprint1-->XXXXX<!--endprint1-->
再加个打印按纽 onclick=preview(1)
-----------------------------------------
WebBrowser是IE内置的浏览器控件,无需用户下载.(未实验)
一、WebBrowser控件
<object ID='WebBrowser' WIDTH=0 HEIGHT=0 CLASSID='CLSID:8856F961-340A-11D0-A96B-00C04FD705A2'></object>

二、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.ExecWB(45,1) 关闭窗体无提示
但是打印是会把整个页面都打印出来的,页面里面有什么东西就打印出来,我们有时候只需要打印数据表格,这时我们就要写一个样式了:把不想打印的部份隐藏起来:
样式内容:
<style type="text/css" media=print> 
.noprint......{display : none } 
</style>

然后使用样式就可以:
<p class="noprint">不需要打印的地方</p>
代码如下:
<script language="javascript"> 
function printsetup()......{ 
// 打印页面设置 
wb.execwb(8,1); 
} 
function printpreview()......{ 
// 打印页面预览 
wb.execwb(7,1); 
} 
function printit() 
....{ 
if (confirm('确定打印吗?')) ......{ 
wb.execwb(6,6) 
} 
} 
</script> 
<OBJECT classid="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2" height=0 id=wb name=wb width=0></OBJECT> 
<input type=button name=button_print value="打印" class="noprint" onclick="javascript:printit()"> 
<input type=button name=button_setup value="打印页面设置" class="noprint" onclick="javascript:printsetup();"> 
<input type=button name=button_show value="打印预览" class="noprint" onclick="javascript:printpreview();">
Javascript 相关文章推荐
基于prototype的validation.js发布2.3.4新版本,让你彻底脱离表单验证的烦恼
Dec 06 Javascript
javascript入门·动态的时钟,显示完整的一些方法,新年倒计时
Oct 01 Javascript
javascript数组的扩展实现代码集合
Jun 01 Javascript
js 鼠标点击事件及其它捕获
Jun 04 Javascript
js下获得客户端操作系统的函数代码(1:vista,2:windows7,3:2000,4:xp,5:2003,6:2008)
Oct 31 Javascript
兼容Firefox的Javascript XSLT 处理XML文件
Dec 31 Javascript
DropDownList实现可输入可选择(两种版本可选)
Dec 07 Javascript
js中的DOM模拟购物车功能
Mar 22 Javascript
vue2.0结合Element实现select动态控制input禁用实例
May 12 Javascript
vue+element实现批量删除功能的示例
Feb 28 Javascript
使用jQuery实现掷骰子游戏
Oct 24 jQuery
JS动态图片的实现方法完整示例
Jan 13 Javascript
js动态为代码着色显示行号
May 29 #Javascript
js判断背景图片是否加载成功使用img的width实现
May 29 #Javascript
jQuery JSON实现无刷新三级联动实例探讨
May 28 #Javascript
jQuery实现随意改变div任意属性的名称和值(部分原生js实现)
May 28 #Javascript
js仿百度有啊通栏展示效果实现代码
May 28 #Javascript
jquery实现商品拖动选择效果代码(自写)
May 28 #Javascript
兼容IE和FF的图片上传前预览js代码
May 28 #Javascript
You might like
通用PHP动态生成静态HTML网页的代码
2010/03/04 PHP
PHP新手入门学习方法
2011/05/08 PHP
php中0,null,empty,空,false,字符串关系的详细介绍
2013/06/20 PHP
php面向对象与面向过程两种方法给图片添加文字水印
2015/08/26 PHP
如何解决PHP使用mysql_query查询超大结果集超内存问题
2016/03/14 PHP
php使用环形链表解决约瑟夫问题完整示例
2018/08/07 PHP
JQuery.closest(),parent(),parents()寻找父结点
2012/02/17 Javascript
使用CamanJS在Web页面上处理图像的技巧
2015/08/18 Javascript
全面解析bootstrap格子布局
2016/05/22 Javascript
浅谈JavaScript中变量和函数声明的提升
2016/08/09 Javascript
bootstrap手风琴制作方法详解
2017/01/11 Javascript
原生js实现淘宝购物车功能
2020/06/23 Javascript
JSONP基础知识详解
2017/03/19 Javascript
获取当前按钮或者html的ID名称实例(推荐)
2017/06/23 Javascript
JavaScript判断变量名是否存在数组中的实例
2017/12/28 Javascript
JavaScript刷新页面的几种方法总结
2019/03/28 Javascript
Nuxt.js实战和配置详解
2019/08/05 Javascript
javascript中的数据类型检测方法详解
2019/08/07 Javascript
vue 实现websocket发送消息并实时接收消息
2019/12/09 Javascript
Python内置的字符串处理函数整理
2013/01/29 Python
解决Python中由于logging模块误用导致的内存泄露
2015/04/23 Python
python基于socket实现网络广播的方法
2015/04/29 Python
在Python的Django框架下使用django-tagging的教程
2015/05/30 Python
Python操作mongodb数据库进行模糊查询操作示例
2018/06/09 Python
Python的条件表达式和lambda表达式实例
2019/01/31 Python
Python中单线程、多线程和多进程的效率对比实验实例
2019/05/14 Python
如何基于Python批量下载音乐
2019/11/11 Python
Python读取VOC中的xml目标框实例
2020/03/10 Python
Zalando Lounge瑞士:时尚与生活方式购物俱乐部
2020/03/12 全球购物
架构师岗位职责
2013/11/18 职场文书
党员个人剖析材料(四风问题)
2014/10/07 职场文书
地道战观后感2000字
2015/06/04 职场文书
子女赡养老人协议书
2016/03/23 职场文书
人为什么会“幸灾乐祸”?
2019/08/06 职场文书
百善孝为先:关于孝道的经典语录
2019/10/18 职场文书
MySQL Server层四个日志的实现
2022/03/31 MySQL