介绍ScriptX控件
对于B/S架构的项目中,Web打印最是让程序员头痛的技术,在这次项目中运用了第三方控件ScriptX解决了此技术包括各种汇总表,详细清单等等,但最大弊端就是打印的格式是死的,你要打印出怎样的格式必须自己来做,还有就是打印分页,它是按你设置的纸张大小来分的,所以必须人为控制,ScriptX控件所需文件ScriptX.cab。(ScriptX下载地址http://www.meadroid.com/scriptx/freedep.asp )
打印功能使用:
⑴ 用户在客户端单击“打印”按钮,第一次使用打印会弹出如下对话框
⑵ 单击“是”按钮,此时会把控件ScriptX下载到本机
⑶ 在打印窗口中有大标题、打印条件、打印列表,单击“打印”按钮进入打印浏览界面。
⑷ 单击“Print”按钮,听打印机声音响起。
!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE> New Document </TITLE> <META NAME="Generator" CONTENT="EditPlus"> <META NAME="Author" CONTENT=""> <META NAME="Keywords" CONTENT=""> <META NAME="Description" CONTENT=""> <SCRIPT> //用于设置打印参数 function printBase() { factory.printing.header = "" //页眉 factory.printing.footer = "" //页脚 factory.printing.portrait = true //true为纵向打印,false为横向打印 factory.printing.leftMargin = 0.5 factory.printing.topMargin = 1.5 factory.printing.rightMargin = 0.5 factory.printing.bottomMargin = 1.5 } //用于调用设置打印参数的方法和显示预览界面 function printReport(){ printBase(); pagesetup_null(); document.all("button").style.display = "none";//隐藏按钮 factory.printing.Preview(); } //使界面最大化 maxWin(); function maxWin() { var aw = screen.availWidth; var ah = screen.availHeight; window.moveTo(0, 0); window.resizeTo(aw, ah); } function printTure() { printBase(); document.all("button").style.display = "none";//隐藏按钮 //factory.printing.Preview(); factory.printing.Print(false); document.all("button").style.display = "block";//显示按钮 } </SCRIPT> </HEAD> <BODY> <OBJECT id="factory" codeBase="ScriptX.cab#Version=6,3,434,26" height="0" width="0" classid="clsid:1663ed61-23eb-11d2-b92f-008048fdd814" viewastext> </OBJECT> <div id="button" style="PADDING-RIGHT: 0px; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; MARGIN: 0px; WIDTH: 98%; PADDING-TOP: 0px"> <table height="15" cellSpacing="1" cellPadding="4" width="100%" bgColor="#ddf3ff" border="0"> <tr> <td align="center" bgColor="#ddf3ff"> <input class="bginput" onclick="printTure()" type="button" value="打印"> <input id="idPrint2" type="button" value="页面设置" onclick="factory.printing.PageSetup()"> <input id="idPrint3" type="button" value="打印预览" onclick="factory.printing.Preview()"> </td> </tr> </table> </div> </BODY> </HTML>
在页面head标签下写上控件引用代码
<object id="factory" style="display: none" classid="clsid:1663ed61-23eb-11d2-b92f-008048fdd814" codebase="ScriptX.cab" viewastext> </object>
写上JAVASCRIPT代码,我只是简单举一个列子,属性下面会有列出
function Preview() { factory.printing.Preview(); //浏览 }
然后用一个按钮调用此JS方法就能实现简单打印,复杂的打印,需要你自己根据自己实际情况而定。
<input type="BUTTON" value="预览打印" onclick="Preview()" id="BUTTON1" name="printbtn">
下面讲列出该控件部分属性
// -------------------基本功能,可免费使用----------------------- factory.printing.header = "";//页眉 factory.printing.footer = "";//页脚 factory.printing.SetMarginMeasure(1);//页边距单位,1为毫米,2为英寸//边距设置,需要注意大部分打印机都不能进行零边距打印,即有一个边距的最小值,一般都是6毫米以上 //设置边距的时候时候如果设置为零,就会自动调整为它的最小边距 factory.printing.leftMargin = 1.0;//左边距 factory.printing.topMargin = 1.0;//上边距 factory.printing.rightMargin = 1.0;//右边距 factory.printing.bottomMargin = 1.0;//下边距 factory.printing.portrait = true;//是否纵向打印,横向打印为false //--------------------高级功能--------------------------------------------- factory.printing.printer = "EPSON LQ-1600KIII";//指定使用的打印机 //factory.printing.printer = "\\\\cosa-data\\HPLaserJ";//如为网络打印机,则需要进行字符转义 factory.printing.paperSize = "A4";//指定使用的纸张 factory.printing.paperSource = "Manual feed";//进纸方式,这里是手动进纸 factory.printing.copies = 1;//打印份数 factory.printing.printBackground = false;//是否打印背景图片 factory.printing.SetPageRange(false, 1, 3); //打印1至3页 //---------------------常用函数-------------------------------- factory.printing.Print(false);//无确认打印,true时打印前需进行确认 factory.printing.PrintSetup();//打印设置 factory.printing.Preview();//打印预览 factory.printing.WaitForSpoolingComplete();//等待上一个打印任务完全送入打印池,在连续无确认打印时非常有用 factory.printing.EnumPrinters(index);//枚举已安装的所有打印机,主要用于生成打印机选择功能