使用IE自带的打印控件进行套打

本文介绍如何利用IE浏览器自带的打印控件实现套打功能。通过展示具体实例,解释了不同场景下如何切换框架页面以达到所需打印效果。同时,还提供了处理IFRAME中编码不一致导致乱码问题的方法。

使用IE自带的打印控件进行套打

Author:http://blog.youkuaiyun.com/fenglibing    20091210     转载请保留

 

当前项目中使用报表设计工具为开源的IREPORT报表工具,它的好处在于是开源的且免费的,如果是一般的打印,完全可以满足要求;但是如果要涉及到打印格式为多种多样,并且要给用户完全的方便,即打印的时候系统自动新建纸张类型并确定宽高,用户只需要点打印就行,IREPORT在这方面就不行了;因为其自身没有打印控件,只是调用IE的打印控件,而IE为了安全起见,是不允许通过客户端创建纸张类型的(注:这是我通过邮件从四方打印PAZU项目组的回复中得知的),其它的专业打印控件,如明宇报表是可以实现这样的功能的。

要使用IREPORT进行套打,也需要做两套模板,用户看到的是全部显示内容的一套,而真正打印的是另外一套只有打印内容的一套,现在项目中就是这样使用的,我不知道IREPORT是否可以根据属性设定来自动生成两套打印模板,即可以在设置页面设置哪些元素是套打元素、哪些是非套打元素,然后自动生成两个HTML页面,就可以减少工作量了;不过正因为它是开源的,所以作者可能维护的时间相对较少一点。

 

现在回到套打上来,在IE中如何使用IE控件进行套打呢?这个时候可以采用在不同的时候根据情况显示不同的框架页面来做到,看如下示意图: 

  


此时我们只需要将打印方法,设置为如下即可实例套打的功能了:

function printThis() {

       document.getElementById("frame1").style.display="none";

       document.getElementById("frame2").style.display="";

       document.getElementById("functionLayer").style.display="none";

       document.frames("frame2").window.focus();           

       window.print();    

       document.getElementById("frame1").style.display="";

       document.getElementById("frame2").style.display="none";

       document.getElementById("functionLayer").style.display="";    

}

 

另外需要注意一点,就是如果IFRAME中被包含的页面的编码与当前包含的页面的编码不一致,如当前父页面的charsetgb2312,但是被包含页面的编码为utf-8,此时通过父面查看子页面是显示乱码的,这个时候可以通过高过iframelang属性,将其设为utf-8,如下:

<iframe id="frame1" src="..." lang="UTF-8" width="100%" height="500" frameborder=no></iframe>

也可以通过设置其charset属性,如下:

frames.frame1.document.charset="utf-8";

这样就可以解决乱码的问题了。

本文出自:冯立彬的博客



评论 15
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值