JSP页面打印
2014/4/25 by lyf @七里外风车磨坊
生活不可能像你想象的的那么好,但也不会像你想象的那么糟。我觉得人的脆弱和坚强都超乎自己的想象。
有时,我可能脆弱得一句话就泪流满面,有时也发现自己咬着牙,走了很远。By 莫泊桑
生活有时候有太多的不如意,哎,可又能怎样呢,也只是感慨感慨而已,一切都还的继续,为了生活。
好久没写点东西了,突然有想写点东西的想法,最近工作也挺忙的,还老是加班,最近在忙着做一个项目,
项目中有一块功能是在JSP页面中实现打印的功能,在网上找了很多,有使用打印控件的,也有直接打印JSP页面的,在本文中我将分享打印JSP的相关技术。
首先呢截个图 看看打印预览的效果
点击打印预览如下图所示的预览效果
下面一起来看看这个是怎样实现的
从页面上可以看见,页面上还有几个按钮,在实际打印中,我们会将页面上的按钮给隐藏掉,按照默认的情况下,直接调用打印,
会将整个页面的内容给打印出来,下面我们来看看直接打印的效果。选择浏览器上的打印,选择打印预览
可以看见整个页面的内容都被打印出来了。显然这不是我们所需要的,于是就在网上找了很多,
可以采用div打印的方式,将打印的区域放在一个div中,不需要打印的部分放在另一个div中,在打印的时候只需要传入需要打印的div即可,怎么做呢,下面是其中的代码部分
1.要在web网页中引入打印webbrowser控件
<objectid="WebBrowser"width="0"height="0"
classid="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2"></object>
2.打印部分的DIV
<divid="print_table"align="center"><br>
<br>
<br>
<br>
<tableclass="titletable"cellpadding="0px"border="0px"cellspacing="0px"width="60%">
<tr>
<tdcolspan="7"align="center"><fontsize="10px">转储单</font></td>
</tr>
<tr>
<tdcolspan="7"align="center"></td>
</tr>
<tr>
<tdcolspan="3">转储单:<%=dumpnum%></td>
<tdcolspan="4">转储日期:<%=dumpdate%></td>
</tr>
<tr>
<tdcolspan="3">大仓位:<%=shortbin%></td>
<tdcolspan="4">转储人:<%=dumpperson%></td>
</tr>
<tr>
<tdcolspan="7"align="center"></td>
</tr>
</table>
<br>
<tableclass="altrowstable"cellpadding="0px"border="1px"cellspacing="0px"width="60%">
<tralign="center">
<td>行项目号</td>
<td>物料编码</td>
<td>物料描述</td>
<td>规格型号</td>
<td>转储数量</td>
<td>单位</td>
<td>批次</td>
</tr>
<%
for(inti=0;i<list.size();i++){
%>
<tralign="center">
<td><%=i%></td>
<td><%=detail.getMatnr()%></td>
<tdalign="left"><%=(null==detail.getMaktx()?" ":detail.getMaktx())%></td>
<tdalign="left"><%=(null==detail.getZggxh()?" ":detail.getZggxh())%></td>
<td><%=(null==detail.getDumpNumber()?" ":detail.getDumpNumber())%></td>
<td><%=(null==detail.getMeins()?" ":detail.getMeins())%></td>
<td><%=(null==detail.getCharg()?" ":detail.getCharg())%></td>
</tr>
<%}
%>
</table>
<br>
<br>
</div>
3.不进行打印的部分
<div id="noprintarea"align="center"><inputtype="button"
value="打印"id="print_dump"onclick="printdump()"/> <input
type="button"value="打印预览"onclick="printdumpview()"
id="print_prevdump"/> <inputtype="button"value="返回"
onclick="back()"id="back_dump"/><inputtype="button"
value="打印页面设置"id="printset_dump"onclick="printset()"></div>
在我们点击打印的预览的时候,将不打印的部分给隐藏掉,打印预览出来后,将该部分恢复即可.
以下是打印相关的JS代码
function hide() //隐藏打印按钮
{
document.all.item("print_dump").style.display="none";
document.all.item("print_prevdump").style.display="none";
document.all.item("back_dump").style.display="none";
document.all.item("printset_dump").style.display="none";
}
functionshow(){ //显示出打印,打印预览,设置等按钮
document.all.item("print_dump").style.display="inline";
document.all.item("print_prevdump").style.display="inline";
document.all.item("back_dump").style.display="inline";
document.all.item("printset_dump").style.display="inline";
}
function printdumpview(){ //打印预览
pagesetup_null();//设置页眉和页脚为空
document.all.WebBrowser.ExecWB(7,1); //调用打印预览
}
function printdump(){//直接打印
pagesetup_null();//设置页眉和页脚为空
document.all.WebBrowser.ExecWB(6,1);//调用打印
show();
}
functionprintset(){ //打印页面设置
document.all.WebBrowser.ExecWB(8,1); //设置打印
}
打印设置页眉与页脚为空,通过操作注册表,隐藏掉打印的页眉与页脚
varhkey_root,hkey_path,hkey_key;
hkey_root="HKEY_CURRENT_USER";
hkey_path="\\Software\\Microsoft\\InternetExplorer\\PageSetup\\";
//配置网页打印的页眉页脚为空
functionpagesetup_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,"");
}catch(e){}
}
//配置网页打印的页眉页脚为默认值
functionpagesetup_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){}
}
毕!