列印網頁中某一段內容

来源:http://www.cnblogs.com/insus/archive/2017/11/01/7765456.html
-Advertisement-
Play Games

很久之前,Insus.NET的寫過一篇,列印Web網頁的。今次嘗試使用jQuery來實現。 列印的網頁如下,需要列印的內容,使用一個div標簽包含起來。並給此div一個ID值,稍後在jQuery代碼會選擇到此div。另外還有放置一個銨鈕,讓用戶點一點此銨鈕,就能調用列印對話框進行列印。 <div i ...


很久之前,Insus.NET的寫過一篇,列印Web網頁的。
今次嘗試使用jQuery來實現。

列印的網頁如下,需要列印的內容,使用一個div標簽包含起來。並給此div一個ID值,稍後在jQuery代碼會選擇到此div。
另外還有放置一個銨鈕,讓用戶點一點此銨鈕,就能調用列印對話框進行列印。

 

<div id="divPrintContents">
        標題標題標題標題標題標題標題標題標題標題
        <br />
        <hr />
        <br />
        內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容 <br />
        內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容<br />
        內容內容內容內容內容內容內容<br />
        內容內容內容內容內容內容內容內容內容內容內容內容內容內容<br />
        內容內容內容內
    </div>
    <br />
    <input type="button" id="btnPrint" value="列印" />
Source Code


既然要使用jquery,那得在網頁上引用jQuery類庫:

<script src="~/Scripts/jquery-3.1.1.js"></script>


jQuery代碼:

 

 $(function () {
            $("#btnPrint").click(function () {
                var frame1 = $('<iframe />');
                frame1[0].name = "frame1";
                frame1.css({ "position": "absolute", "top": "-1000000px" });

                $("body").append(frame1);

                var frameDoc = frame1[0].contentWindow ? frame1[0].contentWindow :
                    frame1[0].contentDocument.document ? frame1[0].contentDocument.document : frame1[0].contentDocument;
                frameDoc.document.open();
                frameDoc.document.write('<html>');
                frameDoc.document.write('<head>');
                frameDoc.document.write('<title>分析報表</title>');
                frameDoc.document.write('<link href="style.css" rel="stylesheet" type="text/css" />');
                frameDoc.document.write('</head>');

                frameDoc.document.write('<body>');
                frameDoc.document.write($("#divPrintContents").html());
                frameDoc.document.write('</body>');

                frameDoc.document.write('</html>');
                frameDoc.document.close();

                setTimeout(function () {
                    window.frames["frame1"].focus();
                    window.frames["frame1"].print();
                    frame1.remove();
                }, 500);
            });
        });
Source Code

 
演示:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.1 快速部署方案 ✔ 問題:當領導給你 100 台已經安裝好系統的伺服器,然後讓優化,讓你提出一個快速部署方案。 解答: 1.tar 打包 先編譯安裝 打包--》分發--》解包(比如 mysql 打包後直接就可以使用 2.SaltStack,puppet,ansible 3.定製 rpm yum ...
  • 1、關掉不需要的外設的時鐘和電源開關; 2、在睡眠前設置IO引腳的狀態,根據硬體電路把IO置高或置低; 3、在低功耗狀態下是否需要內核運行,如果不需要,也要關掉電源或時鐘,如果不能關閉,看能否啟用低頻率的時鐘源; 4、註意RAM區,在低功耗下哪些可以不掉電,哪些會掉電,需要保存的數據可以放在不掉電的 ...
  • NFS通常用於網路中的多台電腦實現共用存儲。 由於測試環境沒有購買阿裡雲的NFS,所以自己搭建一個NFS文件系統,實現一些比如上傳圖片,靜態資源等同享功能。 下麵的測試是在CentOS release 6.8 (Final)中進行的。其他的系統略有不同。 網路環境 :nfs伺服器IP: 192.1 ...
  • 第一章:概述 1.1:make概述 在linux環境下使用make工具能夠比較容易的構建一個屬於自己的工程,整個工程的編譯只需要一個命令就可以完成編譯、連接以至於最後的執行。不過我們需要投入一些時間去學習如何完成makefile文件的編寫,這個文件也是make正常工作的基礎。 所要完成的makefi ...
  • 今天在手機App測試介面的時候發現一個通過POST方式的介面 獲取body中的參數一直為空,但是在數據量小的時候卻可以獲取到數據,開始懷疑是不是POST的長度有限制,然後在web.config中修改了一下maxRequestLength,如下 然後發現 獲取的值還是為空,然後在調試的過程中發現當數據 ...
  • Jquery在非同步提交方面封裝的很好,直接用AJAX非常麻煩,Jquery大大簡化了我們的操作,不用考慮瀏覽器的詫異了。 $.post、$.get是一些簡單的方法,如果要處理複雜的邏輯,還是需要用到jQuery.ajax() 一、$.ajax的一般格式 $.ajax({ type: 'POST', ...
  • 在較早博客隨筆裡面寫過文章《Winform開發框架之簡易工作流設計》之後,很久沒有對工作流部分進行詳細的介紹了,本篇繼續這個主題,詳細介紹其中的設計、實現及效果給大家,這個工作流在好幾年前就應用在市交通行業的審批系統上,經過不斷的改造適合更廣泛的審批流程處理,從最初的Web上擴展到WInform上,... ...
  • 前言 對於搞.net的朋友來說,經常會遇到關於事件和委托的問題:事件與委托有什麼關係?事件的本質是什麼?委托的本質又是什麼?由於.net 做了大量的封裝,對於初學者,這兩個概念確實不怎麼好理解。事件是用戶與應用程式交互的基礎,它是回調機制的一種應用。舉個例子,當用戶點擊按鈕時,我們希望彈出一句“您好 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...