zoukankan      html  css  js  c++  java
  • js或jquery实现页面打印(局部打印)

    首先定义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();"> 
     
     
     
     
    来源:http://www.jb51.net/article/37571.htm
  • 相关阅读:
    Building a flexiable renderer
    Indirect Illumination in mental ray
    我的心情
    Cellular Automata
    Subsurface Scattering in mental ray
    Shader Types in mental ray
    BSP Traversal
    我的渲染器终于达到了MR的速度
    How to handle displacement and motion blur
    说明
  • 原文地址:https://www.cnblogs.com/kongxc/p/7469312.html
Copyright © 2011-2022 走看看