[摘錄] Web 上打印的一些方法


          摘錄地址:http://blog.csdn.net/llwen218/archive/2006/06/07/778197.aspx

          一、利用IE內部打印組件:    
            這個方案也許是最簡單的,當然不會很“專業”。我們假設客戶端是IE6.0版本,因為在IE6.0中才完全體現我們所要應用的“打印模板機制”。它在精確控制頁面邊界,文本間隔,以及打印的統一性上,功能更為完備。    
              至于這種方案的實現也相當簡單,它主要只涉及到DEVICERECT,LAYOUTRECT兩種行為方式,分別用來定義整體頁面風格及單個頁面內容風格。而我們所要打印的HTML可以通過LAYOUTRECT的CONTENTSRC屬性來指定。可喜的是即使我們有1000個頁面要打印,也可以簡單的通過我們的打印模板添加動態修建HTML功能,實現單模板控制多文件風格。(請參考本文所附代碼)。這個方案在CSDN有詳細的介紹,但沒有附示例。示例文件可以在MSDN上下載得到。    
             
             
            二、利用外部DLL打印組件:    
             
              此類方案實現倒也不很復雜,只是利用DLL本身內部類函數操作,創建報表、格式并進行打印,而無需考慮內部實現環節。但對于WEB打印來說,似乎不合適。我個人認為在WEB上創建報表的HTML,然后利用客戶端IE打印是最好的解決方式。而如果你的C#或VB不是很好,那么外部DLL的類型解決是一個很讓人頭疼的事情,何況還要應用到WEB環境下。這種方案我用傻兒的打印組件調試過,但沒成功。    
             
            三、利用外部OCX類控件    
              這類方案和第二種差不多,也是建立在別人的成果的基礎上,但是在ASP.net下,如果沒有這個控件的說明書,我相信你也會和我一樣,不知道該從哪里下手開始設計。    
             
            四、利用XML解析打印    
              這種解決方案在微軟家園有很詳細的介紹,其原理就是解析出定義好的XML格式標記,解讀出文件中標記的參數定義,最后將這些信息還原成打印機輸出的圖形格式。很簡單的理解,例如你要打印一個簡單的表格,那么我們將表格解析成為文本和表格兩部分,程式設計時我們遇到文本文本則輸出文本到打印機,遇到表格標簽即輸出LINE到打印機。如此你可以自定義一些特殊的標簽,如圖片,特殊形狀等。這種方案開發起來很簡單,而且很“專業”,不過其缺點:客戶端需要安裝.NET   FrameWork.(傻了。。)    
             
            五、轉化為PDF文件,利用PDF打印    
              轉化為其它類型的文件輸出,是打印方案很常用的一種方式,而PDF文件格式以其優異的“品質”(打印品質)和“性能”(應用功能)無疑是一種很經濟的方式。而且從WEB向PDF轉換不是很困難,資源占用也不是很嚴重,這是它在同類方案中的優點,也是異類方案中的缺點。如此你可以去PDFCHINA上搜尋相關可用信息。    
             
            六、利用外部設計器設計報表,內部程式碼控制打印    
              這里我針對思路來講這種方案,并針對VISUAL DESIGNER報表組件。我們預先得利用設計器做好報表的格式,爾后在程式碼里面住報表各表單“套值”,就這么簡單。有點像ACCESS里面的報表設計方式。我所在公司的管理系統就是ACCESS寫的,所以我其實挺喜歡這種方案。至于VISUAL DESIGNER可以在CSDN下載到,并有開發說明書。    
             
            七、自己寫專業報表打印組件    
              這是*不得已的作法,當然更符合自己的要求,但是如果你不是專業的開發人員或有其它特殊目的,這些時間就不要花了。很羅索的。如果你有興趣寫,那么我建議你先看看第五種方案的思路和說明文檔。    
             
              WEB打印至今還沒有完美的解決方案,我個人期待IE在這一方面再加改進,以方便我們這一群“勞苦大眾”。    
             
            八、打印頁面:  
             
            <a   href="javascript:window.print()">   打印   </a>    
             
             
            打印時選擇內容進行打印:    
             
            往往在打印網頁時,執行window.print會把網頁的所有內容全部打印,而有一大部分比如網頁頭部的圖片、尾部的版權聲明、按鈕等,并沒有必要打印出來,打印出來浪費時間又浪費油墨。如何把這些內容進行有選擇的打印讓你的打印文本更簡潔明了,更省時美觀呢?以下就對這個問題寫一個JS文本,供有緣人參考。

          <script   language="javascript">  
            function   DtPrint()   {  
            if   (window.print)   {  
            var   p_1               =   document.all.p_1.innerHTML;  
            var   p_2           =   document.all.p_2.innerHTML;  
             
            這里根據你要打印的哪些內容,從原顯示頁面中用  
            <div   id=P_1>p_1....</div><div   id=P_2>p_2...</div>等標示,要打印多少項目就用多少下  
            提示一下,自己體會:),此處我只寫出兩個出來:D  
             
            var   css   =   '<style   type="text/css">'   +  
                'p   {     line-height:   120%}'   +  
                '.ftitle   {     line-height:   120%;   font-size:   18px;   color:   #000000}'   +  
                'td   {     font-size:   10px;   color:   #000000}'   +  
                '</style>'   ;  
             
            這里是定義打印用的CSS,可以根據你自己的設定去寫適合你的格式哦  
            本文只定義三個,p,.ftitle,td,其余自己寫。越美觀越好。  
             
            var   body   ='<table   width="640"   border="0"   cellspacing="0"   cellpadding="5">'   +  
                      '     <tr>   '   +  
                      '         <td     class="fbody">   '   +  
                      '             <div   align="center"   class=ftitle>'   +   p_title   +   '</div>'   +   p_2   +    
                      '         </td>'   +  
                      '     </tr>'   +  
                      '</table>';  
             
            body這才是你重新設置的打印格式,根據你的打印要求,重新把原顯示網頁的DIV內容重新  
            組合,可以根據你原來的表格內容,去掉不要打印的東東,只調用你要打印的內容  
            另外:根據經驗,表格大小為640左右正好是適合A4打印幅面!哈!  
             
            document.body.innerHTML   =   '<center>'   +   css   +   body   +   '</center>';  
             
            然后在這里把document.body重新設一下,這就是打印文檔!(有加CSS格式了)  
             
            window.print();  
             
            }  
            }  
            </SCRIPT>  
             
            在頁面中,然后通過:dtPrint()調用,就行了  
            比如:  
            <input   type="button"   value="打印"   LANGUAGE="javascript"   onclick="return    
            dtPrint()"   ID="Button2"   NAME="Button1">  
             
            噢!注意這個可以不用<div></div>標示哦,即使標示,也不用在以上打印文本中調用出來,那樣這個Button就不會打印出來了哦  




          歡迎大家訪問我的個人網站 萌萌的IT人

          posted on 2007-07-30 10:33 見酒就暈 閱讀(223) 評論(0)  編輯  收藏 所屬分類: 常用技術

          <2025年6月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          導航

          統計

          常用鏈接

          留言簿(3)

          我參與的團隊

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          收藏夾

          BLOG

          FRIENDS

          LIFE

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 城口县| 吴忠市| 开江县| 渝北区| 修水县| 五大连池市| 余江县| 安龙县| 罗甸县| 台东县| 顺义区| 宁武县| 青阳县| 四会市| 乐昌市| 黄梅县| 浦县| 柘荣县| 济阳县| 神池县| 唐海县| 洛扎县| 古田县| 延安市| 宁津县| 黄骅市| 金阳县| 交城县| 通海县| 耒阳市| 乃东县| 阿巴嘎旗| 潼南县| 忻州市| 枞阳县| 武胜县| 都江堰市| 双江| 合水县| 定州市| 卓资县|