1. 论坛系统升级为Xenforo,欢迎大家测试!
    排除公告

web打印的另类方法-ASP教程,打印相关

本帖由 百联真菲2006-09-14 发布。版面名称:后端开发

  1. 百联真菲

    百联真菲 New Member

    注册:
    2006-09-14
    帖子:
    16
    赞:
    0
    文章页数:[1]
    相信用b/s方式做过应用的人都可能会遇到这样一个问题,如何方便、美观地实现报表打印。如果使用浏览器的打印菜单打印的话,将把网页上的一些无用的东西打到报表上,比如应用菜单等。因为选择打印菜单打印网页将会把网页中的所有内容全部打印出来,如果你的应用有分帧则打印内容将包括各帧中的内容,而你实际要的内容只是其中一部分。所以有很多应用就只能把打印功能放到后台完成了。  针对这种情况,我们该怎么办?其实可以有多种方法实现网页打印功能。

      一种方法就是使用专业的打印工具,如crystal reports(水晶报表)。用过visual studio 5.0的朋友肯定记得这个工具,不过那时的版本只有4.几。现在的最新版本已达9了,近几个版本的水晶报表都支持web打印。最简单的方法是先用水晶报表制作好模板,然后使用asp带参数调用制作好的模板即可。水晶报表在网页上生成报表后,可以直接打印,也可以转存为其它的比较通过的文件如excel文件。使用水晶报表可以制作出非常漂亮的样式,关键在你对水晶报表的开发能力上,但由于水晶报表价格较高,只有当项目很赚钱时才买得起。

      第二种方法是购买第三方的网上打印控件,费用同水晶报表相比便宜,但效果性能到底如何则仁者见仁了。

      第三种方法是利用样式表及javascript自定义函数实现。通过样式表及javascript,实现网页打印,效果也还可以。在此有一个实例请大家看看。下面是打印函数实现详解:

    <script language="javascript" type="text/javascript">

    <!--

    function dp() {

    if (window.print)

    {

    var div1 = document.all.div1.innerhtml;

    var div2 = document.all.div2.innerhtml;

    // *****************************************************

    // div1、div2即为你在打印的区域

    // 这里根据你要打印的哪些内容,从原显示页面中用

    // <div id=div1>div1....</div><div id=div2>div2...</div>

    // 等标示出来,要打印多少项目就标示多少

    // ***************************************************** var css = <style type="text/css" media=all> +

    p { line-height: 120%} +

    .ftitle { line-height: 120%; font-size: 18px; color: #000000} +

    td { font-size: 10px; color: #000000} +

    </style> ;

    // *****************************************************

    // 定义打印用的css,具体你想打印出什么样的格式全看你自己

    // 了,但要注意:如果此处有什么同网页中不一致的,可能打印

    // 出来的页面同网页格式、字体可能会有所不同

    // *****************************************************

    var body =<table width="640" border="0" cellspacing="0" cellpadding="5"> +

    <tr> +

    <td class="fbody"> +

    <div align="center" class=ftitle> + div1 + </div> + div2 +

    </td> +

    </tr> +

    </table>;

    // ******************************************************

    // 在此处重新设置的打印格式,根据你的打印要求,将原显示的

    // 网页的div内容重新组合,可以根据你原来的表格内容,去掉

    // 不要打印的,你也可以能下面定义的noprint忽略掉你不想打

    // 印的东西,只调用你要打印的内容,但这样被忽略掉的地方将

    // 打印出空,不是很美观。表格宽度要同打印的纸张宽度匹配。

    // ******************************************************

    document.body.innerhtml = <center> + css + body + </center>;

    // ******************************************************

    // 重设document.body,打印文档准备就绪

    // ******************************************************

    window.print();

    window.history.go(0);

    // ******************************************************

    // 调用打印命令,打印当前窗口内容。当你打印时其实是一张新

    // 的网页了,但网页文件还是原先的。紧接着调用

    // window.history.go(0),再回到打印前的页面,效果相当不差

    // ******************************************************

    }

    }

    -->

    </script>

    <style>

    @media print {

    .noprint {display:none}

    }

    </style>

    <!--//.noprint 定义了noprint,在以下不需要打印的地方加入 class="noprint"后,用window.print()打印就会忽略-->

      好了,一切就绪了,现在要做的就是调用dp函数,如果你将实现调用的按钮设计在同一张网页上,则直接调用即可;如果你用了分帧方法,实现调用的按钮是在另一张网页上,则在dp函数的第一行加入window.focus()命令,否则打印的只是有按钮的网页。

      第四种方法,实现是一种取巧的方法。一样还是通过调用window.print()实现,只是将你要打印的内容专门生成一张网页,而打印按钮在另一帧上。假设报表网页在mainframe上,按钮在topframe上,按钮调用printreports()函数,printreports()函数如下即可实现打印工作。

    function printreports() //topframe网页中的函数

    {

    try

    // *******************************************************

    // 错误处理,如果在mainframe中的网页没有dp函数则不打印

    // *******************************************************

    {

    window.parent.frames("mainframe").dp();

    }

    catch(e)

    {

    alert("no object to print!");

    }

    }

    function dp() // mainframe网页中函数

    {

    window.focus();

    if (window.print)

    {

    window.print();

    }

    }

    我个人认为这是最方便的方法了。

      最后,如果你将ie浏览器的“文件--页面设置”中的“页眉、页角”的设置去掉,则效果更佳了。(转载)