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 相关文章推荐
Jquery实战_读书笔记1—选择jQuery
Jan 22 Javascript
jquery插件制作 提示框插件实现代码
Aug 17 Javascript
js中parseFloat(参数1,参数2)定义和用法及注意事项
Jan 27 Javascript
禁止IE用右键的JS代码
Dec 30 Javascript
Jquery焦点图实例代码
Nov 25 Javascript
JavaScript中校验银行卡号的实现代码
Dec 19 Javascript
jQuery返回定位插件详解
May 15 jQuery
vue-cli的eslint相关用法
Sep 29 Javascript
js操作二进制数据方法
Mar 03 Javascript
浅谈Angular HttpClient简单入门
May 04 Javascript
迅速了解一下ES10中Object.fromEntries的用法使用
Mar 05 Javascript
js加减乘除精确运算方法实例代码
Jan 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
在php中使用sockets:从新闻组中获取文章
2006/10/09 PHP
PHP+Mysql+jQuery实现发布微博程序 jQuery篇
2011/10/08 PHP
PHP图片处理之图片背景、画布操作
2014/11/19 PHP
Zend Framework教程之Zend_Controller_Plugin插件用法详解
2016/03/07 PHP
PHP7安装Redis扩展教程【Linux与Windows平台】
2016/09/30 PHP
如何在Laravel5.8中正确地应用Repository设计模式
2019/11/26 PHP
jqeury eval将字符串转换json的方法
2011/01/20 Javascript
Textarea与懒惰渲染实现代码
2012/01/04 Javascript
基于JQuery的模拟苹果桌面Dock效果(稳定版)
2012/10/15 Javascript
JS判断对象是否存在的10种方法总结
2013/12/23 Javascript
单元选择合并变色示例代码
2014/05/26 Javascript
js实现防止被iframe的方法
2015/07/03 Javascript
分享javascript实现的冒泡排序代码并优化
2016/06/05 Javascript
浅谈jQuery中的$.extend方法来扩展JSON对象
2017/02/12 Javascript
基于JavaScript实现轮播图原理及示例
2020/04/10 Javascript
jQuery点击头像上传并预览图片
2017/02/23 Javascript
JavaScript纯色二维码变成彩色二维码
2020/07/23 Javascript
在 Node.js 中使用原生 ES 模块方法解析
2017/09/19 Javascript
JS求Number类型数组中最大元素方法
2018/04/08 Javascript
jQuery实现基本动画效果的方法详解
2018/09/06 jQuery
记一次vue-webpack项目优化实践详解
2019/02/17 Javascript
vue-cli3 DllPlugin 提取公用库的方法
2019/04/24 Javascript
详解Vue demo实现商品列表的展示
2019/05/07 Javascript
angula中使用iframe点击后不执行变更检测的问题
2020/05/10 Javascript
使用Python编写Linux系统守护进程实例
2015/02/03 Python
python list转矩阵的实例讲解
2018/08/04 Python
python制作英语翻译小工具代码实例
2019/09/09 Python
pycharm内无法import已安装的模块问题解决
2020/02/12 Python
Python抓包程序mitmproxy安装和使用过程图解
2020/03/02 Python
Pycharm创建python文件自动添加日期作者等信息(步骤详解)
2021/02/03 Python
css3背景_动力节点Java学院整理
2017/07/11 HTML / CSS
瑞典Happy Socks美国官网:购买色彩斑斓的快乐袜子
2016/10/19 全球购物
庆七一活动方案
2014/01/25 职场文书
学生会自荐信
2019/05/16 职场文书
Python之基础函数案例详解
2021/08/30 Python
JavaScript流程控制(循环)
2021/12/06 Javascript