js调用打印机.docx
- 文档编号:23207634
- 上传时间:2023-05-15
- 格式:DOCX
- 页数:24
- 大小:26.64KB
js调用打印机.docx
《js调用打印机.docx》由会员分享,可在线阅读,更多相关《js调用打印机.docx(24页珍藏版)》请在冰豆网上搜索。
js调用打印机
1网页打印实例
网页打印按钮的源代码:
javascript:
window.print();
可以用css控制
@mediaprint
.a{display:
block}
.b{display:
hidden}
好像是这样。
把你不想打印的部分class设为b
首先在网页中添加:
8856F961-340A-11D0-A96B-00C04FD705A2" VIEWASTEXT> 然后就可以依次加入功能按钮了: window.close()"> 将这两块东西放到 当然要定义noprint了: none}只要把不想打印的东西的css设置成noprint就可以了。 现在就实现了基本的web打印,需要注意的情况如下: 1.必须将ie的internet选项的安全设置中对于没有标记为安全的ActiveX控件进行...设置成提示或者启用,否则会报错,导致不可用。 2.如果在编辑环境下编辑该页面,它经常自动的给object添加多余的参数,有了这些东西,打印就会出错,所以要记得最后保存的时候删除它们。 为了简便并且达到最好的效果,我们可以在一个页面实现编辑和打印,这时候会需要很多的textbox,我们把它的css设置成.edittext { overflow-y: visible; width: 100%; border-top: none; border-right: none; border-bottom: none; border-left: none; }就可以实现在打印的时候不显示边框和multiline的textbox不显示滚动条了。 还有一些小经验就是在设置标格宽度的时候,对于A4纸张,横打用920,竖打用640,效果最好。 相信用B/S方式做过应用的人都可能会遇到这样一个问题,如何方便、美观地实现报表打印。 如果使用浏览器的打印菜单打印的话,将把网页上的一些无用的东西打到报表上,比如应用菜单等。 因为选择打印菜单打印网页将会把网页中的所有内容全部打印出来,如果你的应用有分帧则打印内容将包括各帧中的内容,而你实际要的内容只是其中一部分。 所以有很多应用就只能把打印功能放到后台完成了。 针对这种情况,我们该怎么办? 其实可以有多种方法实现网页打印功能。 一种方法就是使用专业的打印工具,如CrystalReports(水晶报表)。 用过VisualStudio5.0的朋友肯定记得这个工具,不过那时的版本只有4.几。 现在的最新版本已达9了,近几个版本的水晶报表都支持WEB打印。 最简单的方法是先用水晶报表制作好模板,然后使用ASP带参数调用制作好的模板即可。 水晶报表在网页上生成报表后,可以直接打印,也可以转存为其它的比较通过的文件如Excel文件。 使用水晶报表可以制作出非常漂亮的样式,关键在你对水晶报表的开发能力上,但由于水晶报表价格较高,只有当项目很赚钱时才买得起。 第二种方法是购买第三方的网上打印控件,费用同水晶报表相比便宜,但效果性能到底如何则仁者见仁了。 第三种方法是利用样式表及 JavaScript自定义函数实现。 通过样式表及JavaScript,实现网页打印,效果也还可以。 在此有一个实例请大家看看。 下面是打印函数实现详解: <scriptlanguage="JavaScript"type="text/JavaScript"> <! -- functionDP(){ if(window.print) { varDiv1=document.all.Div1.innerHTML; varDiv2=document.all.Div2.innerHTML; //***************************************************** //Div1、Div2即为你在打印的区域 //这里根据你要打印的哪些内容,从原显示页面中用 //<divid=Div1>Div1....</div><divid=Div2>Div2...</div> //等标示出来,要打印多少项目就标示多少 //*****************************************************varcss='<styletype="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,具体你想打印出什么样的格式全看你自己 //了,但要注意: 如果此处有什么同网页中不一致的,可能打印 //出来的页面同网页格式、字体可能会有所不同 //***************************************************** varbody='<tablewidth="640"border="0"cellspacing="0"cellpadding="5">'+ '<tr>'+ '<tdclass="fbody">'+ '<divalign="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> @mediaprint{ .noprint{display: none} } </style> <! --//.noprint定义了noprint,在以下不需要打印的地方加入class="noprint"后,用window.print()打印就会忽略--> 好了,一切就绪了,现在要做的就是调用DP函数,如果你将实现调用的按钮设计在同一张网页上,则直接调用即可;如果你用了分帧方法,实现调用的按钮是在另一张网页上,则在DP函数的第一行加入window.focus()命令,否则打印的只是有按钮的网页。 第四种方法,实现是一种取巧的方法。 一样还是通过调用window.print()实现,只是将你要打印的内容专门生成一张网页,而打印按钮在另一帧上。 假设报表网页在mainFrame上,按钮在topFrame上,按钮调用PrintReports()函数,PrintReports()函数如下即可实现打印工作。 functionPrintReports()//topFrame网页中的函数 { try //******************************************************* //错误处理,如果在mainFrame中的网页没有DP函数则不打印 //******************************************************* { window.parent.frames("mainFrame").DP(); } catch(e) { alert("noobjecttoprint! "); } } functionDP()//mainFrame网页中函数 { window.focus(); if(window.print) { window.print(); } } 1、控制"纵打"、横打”和“页面的边距。 (1) functionSetPrintSettings(){ //--advancedfeatures factory.printing.SetMarginMeasure (2)//measuremarginsininches factory.SetPageRange(false,1,3)//needpagesfrom1to3 factory.printing.printer="HPDeskJet870C" factory.printing.copies=2 factory.printing.collate=true factory.printing.paperSize="A4" factory.printing.paperSource="Manualfeed" //--basicfeatures factory.printing.header="ThisisMeadCo" factory.printing.footer="AdvancedPrintingbyScriptX" factory.printing.portrait=false factory.printing.leftMargin=1.0 factory.printing.topMargin=1.0 factory.printing.rightMargin=1.0 factory.printing.bottomMargin=1.0 } (2) functionprintsetup(){ //打印页面设置 wb.execwb(8,1); } functionprintpreview(){ //打印页面预览 wb.execwb(7,1); } functionprintit() { if(confirm('确定打印吗? ')){ wb.execwb(6,6) } } 8856F961-340A-11D0-A96B-00C04FD705A2" height=0id=wbname=wbwidth=0> onclick="javascript: printit()"> onclick="javascript: printsetup();"> onclick="javascript: printpreview();"> onclick="javascript: window.close();"> ------------------------------------------------ 关于这个组件还有其他的用法,列举如下: 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)关闭窗体无提示 2、分页打印 <%whilenotrs.eof%> <%=rs(0)%> <%rs.movenext%> <%wend%> 3、ASP页面打印时如何去掉页面底部的路径和顶端的页码编号 (1)ie的文件-〉页面设置-〉讲里面的页眉和页脚里面的东西都去掉,打印就不出来了。 (2) dimhkey_root,hkey_path,hkey_key hkey_root="HKEY_CURRENT_USER" hkey_path="/Software/Microsoft/InternetExplorer/PageSetup" '//设置网页打印的页眉页脚为空 functionpagesetup_null() onerrorresumenext SetRegWsh=CreateObject("WScript.Shell") hkey_key="/header" RegWsh.RegWritehkey_root+hkey_path+hkey_key,"" hkey_key="/footer" RegWsh.RegWritehkey_root+hkey_path+hkey_key,"" endfunction '//设置网页打印的页眉页脚为默认值 functionpagesetup_default() onerrorresumenext SetRegWsh=CreateObject("WScript.Shell") hkey_key="/header" RegWsh.RegWritehkey_root+hkey_path+hkey_key,"&w&b页码,&p/&P" hkey_key="/footer" RegWsh.RegWritehkey_root+hkey_path+hkey_key,"&u&b&d" endfunction
4、浮动帧打印
functionbutton1_onclick(){
varodoc=window.iframe1.document;
varr=odoc.body.createTextRange();
varstxt=r.htmlText;
alert(stxt)
varpwin=window.open("","print");
pwin.document.write(stxt);
pwin.print();
}
4、用FileSystem组件实现WEB应用中的本地特定打印
functionprint_onclick//打印函数
dimlabel
label=document.printinfo.label.value//获得HTML页面的数据
setobjfs=CreateObject("Scripting.FileSystemObject")//创建FileSystem组件对象的实例
setobjprinter=objfs.CreateTextFile("LPT1:
",true)//建立与打印机的连接
objprinter.Writeline("__________________________________")//输出打印的内容
objprinter.Writeline("||")
objprinter.Writeline("|您打印的数据是:
"&label&"|”)
objprinter.Writeline("||")
objprinter.Writeline("|_________________________________|")
objprinter.close//断开与打印机的连接
setobjprinter=nothing
setobjfs=nothing//关闭FileSystem组件对象
endfunction
服务器端脚本:
<%………
setconn=server.CreateObject("adodb.connection")
conn.Open"DSN=name;UID=XXXX;PWD=XXXX;"
setrs=server.CreateObject("adodb.recordset")
rs.Open(“select……”),conn,1,1
……….%>//与数据库进行交互
HTML页面编码:
………
………
————————————————————————————————
可以控制打印区域打印代码
先写入以下代码:
functiondoPrint(){
varstr="";
vararticle;
varcss;
varstrAdBegin="
--NEWSZW_HZH_BEGIN-->";
varstrAdEnd="
--NEWSZW_HZH_END-->";
varstrFontSize='【 doZoom(16)">大 doZoom(14)">中 doZoom(12)">小】' varstrdoPrint="doPrint()"; varstrTmp; css=""; str+=css; str+=' str+=' str+="
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- js 调用 打印机