位置: 编程技术 - 正文

web打印的另类方法(web直接打印)

编辑:rootadmin
web打印的另类方法 选择自 wfmazhenhai 的 Blog 关键字 web打印的另类方法 出处 相信用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: %}' + '.ftitle { line-height: %; font-size: px; color: #}' + 'td { font-size: px; color: #}' + '</style>' ; // ***************************************************** // 定义打印用的CSS,具体你想打印出什么样的格式全看你自己 // 了,但要注意:如果此处有什么同网页中不一致的,可能打印 // 出来的页面同网页格式、字体可能会有所不同 // ***************************************************** var body ='<table width="" 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浏览器的“文件--页面设置”中的“页眉、页角”的设置去掉,则效果更佳了。(转载)

推荐整理分享web打印的另类方法(web直接打印),希望有所帮助,仅作参考,欢迎阅读内容。

web打印的另类方法(web直接打印)

文章相关热门搜索词:web版式打印,web实现打印功能,web打印解决方案,web打印的另类方式是什么,web打印的另类方法有哪些,web实现打印功能,web实现打印功能,web打印的另类方法有哪些,内容如对您有帮助,希望把文章链接给更多的朋友!

用CSS实现的一张图完成的按钮效果 [Ctrl+A全选注:如需引入外部Js需刷新才能执行]用CSS实现的一张图完成的导航条游戏娱乐菜单好玩[Ctrl+A全选注:如需引入外部Js需刷新才能执行]

文章内容页广告浮于左上角的解决办法 这个是整页代码,你可以看着改了,也可以保存成HTML文件,完了试试看就知道了,主要用的CSS+DIV上面的东西移到模板中,下面的东西也是一样~完了就

广告放在文章页左上角的解决办法二 可以试试这个表格式代码~tablewidth="%"border=0align="center"cellPadding=0cellSpacing=0trtdalign=leftheight=divalign=lefttablecellSpacing=0cellPadding=0align=leftborder=0trtdalign=centerw

标签: web直接打印

本文链接地址:https://www.jiuchutong.com/biancheng/371959.html 转载请保留说明!

上一篇:让人不得不佩服的CSS效果(不得不佩服自己的搞笑说说)

下一篇:用CSS实现的一张图完成的按钮效果(用css制作网页的步骤)

  • 个人所得税可以退吗
  • 海产品的增值税税率是多少
  • 进项税有余额但没有余额
  • 出口退税政策
  • 土地增值税应纳税额如何计算
  • 小规模纳税人广联达怎么取费怎么取
  • 出口商品认证
  • 增值税发票税控开票软件打不开
  • 房地产企业售楼降价法律条文
  • 土地增值税清算利息扣除规定
  • 土地增值税计税价格
  • 坏账的处理方法包括
  • 事业基金弥补收支差额是什么意思
  • 财务人员需具备的基本素质和条件是什么
  • 办事处可以办理临时身份证吗
  • 国税退税需要多长时间
  • 从免税到征税企业应该怎么做
  • 发生销售折扣如何做账
  • 水利基金减免政策2022
  • 取得赔偿款的发票可以抵扣吗
  • 固定资产累计折旧借方表示什么
  • 维修费属于印花税
  • 支付机器设备修理费
  • 季度所得税弥补亏损
  • 笔记本电池保养注意事项
  • 收到银行承兑汇票的账务处理
  • 分配辅助生产成本时可能借记的科目有
  • symfony是最好的框架
  • jquery 批量删除
  • php将数据导出到excel
  • 房地产消防工程入什么科目
  • 什么情况下附加税减半征收
  • 小程序navigator组件
  • Es6的新特性promise对象的设计初衷是
  • 前端cgi
  • ChatGPT会取代你的岗位吗?
  • python快速检索
  • 面试官问:mysql 的自增 id 用完了,怎么办?
  • 尚未进行抄报税无法申报是什么意思
  • 或有资产确认的前提为什么是
  • 高价值配件用入固定资产吗
  • 一般纳税人无票收入怎么报增值税
  • 职工福利费的作用
  • 织梦自定义字段
  • sql server创建数据表的完整语法
  • 公司股东和自然人的关系
  • 购买设备配件
  • mysql数据查询慢
  • 充电桩的安装费是多少
  • 税控服务费全额抵扣
  • 小规模企业现金流量表
  • 建筑行业旧项目怎么处理
  • 一般纳税人销售旧货
  • 单位代扣代缴个人所得税凭证
  • 加计抵减10%政策适用范围
  • 生产性生物资产折旧计入什么科目
  • 物业管理企业应按职工工资总额的1.5%计提工会经费
  • 将Sublime Text 2固定到Ubuntu启动器的方法
  • mac怎么保存网页到桌面
  • linux多线程并发的处理方式
  • centos更新命令
  • win10 记笔记
  • 用centos搭建服务器的详细教程
  • linux中nfs的配置
  • win8系统升级后怎么退回
  • xp系统进入桌面后没反应
  • 软件生态圈是什意思
  • win10 edge浏览器崩溃
  • css模糊滤镜
  • python图片处理酷炫效果
  • emacs win10
  • jquery?
  • webpack配置文件在哪
  • nodejs回调函数例子 getdata check
  • 使用jquery实现的项目
  • js制作qq简易聊天框
  • 房屋附属设备和配套设施计征房产税
  • 国家税务局公告2018年第28号
  • 电子发票软件怎么打开
  • 电子缴款凭证可以用于报销吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设