<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    內蒙古java團隊

    j2se,j2ee開發組
    posts - 139, comments - 212, trackbacks - 0, articles - 65
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    JavaScript實現Web打印

    Posted on 2010-04-25 22:24 帥子 閱讀(2403) 評論(1)  編輯  收藏
    在Web中想用JavaScript實現打印功能,需要一個瀏覽器控件WebBrowser。WebBrowser是IE內置的瀏覽器控件,無需用戶下載,只需要在頁面簡單的設置,就可以Dom方法獲取到該對象.

      WebBrowser 控件為 WebBrowser ActiveX 控件提供了托管包裝。托管包裝使您可以在 Windows 窗體客戶端應用程序中顯示網頁。使用 WebBrowser 控件,可以復制應用程序中的 Internet Explorer Web 瀏覽功能,還可以禁用默認的 Internet Explorer 功能,并將該控件用作簡單的 HTML 文檔查看器。此外,可以使用該控件將基于 DHTML 的用戶界面元素添加到窗體中,還可以隱瞞這些元素在 WebBrowser 控件中承載的事實。通過這種方法,可以將 Web 控件和 Windows 窗體控件無縫地整合到一個應用程序中。

      WebBrowser 控件包含多種可以用來實現 Internet Explorer 中的控件的屬性、方法和事件。例如,可以使用 Navigate 方法實現地址欄,使用 GoBack、GoForward、Stop 和 Refresh 方法實現工具欄中的導航按鈕。可以處理 Navigated 事件,以便使用 Url 屬性的值更新地址欄,使用 DocumentTitle 屬性的值更新標題欄。

      用WebBrowser實現打印方法如下:

      1.引入一個WebBrowser:

      <object id=”WebBrowser” classid=CLSID:8856F961-340A-11D0-A96B-00C04FD705A2 height=”0″ width=”0″>

      </object>

      2. 隱藏不打印的頁面元素和分頁

      CSS 有個Media 屬性,可以分開設置打印和顯示的格式。

      如 <style media=”print” type=”text/css”> …</style> 中間的格式將只在打印時起作用,不會影響顯示界面。

      所以可以設定

      <style media=”print” type=”text/css”>

      .Noprint{display:none;}

      .PageNext{page-break-after: always;}

      </style>

      然后給不想打印的頁面元素添加: ,那就不會出現在打印和打印預覽中了。 想分頁的地方添加: <div></div> 就可以了。

      3. 頁面設置和打印預覽

      常用的:

      WebBrowser.ExecWB(1,1) 打開

      WebBrowser.ExecWB(2,1) 關閉現在所有的IE窗口,并打開一個新窗口

      WebBrowser.ExecWB(4,1) 保存網頁

      WebBrowser.ExecWB(6,1) 打印

      WebBrowser.ExecWB(7,1) 打印預覽

      WebBrowser.ExecWB(8,1) 打印頁面設置

      WebBrowser.ExecWB(10,1) 查看頁面屬性

      WebBrowser.ExecWB(15,1) 撤銷

      WebBrowser.ExecWB(17,1) 全選

      WebBrowser.ExecWB(22,1) 刷新

      WebBrowser.ExecWB(45,1) 關閉窗體無提示

      在ExtJs中實現打印

      簡單來說就是將要打印的innerHtml內賦值給window.document.body.innerHTM,然后調用window.focus():

      function doPrint(){

      var printArea=…….;//這個是取得要打印的那個組件

      window.document.body.innerHTML=printArea.innerHTML;

      window.focus();

      WebBrowser.ExecWB(6,6);

      }

      window.print()

      上面ExtJs打印代碼用到了window.print() ,實際上,window.print() 是瀏覽器打印功能菜單的一種程序調用。

      與點擊打印功能菜單一樣,不能精確分頁,不能設置紙型,套打的問題更加無從談起,只不 過,可以讓用戶不用去點菜單,直接點擊網頁中的一個按鈕,或一個鏈接里面調用罷了。事實上,很多用戶都是采用這種方式打印,但 是這種方式最致命的缺點是不能設置打印參數,比如紙型,頁邊距,選擇打印機等等。

      需要指出的是這種方法提供一個打印前和打印后的事件onbeforeprint、onafterprint。可以在打印前的時候重新編輯一些格式,專門送 去打印,打印后又處理回來。

      分享一個國內打印工具 JatoolsPrinter:官方網站

      jatoolsPrinter (杰表.打印控件)是一款實現網頁套打的專用工具。作為web應用開發者,我們經常會遇到在瀏覽器中打印報表、票據的需求,這些需求瀏覽器本身的打印功能 一般不能滿足, 如精確分頁,套打等。這就需要有一種能解決常見的瀏覽器端打印問題的軟件工具,這也是 jatoolsPrinter 的研發背景。

      jatoolsPrinter 的特點是可以直接對web頁面進行精確的分頁打印。jatoolsPrinter 通過在網頁中嵌入控件,解決了web客戶端精確打印,批量打印,打印配置自動保留等問題。

      Related posts:

      JavaScript判斷瀏覽器類型及版本

      獲取XMLHttpRequest的步驟

      JavaScript中的閉包

      javascript 彈出子窗口


    評論

    # re: JavaScript實現Web打印  回復  更多評論   

    2010-04-27 18:48 by bywqcnll
    jatoolsPrinter功能超強,價錢超貴.

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 免费无码AV一区二区| 亚洲欧洲日韩综合| 久操视频在线免费观看| 亚洲精品午夜在线观看| 成年人在线免费看视频| 国产亚洲精品第一综合| 亚洲av无码一区二区三区不卡| 国产91色综合久久免费| 国产亚洲日韩在线a不卡| 亚洲国产高清人在线| 天堂在线免费观看中文版| 久久免费香蕉视频| 亚洲免费福利视频| 久久亚洲AV无码西西人体| 亚洲一区免费在线观看| 一级毛片人与动免费观看| 亚洲国产精品午夜电影| 亚洲精品视频免费| 久久精品无码一区二区三区免费 | 亚洲色大成网站WWW久久九九| 成人永久免费高清| 两个人看的www高清免费观看| 亚洲 欧洲 自拍 另类 校园| 亚洲国产精品无码久久久不卡| 我要看免费的毛片| 无码人妻精品中文字幕免费| 美女18毛片免费视频| 亚洲国产综合自在线另类| 久久久久亚洲AV综合波多野结衣 | 亚洲国产一区视频| av大片在线无码免费| 91福利免费网站在线观看| 亚洲国产成人AV网站| 亚洲免费闲人蜜桃| 亚洲最大的成网4438| 精品国产日韩亚洲一区| 拔擦拔擦8x华人免费久久| 97性无码区免费| 久久久久久国产精品免费无码| 国产精品免费在线播放| 水蜜桃视频在线观看免费|