博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS网页打印设置技巧
阅读量:4625 次
发布时间:2019-06-09

本文共 4525 字,大约阅读时间需要 15 分钟。

转自:http://blog.sina.com.cn/s/blog_3eba8f1c0100emu4.html

最近写一些东西需要提供网页打印功能,所以归纳总结了一下,本节主要讲述使用IE6支持打印功能,不同浏览器安全设置与支持有差异,如果不支持,请使用您的浏览器自带打印功能(或手动设置启用ActiveX控件)。书写有不足或描述不清的地方请大家指正。^-^

 
利用CSS样式打印是经常使用的一种打印方法,利用它可以非常方便的实现打印页面中的指定内容和分页打印,下面将通过具体实例介绍如何利用CSS样式打印。
 
[分析]:
 1.打印样式区分

打印网页带页面样式,需指明一个media='print'的样式,建议分开,如下创建军一个bankprint.css打印样式文件。

 <link rel="stylesheet" media="screen" type="text/css" href="/public/default/css/bank.css" />
 <!-- 打印样式 -->
 <link rel="stylesheet" media="print" type="text/css" href="/public/default/css/bankprint.css" />
 例:
 <style media=‘print’>
 
.Noprint {display:none;}
 
.PageBreak {page-break-after: always;}
 
</style>
 说明:
 media类型是CSS属性媒体类型,用于直接引入媒体的属性。其语法格式如下:
 @media screen | print | projection | braille | aural | tv | handheld | all
 参数说明
   screen:指计算机屏幕。
   print:指用于打印机的不透明介质。
   projection:指用于显示的项目。
   braille:盲文系统,指有触觉效果的印刷品。
   aural:指语音电子合成器。
   tv:电视类型的媒体。
   handheld:指手持式显示设备。
   all:用于所有媒体。

 2.WebBrowser控件
 同其他控件一样,首先我们需要在页面中嵌入WebBrowser控件,不过由于该控件是IE浏览器自带的,支持浏览器默认安全设置,因此避免了安全性设置的麻烦。对于IE7及以上安全性要求更高的浏览器,您或许还是需要自定义IE的安全性级别。
 <OBJECT classid="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2" id="wb" width="0" height="0"></OBJECT>
 下面就是该控件涉及打印的功能调用,用户可以在JavaScrip中调用:
 wb.execwb(6,1); //打印,打印当前页面
 wb.execwb(7,1); //打印预览
 wb.execwb(8,1); //打印设置,调出系统打印设置对话框
 
3.页眉、页脚设置:打印时,有的需要去掉页眉页脚,或替换成自已想要的。

 <script language="JavaScript">  
   var hkey_root,hkey_path,hkey_key;
     hkey_root="HKEY_CURRENT_USER";
     hkey_path="\\Software\\Microsoft\\Internet Explorer\\PageSetup\\";
     //配置网页打印的页眉页脚为空
     function pagesetup_null(){  
         try{
             var RegWsh = new ActiveXObject("WScript.Shell");          
             hkey_key="header";          
             RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"");
             hkey_key="footer";
             RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"");
             //&b 第&p页/共&P页 &b
         }catch(e){}
     }
     //配置网页打印的页眉页脚为默认值
     function pagesetup_default(){
         try{
             var RegWsh = new ActiveXObject("WScript.Shell");
             hkey_key="header";
             RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"&w&b页码,&p/&P")
             hkey_key="footer";
             RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"&u&b&d");
         }catch(e){}
     }
 </script>
 
[源码例子]:
 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "">
 <html xmlns="">
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>打印设置</title>
 <link rel="stylesheet" media="screen" type="text/css" href="" />
 <!-- 打印样式 -->
 <link rel="stylesheet" media="print" type="text/css" href="" />
 <script language="JavaScript">
     var hkey_root,hkey_path,hkey_key;
     hkey_root="HKEY_CURRENT_USER";
     hkey_path="\\Software\\Microsoft\\Internet Explorer\\PageSetup\\";
     //配置网页打印的页眉页脚为空
     function pagesetup_null(){  
         try{
             var RegWsh = new ActiveXObject("WScript.Shell");          
             hkey_key="header";          
             RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"");
             hkey_key="footer";
             RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"");
             //&b 第&p页/共&P页 &b
         }catch(e){}
     }
     //配置网页打印的页眉页脚为默认值
     function pagesetup_default(){
         try{
             var RegWsh = new ActiveXObject("WScript.Shell");
             hkey_key="header";
             RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"&w&b页码,&p/&P")
             hkey_key="footer";
             RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"&u&b&d");
         }catch(e){}
     }  
      //打印选区内容
     function doPrint() {
         pagesetup_null();
         bdhtml=window.document.body.innerHTML;
         sprnstr="<!--startprint-->";
         eprnstr="<!--endprint-->";
         prnhtml=bdhtml.substr(bdhtml.indexOf(sprnstr)+17);
         prnhtml=prnhtml.substring(0,prnhtml.indexOf(eprnstr));
         window.document.body.innerHTML=prnhtml;
         window.print();
     }
     //打印页面预览
     function printpreview(){
         pagesetup_null();
         //wb.printing.header = "居左显示&b居中显示&b居右显示页码,第&p页/共&P页";
         //wb.printing.footer = "居左显示&b居中显示&b居右显示页码,第&p页/共&P页";
         try{
             wb.execwb(7,1);
         }catch(e){
             alert("您的浏览器不支持此功能,请选择'文件'->'打印预览'");
         }
     }
     //打印
     function prints(){
         pagesetup_null();
         //wb.printing.header = "居左显示&b居中显示&b居右显示页码,第&p页/共&P页";
         //wb.printing.footer = "居左显示&b居中显示&b居右显示页码,第&p页/共&P页";
         try{
             wb.execwb(6,1);
         }catch(e){
             alert("您的浏览器不支持此功能");
         }
     }
 </script>
 </head>
 <body>
 <OBJECT classid="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2" id="wb" width="0" height="0"></OBJECT>
 <div id="bankwrap">
   <div class="Noprint"><a href="" style="cursor:pointer; color:#0000FF">返回首页</a></div>
   <div style="text-align:right">
     <p class="Noprint">
         <span style="cursor:pointer; color:#0000FF" οnclick="javascript:window.open('http://www.chinasvf.com/Webs/Share/printhelp')" class="Noprint">打印帮助</span>
         <span style="cursor:pointer; color:#0000FF" οnclick="printpreview();">打印预览</span>
         <span style="cursor:pointer; color:#0000FF" οnclick="prints();" class="Noprint">打印</span>
     </p>
   </div>
   <div class="banktitle">内容</div>
 </div>
 </body>
 </html>

转载于:https://www.cnblogs.com/dragon88/archive/2013/04/20/3032727.html

你可能感兴趣的文章
[BZOJ4824][Cqoi2017]老C的键盘 树形dp+组合数
查看>>
配置的热更新
查看>>
MySQL事务的开启与提交,autocommit自动提交功能
查看>>
PriorityQueue
查看>>
CODEVS1403 新三国争霸
查看>>
iOS 环信离线推送
查看>>
WPFTookit Chart 高级进阶
查看>>
雷云Razer Synapse2.0使用测评 -第二次作业
查看>>
django上传文件
查看>>
CVPR2013-papers
查看>>
PHP之时间函数
查看>>
Python open()完整参数
查看>>
django里面DTL使用for循环时,获取当前循环次数使用{{forloop.counter}}
查看>>
Java基础——Java集合(二)
查看>>
详解如何让Android UI设计性能更高效
查看>>
Zorka监控平台的Online reconfiguration基本效果展示
查看>>
mysql查看执行sql语句的记录日志
查看>>
值传递
查看>>
冲刺7
查看>>
《Python学习之路 -- Python基础之文件处理》
查看>>