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 相关文章推荐
js下弹出窗口的变通
Apr 18 Javascript
jquery last-child 列表最后一项的样式
Jan 22 Javascript
手机开发必备技巧:javascript及CSS功能代码分享
May 25 Javascript
纯javascript响应式树形菜单效果
Nov 10 Javascript
JS中实现函数return多个返回值的实例
Feb 21 Javascript
深入讲解xhr(XMLHttpRequest)/jsonp请求之abort
Jul 26 Javascript
vue-quill-editor实现图片上传功能
Aug 08 Javascript
配置eslint规范项目代码风格
Mar 11 Javascript
Vue 权限控制的两种方法(路由验证)
Aug 16 Javascript
小程序如何获取多个formId实现详解
Sep 20 Javascript
js实现轮播图特效
May 28 Javascript
关于对TypeScript泛型参数的默认值理解
Jul 15 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仿QQ验证码的实例分析
2013/07/01 PHP
PHP设置图片文件上传大小的具体实现方法
2013/10/11 PHP
PHP实现简单的新闻发布系统实例
2015/07/28 PHP
PHP文件操作之获取目录下文件与计算相对路径的方法
2016/01/08 PHP
PHP优化之批量操作MySQL实例分析
2020/04/23 PHP
Javascript实例教程(19) 使用HoTMetal(3)
2006/12/23 Javascript
JavaScript面向对象编程
2008/03/02 Javascript
Javascript 构造函数 实例分析
2008/11/26 Javascript
基于jQuery的淡入淡出可自动切换的幻灯插件
2010/08/24 Javascript
优化innerHTML操作(提高代码执行效率)
2011/08/20 Javascript
JQuery模板插件 jquery.tmpl 动态ajax扩展
2011/11/10 Javascript
制作jquery遮罩层效果导航菜单代码分享
2013/12/25 Javascript
浅谈Javascript中匀速运动的停止条件
2014/12/19 Javascript
JavaScript常用字符串与数组扩展函数小结
2016/04/24 Javascript
3分钟快速搭建nodejs本地服务器方法运行测试html/js
2017/04/01 NodeJs
JS实现评价的星星功能
2017/08/20 Javascript
详解使用 Node.js 开发简单的脚手架工具
2018/06/08 Javascript
[02:01]大师之路——DOTA2完美大师赛11月论剑上海
2017/11/06 DOTA
Java与Python两大幸存者谁更胜一筹呢
2018/04/12 Python
使用python绘制二元函数图像的实例
2019/02/12 Python
Python进阶之迭代器与迭代器切片教程
2020/01/29 Python
如何基于python3和Vue实现AES数据加密
2020/03/27 Python
pandas to_excel 添加颜色操作
2020/07/14 Python
Python装饰器如何实现修复过程解析
2020/09/05 Python
真正了解CSS3背景下的@font face规则
2017/05/04 HTML / CSS
IE滤镜与CSS3效果(详细整理分享)
2013/01/25 HTML / CSS
一款基于css3的列表toggle特效实例教程
2015/01/04 HTML / CSS
使用CSS3的ruby-position固定注音位置的用法示例
2016/07/05 HTML / CSS
基本款天堂:Everlane
2017/05/13 全球购物
舞蹈专业大学生职业规划范文
2014/03/12 职场文书
土地转让协议书
2014/04/15 职场文书
机动车交通事故协议书
2015/01/29 职场文书
酒店员工辞职信范文
2015/02/28 职场文书
校园文化艺术节开幕词
2016/03/04 职场文书
python编程项目中线上问题排查与解决
2021/11/01 Python
html中相对位置与绝对位置的具体使用
2022/05/15 HTML / CSS