做過很多的Web項目,大多數(shù)在打印頁面內(nèi)容的時候,采用的都是通過Javascript調(diào)用系統(tǒng)內(nèi)置的打印方法進行打印,也就是調(diào)用 PrintControl.ExecWB(?,?)實現(xiàn)直接打印和打印預(yù)覽功能。
打印的效果及控制性雖然不是很好,但是也能勉強使用,應(yīng)付一般的打印還是 可以的了。
代碼如下所示: 代碼 代碼如下: //調(diào)用PrintControl.ExecWB(?,?)實現(xiàn)直接打印和打印預(yù)覽功能。(直接用系統(tǒng)提供的print()方法打印無法隱藏某些區(qū)域) //preview:是否顯示預(yù)覽。null/false:不顯示,true:顯示 function printPage(preview) { try { var content=window.document.body.innerHTML; var oricontent=content; while(content.indexOf("{$printhide}")>=0) content=content.replace("{$printhide}","style='display:none'"); if(content.indexOf("ID="PrintControl"")<0) content=content+"<OBJECT ID="PrintControl" WIDTH=0 HEIGHT=0 CLASSID="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2"></OBJECT>"; window.document.body.innerHTML=content; //PrintControl.ExecWB(7,1)打印預(yù)覽,(1,1)打開,(4,1)另存為,(17,1)全選,(10,1)屬性,(6,1)打印,(6,6)直接打印,(8,1)頁面設(shè)置 if(preview==null||preview==false) PrintControl.ExecWB(6,1); else PrintControl.ExecWB(7,1); //OLECMDID_PRINT=7; OLECMDEXECOPT_DONTPROMPTUSER=6/OLECMDEXECOPT_PROMPTUSER=1 window.document.body.innerHTML=oricontent; } catch(ex){ alert("執(zhí)行Javascript腳本出錯。"); } } function printConten(preview, html) { try { var content=html; var oricontent=window.document.body.innerHTML; while(content.indexOf("{$printhide}")>=0) content=content.replace("{$printhide}","style='display:none'"); if(content.indexOf("ID="PrintControl"")<0) content=content+"<OBJECT ID="PrintControl" WIDTH=0 HEIGHT=0 CLASSID="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2"></OBJECT>"; window.document.body.innerHTML=content; //PrintControl.ExecWB(7,1)打印預(yù)覽,(1,1)打開,(4,1)另存為,(17,1)全選,(10,1)屬性,(6,1)打印,(6,6)直接打印,(8,1)頁面設(shè)置 if(preview==null||preview==false) PrintControl.ExecWB(6,1); else PrintControl.ExecWB(7,1); //OLECMDID_PRINT=7; OLECMDEXECOPT_DONTPROMPTUSER=6/OLECMDEXECOPT_PROMPTUSER=1 window.document.body.innerHTML=oricontent; } catch(ex){ alert("執(zhí)行Javascript腳本出錯。"); } } 上面兩個函數(shù)放在一個Js文件中,在頁面內(nèi)容中通過應(yīng)用該腳本文件并調(diào)用進一步封裝的函數(shù)即可打印指定部分的內(nèi)容: 代碼如下: <script language="javascript"> function Print(preview) { var text = document.getElementById("content").innerHTML; printConten(preview, text); } 打印的效果大致如下圖所示,如果打印的頁面在框架頁面中,那么需要選定“僅打印選定框架”的選項。 ![]() 采用此種方法,不需要安裝任何控件,具有很好的兼容優(yōu)勢,不過出來的報表內(nèi)容,好像控制起來會比較麻煩一些,特別對于一些報表方面的打印,需要輸出復(fù)雜的內(nèi)容是,也有一定的缺陷,但總體來說,也是一個較好的選擇。 后來在需要做一些證件套打方面的工作,這個控件就做不到了,因此需要一種方法或者控件,能夠較好處理套打方面的事情。 無意間,發(fā)現(xiàn)一個比較好的打印控件,支持各種格式的打印,還有我關(guān)心的證件套打功能,功能強大,使用也很簡單的,非常值得推薦。 控件的相關(guān)地址: 控件下載 http://www.jb51.net/codes/23956.html 控件博客介紹:http://blog.sina.com.cn/s/articlelist_1340389911_0_1.html
應(yīng)用這個控件,普通報表的打印效果如下所示:
上面兩個報表的打印其實都差不多,都是打印部分的HTML內(nèi)容,不過后者看起來要好一點,而且提供很完善的報表功能設(shè)置。 代碼大致如下所示。 如果給打印內(nèi)容設(shè)置了樣式,那么出來的界面效果就好很多了。
|
|
來自: 悟靜 > 《.net和asp.net》