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 相关文章推荐
javaScript Array(数组)相关方法简述
Jul 25 Javascript
jQuery 表单验证扩展代码(一)
Oct 11 Javascript
关于jQuery中.attr()和.prop()的问题探讨
Sep 06 Javascript
js特殊字符转义介绍
Nov 05 Javascript
javascript中AJAX用法实例分析
Jan 30 Javascript
由简入繁实现Jquery树状结构的方法(推荐)
Jun 10 Javascript
angular+ionic 的app上拉加载更新数据实现方法
Jan 16 Javascript
解决html input验证只能输入数字,不能输入其他的问题
Jul 21 Javascript
使用nvm和nrm优化node.js工作流的方法
Jan 17 Javascript
微信内置开发 iOS修改键盘换行为搜索的解决方案
Nov 06 Javascript
详解用js代码触发dom事件的实现方案
Jun 10 Javascript
JavaScript 中for/of,for/in 的详细介绍
Nov 17 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
ThinkPHP中U方法的使用浅析
2014/06/13 PHP
PHP实现简单的新闻发布系统实例
2015/07/28 PHP
php+ajax简单实现全选删除的方法
2016/12/06 PHP
PHP的微信支付接口使用方法讲解
2019/03/08 PHP
YUI 读码日记之 YAHOO.util.Dom - Part.1
2008/03/22 Javascript
网页中CDATA标记的说明
2010/09/12 Javascript
基于Jquery的仿Windows Aero弹出窗(漂亮的关闭按钮)
2010/09/28 Javascript
写给想学习Javascript的朋友一点学习经验小结
2010/11/23 Javascript
打造基于jQuery的高性能TreeView(asp.net)
2011/02/23 Javascript
jQuery ajax serialize()方法的使用以及常见问题解决
2013/01/27 Javascript
在javascript中对于DOM的加强
2013/04/11 Javascript
关于jquery.validate1.9.0前台验证的使用介绍
2013/04/26 Javascript
JavaScript-RegExp对象只能使用一次问题解决方法
2014/06/23 Javascript
基于javascript简单实现对身份证校验
2021/01/25 Javascript
jQuery实现iframe父窗体和子窗体的相互调用
2016/06/17 Javascript
AngularJS模块详解及示例代码
2016/08/17 Javascript
浅谈js中的引用和复制(传值和传址)
2016/09/18 Javascript
JavaScript排序算法动画演示效果的实现方法
2016/10/18 Javascript
Node.js API详解之 dgram模块用法实例分析
2020/06/05 Javascript
JavaScript逻辑运算符相关总结
2020/09/04 Javascript
[15:15]教你分分钟做大人:狙击手
2014/10/30 DOTA
[01:21]2018DOTA2亚洲邀请赛4.5采访 打DOTA2也能有女朋友?
2018/04/06 DOTA
python实现在windows服务中新建进程的方法
2015/06/30 Python
用python实现的线程池实例代码
2018/01/06 Python
3分钟学会一个Python小技巧
2018/11/23 Python
Python selenium自动化测试模型图解
2020/04/15 Python
keras训练浅层卷积网络并保存和加载模型实例
2020/07/02 Python
澳大利亚网上玩具商店:Mr Toys Toyworld
2018/03/25 全球购物
Trip.com澳大利亚:在线旅行社
2019/12/01 全球购物
大学生专科毕业生自我评价
2013/11/17 职场文书
药店促销活动策划方案
2014/08/24 职场文书
法定代表人身份证明书
2014/09/10 职场文书
乡镇领导干部个人对照检查材料思想汇报
2014/09/23 职场文书
2014年导购员工作总结
2014/11/18 职场文书
2015年世界水日活动总结
2015/02/09 职场文书
python APScheduler执行定时任务介绍
2022/04/19 Python