js实现局部打印及其打印预览

虽然浏览器提供了打印的功能,但是有时候需要我们自己定义打印的区域,这个时候需要JS来帮忙,以下是我找的几个打印的方法。

局部打印方法一:

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();
 }
}


使用很简单 将页面内要打印的内容加入中间XXXXX再加个打印按纽 οnclick=preview(1)

局部打印方法二:

或者使用div将需要打印的部分包裹起来后直接获取这部分

 function printdiv() {
            var newstr = document.getElementById("PrintContentDiv").innerHTML;   //获得需要打印的内容
            // alert(newstr);
            var oldstr = document.body.innerHTML;   //保存原先网页的代码
            document.body.innerHTML = newstr; //将网页内容更改成需要打印
            window.print();
            document.body.innerHTML = oldstr;   //将网页还原
            return false;
        }

另外,还有一种打印的方法,通过css+js实现局部打印。这个是调用浏览器自己的控件,不过好像只能在IE中使用。

局部打印方法三:

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>
注意这个 media=print很重要,如果不写的话在页面上就会直接隐藏,写上之后只有打印的时候才会隐藏,浏览的时候还是正常显示。

然后把想隐藏的部分的class定义为noprint即可。

第三种方法最方便,但是局限性也最大,只能使用IE才有效,因为控件是IE的控件。

CSS隐藏不打印部分的方式所有浏览器通用。

以上打印方法一和打印方法三出自Sam Lin 的博客,打印方法二出自TianGaojie123abc 的博客 感谢作者

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值