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中常用的55个经典技巧
Aug 12 Javascript
Javascript客户端将指定区域导出到Word、Excel的代码
Oct 22 Javascript
如何在一个页面显示多个百度地图
Apr 07 Javascript
jQuery+CSS实现滑动的标签分栏切换效果
Dec 17 Javascript
浅谈$('div a') 与$('div&gt;a')的区别
Jul 18 Javascript
详谈JS中实现种子随机数及作用
Jul 19 Javascript
jQuery Validate 相关参数及常用的自定义验证规则
Mar 06 Javascript
从零开始学习Node.js系列教程二:文本提交与显示方法
Apr 13 Javascript
VueJs组件prop验证简单介绍
Sep 12 Javascript
Vue全家桶实践项目总结(推荐)
Nov 04 Javascript
动态加载权限管理模块中的Vue组件
Jan 16 Javascript
JS同步、异步、延迟加载的方法
May 05 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
CodeIgniter配置之config.php用法实例分析
2016/01/19 PHP
PHP的Yii框架中Model模型的学习教程
2016/03/29 PHP
PHP实现图片的等比缩放和Logo水印功能示例
2017/05/04 PHP
一个不错的用JavaScript实现的UBB编码函数
2007/03/09 Javascript
让人印象深刻的10个jQuery手风琴效果应用
2012/05/08 Javascript
javascrip关于继承的小例子
2013/05/10 Javascript
jQery使网页在显示器上居中显示适用于任何分辨率
2014/06/09 Javascript
js使用post 方式打开新窗口
2015/02/26 Javascript
JavaScript中神奇的call()方法
2015/03/12 Javascript
JS组件Bootstrap ContextMenu右键菜单使用方法
2016/04/17 Javascript
浅谈angularjs $http提交数据探索
2017/01/20 Javascript
vue-resouce设置请求头的三种方法
2017/09/12 Javascript
Vue render深入开发讲解
2018/04/13 Javascript
微信小程序动态添加view组件的实例代码
2019/05/23 Javascript
[01:36]DOTA2完美大师赛趣味视频之与队友相处的十万个技巧
2017/11/19 DOTA
[00:52]DOTA2国际邀请赛
2020/02/21 DOTA
Python实现将MySQL数据库表中的数据导出生成csv格式文件的方法
2018/01/11 Python
Django中Model的使用方法教程
2018/03/07 Python
Python实现替换文件中指定内容的方法
2018/03/19 Python
python爬虫获取新浪新闻教学
2018/12/23 Python
python3中类的继承以及self和super的区别详解
2019/06/26 Python
python Matplotlib底图中鼠标滑过显示隐藏内容的实例代码
2019/07/31 Python
python中property和setter装饰器用法
2019/12/19 Python
Python selenium抓取虎牙短视频代码实例
2020/03/02 Python
一款纯css3实现的动画加载导航
2014/10/08 HTML / CSS
英国豪华真皮和布艺沙发销售网站:Darlings of Chelsea
2018/01/05 全球购物
医学专业毕业生个人求职信
2013/12/25 职场文书
小学生环保标语
2014/06/13 职场文书
校长师德师风自我剖析材料
2014/09/29 职场文书
政风行风评议心得体会
2014/10/21 职场文书
纪录片信仰观后感
2015/06/08 职场文书
从事会计工作年限证明
2015/06/23 职场文书
2016学习依法治国心得体会
2016/01/15 职场文书
浅谈golang package中init方法的多处定义及运行顺序问题
2021/05/06 Golang
Java Kafka 消费积压监控的示例代码
2021/07/01 Java/Android
一条 SQL 语句执行过程
2022/03/17 MySQL