js控制web打印(局部打印)办法整理

家电修理 2023-07-16 19:16www.caominkang.com电器维修

定义css样式
复制代码 代码如下:
@media print {
.noprint { display: none;color:green }
}

对于不想打印的内容只用在标签中加上 class=noprint即可,打印的时候客户也不会看到页面任何变化。
打印时调用 indo.print();

几种js局部打印的方法
移花接木
打印的时候,把需要打印的内容替换成整个body内容(用户会在打印的时候看到变化,客户体验不太好)
复制代码 代码如下:
function previe(oper)
......{
if (oper < 10)......{
bdhtml=indo.document.body.innerHTML;//获取当前页的html代码
sprnstr="";//设置打印开始区域
eprnstr="";//设置打印结束区域
prnhtml=bdhtml.substring(bdhtml.indexOf(sprnstr)+18); //从开始代码向后取html
prnhtml=prnhtml.substring(0,prnhtml.indexOf(eprnstr));//从结束代码向前取html
indo.document.body.innerHTML=prnhtml;
indo.print();
indo.document.body.innerHTML=bdhtml;
} else ......{
indo.print();
}
}

使用很简单 将页面内要打印的内容加入中间XXXXX
再加个打印按纽 onclick=previe(1)
-----------------------------------------
WebBroser是IE内置的浏览器控件,无需用户下载.(未实验)
一、WebBroser控件
复制代码 代码如下:
  

二、WebBroder控件的方法
复制代码 代码如下:
//打印
WebBroser1.ExecWB(6,1);
//打印设置
WebBroser1.ExecWB(8,1);
//打印预览
WebBroser1.ExecWB(7,1);

关于这个组件还有其他的用法,列举如下
WebBroser.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) 关闭窗体无提示
打印是会把整个页面都打印出来的,页面里面有什么东西就打印出来,我们有时候只需要打印数据表格,这时我们就要写一个样式了:把不想打印的部份隐藏起来
样式内容
复制代码 代码如下:

.noprint......{display : none }


然后使用样式就可以

不需要打印的地方


代码如下:
复制代码 代码如下:





Copyright © 2016-2025 www.caominkang.com 曹敏电脑维修网 版权所有 Power by