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中的事件
Sep 23 Javascript
javascript之函数直接量(function(){})()
Jun 29 Javascript
一些相见恨晚的 JavaScript 技巧
Apr 25 Javascript
JS解析json数据并将json字符串转化为数组的实现方法
Dec 25 Javascript
javascript获取函数名称、函数参数、对象属性名称的代码实例
Apr 12 Javascript
js实现鼠标点击左上角滑动菜单效果代码
Sep 06 Javascript
easyui messager alert 三秒后自动关闭提示的实例
Nov 07 Javascript
Bootstrap中定制LESS-颜色及导航条(推荐)
Nov 21 Javascript
基于js实现checkbox批量选中操作
Nov 22 Javascript
jQuery滚动监听实现商城楼梯式导航效果
Mar 06 Javascript
Vue + element 实现多选框组并保存已选id集合的示例代码
Jun 03 Javascript
vue+iview分页组件的封装
Nov 17 Vue.js
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下载excel无法打开的解决方法
2013/12/24 PHP
PHP生成数组再传给js的方法
2014/08/07 PHP
php生成html文件方法总结
2014/12/01 PHP
PHP中header函数的用法及其注意事项详解
2016/06/13 PHP
php中类和对象:静态属性、静态方法
2017/04/09 PHP
PHP与JavaScript针对Cookie的读写、交互操作方法详解
2017/08/07 PHP
PHP判断json格式是否正确的实现代码
2017/09/20 PHP
laravel5.6实现数值转换
2019/10/23 PHP
JS中产生20位随机数以0-9为例也可以是a-z A-Z
2014/08/01 Javascript
用jquery修复在iframe下的页面锚点失效问题
2014/08/22 Javascript
js变形金刚文字特效代码分享
2015/08/20 Javascript
微信支付如何实现内置浏览器的H5页面支付
2015/09/25 Javascript
jquery插件bootstrapValidator数据验证详解
2016/11/09 Javascript
jQuery插件jqGrid动态获取列和列字段的方法
2017/03/03 Javascript
微信小程序实现文字无限轮播效果
2018/12/28 Javascript
Vue中用JSON实现刷新界面不影响倒计时
2020/10/26 Javascript
vant中的toast轻提示实现代码
2020/11/04 Javascript
基于Numpy.convolve使用Python实现滑动平均滤波的思路详解
2019/05/16 Python
python 解决flask 图片在线浏览或者直接下载的问题
2020/01/09 Python
解决tensorboard多个events文件显示紊乱的问题
2020/02/15 Python
python生成任意频率正弦波方式
2020/02/25 Python
python 使用递归实现打印一个数字的每一位示例
2020/02/27 Python
Html5获取高德地图定位天气的方法
2019/12/26 HTML / CSS
什么是Assembly(程序集)
2014/09/14 面试题
法律进学校实施方案
2014/03/15 职场文书
医院护士见习期自我鉴定
2014/04/10 职场文书
行政专员求职信范文
2014/05/03 职场文书
淘宝活动总结范文
2014/06/26 职场文书
博士生求职信
2014/07/06 职场文书
我的中国梦演讲稿500字
2014/08/19 职场文书
525心理健康活动总结
2015/05/08 职场文书
酒店员工手册范本
2015/05/14 职场文书
pycharm2021激活码使用教程(永久激活亲测可用)
2021/03/30 Python
vue引入Excel表格插件的方法
2021/04/28 Vue.js
利用JuiceFS使MySQL 备份验证性能提升 10 倍
2022/03/17 MySQL
动视暴雪取消疫苗禁令 让所有员工返回线下工作
2022/04/03 其他游戏