狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

使用 CSS 打印樣式為 Web 頁面設置專業(yè)的打印機效果

freeflydom
2024年8月5日 23:33 本文熱度 1251

導讀

對于有打印需求的網(wǎng)頁,特別是文章的詳情頁,需要設置專門的打印樣式來適配頁面。CSS 打印樣式允許你為網(wǎng)頁設置專門用于打印的樣式。文本就是專門介紹如何使用 CSS 打印樣式為 Web 頁面設置專業(yè)的打印機效果。

@media print

通過使用 @media print 媒體查詢,你可以定義打印時使用的CSS規(guī)則。聲明打印樣式有兩種方法:

使用 @media print 的媒體查詢

@media print {

    .no-print {

        display: none;

    }

}

在 style 或者 link 標簽使用 media=print 屬性

<style media="print">...</style> 

<link rel="stylesheet" media="print" />

CSS 打印樣式常見技巧

以下是一些常見的 CSS 打印樣式設置的技巧:

隱藏不必要的內(nèi)容

在打印時,一般都只需要顯示頁面中的正文內(nèi)容,因此需要隱藏導航欄、廣告等不需要打印的元素。

@media print {

    .no-print {

        display: none;

    }

}

設置打印友好的字體和顏色

打印機的顯示和 Web 頁面的顯示還是有一定區(qū)別的。要知道,不是所有的瀏覽器默認的背景顏色都是白色,默認的字體顏色是黑色的。設置打樣樣式是需要使用簡單的字體和明確指定白背景色和黑色文字顏色來確保打印的清晰度。

@media print {

    body {

        font-family: Arial, sans-serif;

        color: #000;

        background: #fff;

    }

}

!important 確保瀏覽器采用 print 的樣式

上面的實例代碼中都使用了 !important,這是因為在設置 print 的樣式時,普通 Web 頁面通用樣式的層疊,可能會導致打印樣式失效,這時需要特別采用 !important 來確保瀏覽器采用print下面的樣式,例如:

@media print {

  .outline {

    &-message,

    &-toolbar {

      /* 隱藏不必要的內(nèi)容 */  

      display: none !important;

    }

  }  

}

字體大小

在CSS打印樣式中設置字體大小時,有幾個關鍵點和建議可以幫助你確保打印輸出的可讀性和一致性。

使用相對單位

如果你的 Web 頁面使用的是相對單位(如em、rem、%)。那么打印樣式也應該保持一致,基礎字體設置絕對大小,其它均用相對單位,可以使字體大小相對于父元素或根元素調(diào)整,確保打印時的比例一致。

@media print {

  body {

      /* 基礎字體大小使用絕對值 */

      font-size: 12pt !important; 

  }

  

  h1 {

     /* 繼承自body的2倍字體大小 */

      font-size: 2em !important; 

  }

  

  p {

      /* 與body相同的字體大小 */

      font-size: 1em !important; 

  }

}

使用絕對單位

如果你的 Web 頁面使用的是絕對單位(如px、in、cm),那么打印樣設置時要使用 pt 單位設置基礎文字大小,pt 值和 px 值要最好相等,以確保打印時的字體大小固定,不受屏幕大小或其他因素的影響。

@media print {

    /* 全局字體大小 */

    body {

         

    }

    

    /* 標題字體大小 */

    h1 {

        font-size: 14pt; 

    }

    

    /* 段落字體大小 */

    p {

         

    }

}

pt 和 px 的關系

使用絕對值的時候,pt 的值怎么才能跟 Web 頁面中的 px 對應呢?例如前文中希望在打印樣式中使用的字體大小的絕對值與 Web 中的字體大小保持一致,要如何換算呢?

在 CSS中,pt(點)和 px(像素)是常用的單位,用于設置字體大小和其他尺寸。計算它們之間的轉(zhuǎn)換可以幫助你在不同的環(huán)境中保持一致的樣式。

標準屏幕分辨率(96 DPI)

1pt = 1/72 英寸

1英寸 = 96 像素

因此,1pt = 96/72 像素 ≈ 1.333px

公式

從pt轉(zhuǎn)換為px:px = pt * 96 / 72

從px轉(zhuǎn)換為pt:pt = px * 72 / 96

從 pt 轉(zhuǎn)換為 px

12pt 轉(zhuǎn)換為 px:12 * 96 / 72 = 16px

14px 轉(zhuǎn)換為 px:10 * 96 / 72 ≈ 13.33px

從 px 轉(zhuǎn)換為 pt

16px 轉(zhuǎn)換為 pt:16 * 72 / 96 = 12pt

14px 轉(zhuǎn)換為 pt:14 * 72 / 96 ≈ 14px

順便說一下,設置打印樣式的字體大小時,推薦的單位是 pt。

調(diào)整布局

在設置打印樣式,由于受到打印顯示區(qū)域的寬度顯示,無法向 Web 頁面那樣在一個很寬的區(qū)域顯示內(nèi)容,在打印預覽時很多除浮動和固定定位的內(nèi)容會換行或者顯示不正常。這是就需要調(diào)整布局,移除浮動和固定定位,使內(nèi)容在打印時更加整齊。

@media print {

    .float-element {

        float: none !important;

    }

    .fixed-element {

        position: static !important;

    }

}

分頁

控制分頁符的位置,避免內(nèi)容在打印時被不合理地分割。例如:

@media print {

  .page-break {

      /* 在元素之前插入分頁符 */

      page-break-before: always !important; 

      /* 避免在元素內(nèi)部插入分頁符 */

      page-break-inside: avoid !important; 

  }

}

需要說明的是,這個分頁控制需要根據(jù)特定的頁面內(nèi)容來設置。不是一個通用的設置技巧,并且根據(jù)我的個人實踐來說,一般都不會特意設置分頁控制的打印樣式。

鏈接和媒體處理

打印界面是無法顯示 Web 頁面中的視頻和音頻信息的,因此需要隱藏視頻、音頻等無法打印的媒體元素,并顯示鏈接的 URL。

@media print {

  a:after {

      /* 技巧1:在鏈接文字后顯示 URL 地址 */

      content: " (" attr(href) ")";

  }

  /* 技巧2:在鏈接文字顯示下劃線和高亮色顯示 */

  a:link,

  a:visited:

  a:hover {

     text-decoration: underline;

     color: #507afe;      

  }

  video, audio {

      display: none !important;

  }

}

說明:bootstrap 之類的 CSS 庫也會有一些打印樣式的設置,如果你的 Web 頁面使用第三方庫的,需要看看打印效果。例如 bootstrap 就設置技巧1那樣的額外顯示 URL 地址的鏈接文字,如果你不需要,需要這樣覆蓋:

@media print {

  a:after {

      /* 技巧1:在鏈接文字后顯示 URL 地址 */

      content: "" !important;

  }

}  

表格打印優(yōu)化

確保表格在打印時的邊框和對齊方式清晰。

@media print {

  table {

      width: 100%;

      border-collapse: collapse;

  }

  th, td {

      border: 1px solid #000;

      padding: 8px;

  }

}

頁眉和頁腳

如果希望打印時顯示頁面的相關信息,還可以在打印樣式中為每頁添加頁眉和頁腳,用以顯示標題、頁碼等信息,并且還可以設置打印的頁邊距。

@media print {

  @page {

    /* 設置打印的頁邊距 */

    /* 設置內(nèi)容的上下邊距,以避免頁眉和頁腳覆蓋內(nèi)容 */

    margin: 1in;

    

    /* 其它可選位置:@top-left @top-right */

    @top-center {

        /* 頁眉左側(cè)顯示標題 */

        content: "Document Title"

    }

    

    /* 其它可選位置:@bottom-left @bottom-right */

    @bottom-center {

        /* 頁腳右側(cè)顯示頁碼 */

        content: "Page "counter(page) " of "counter(pages); 

    }

  }

}

CSS 打印樣式的應用實踐

這里還是以我的 outline.js 項目為例,以下是使用了 outline.js 頁面的原始界面:

 

這個是打印預覽界面:

 

前文介紹的主要的打印頁面的技巧在 outline.js 中基本都用到了。以下是完整的打印樣式代碼:

@media print {

  html,

  body {

    /* 打印的基礎字體大小 */

    font-size: 12pt;

    /* 顯示設置文字顏色和背景顏色 */

    background-color: @white;

    color: @primary_text_color;

    height: initial !important;

  }

  /* 設置鏈接樣式 */

  a:link,

  a:visited,

  a:hover {

    text-decoration: underline !important;

    color: @primary_color;

  }

  /* 隱藏媒體標簽 */

  video,

  audio {

    display: none !important;

  }

  /* 確保表格在打印時的邊框和對齊方式清晰 */

  table {

    width: 100%;

    border-collapse: collapse;

  }

  th,

  td {

    border: 1px solid @primary_border_color;

    padding: 8px 20px;

  }

  .outline {

    &-message,

    &-toolbar {

      /* 隱藏了工具欄和信息提示框 */

      display: none !important;

    }

    &-reader {

      display: block !important;

      overflow: hidden;

      &__title {

        margin: 13.4pt 0 28pt !important;

        text-align: center !important;

        font-size: 32pt !important;

      }

      /* 取消了絕對定位 */

      &--reading {

        position: relative !important;

        height: auto !important;

        padding: 0 !important;

        background-color: @white;

        overflow: hidden !important;

      }

      /* 隱藏閱讀進度條 */

      &__progress {

        display: none !important;

      }

      /* 打印時不顯示正文 DOM 的陰影效果 */

      &__paper {

        box-shadow: none;

      }

      pre {

        padding: 1em !important;

        border: 1px solid @border_color !important;

        border-radius: 4px !important;

      }

      pre,

      code {

        background-color: @white !important;

      }

      table,

      img,

      svg {

        break-inside: avoid;

      }

      /* 所有文章內(nèi)容 DOM 相關的鄰居節(jié)點都隱藏了 */

      &_sibling {

        display: none !important;

      }

    }

  }

}

設置打印樣式的基礎字體大小和文字和背景顏色:

@media print {

  html,

  body {

    /* 打印的基礎字體大小 */

    font-size: 12pt;

    /* 顯示設置文字顏色和背景顏色 */

    background-color: @white;

    color: @primary_text_color;

    height: initial !important;

  }

}

設置鏈接文字高亮顯示

@media print {

  /* 設置鏈接樣式 */

  a:link,

  a:visited,

  a:hover {

    text-decoration: underline !important;

    color: @primary_color;

  }

}

隱藏媒體標簽(內(nèi)容)

@media print {

  /* 隱藏媒體標簽 */

  video,

  audio {

    display: none !important;

  }

}

確保表格在打印時的邊框和對齊方式清晰

@media print {

  /* 確保表格在打印時的邊框和對齊方式清晰 */

  table {

    width: 100%;

    border-collapse: collapse;

  }

  th,

  td {

    border: 1px solid @primary_border_color;

    padding: 8px 20px;

  }

}

隱藏了非正文 DOM 的所有其他內(nèi)容

@media print {

  .outline {

    &-message,

    &-toolbar {

      /* 隱藏了工具欄和信息提示框 */

      display: none !important;

    }

    

    /* 隱藏閱讀進度條 */

    &__progress {

      display: none !important;

    }

    

    /* 所有文章內(nèi)容 DOM 相關的鄰居節(jié)點都隱藏了 */

    &_sibling {

      display: none !important;

    }

  }  

}

作者:自由的巨浪

鏈接:https://juejin.cn/post/7398472542313611276

來源:稀土掘金

著作權歸作者所有。商業(yè)轉(zhuǎn)載請聯(lián)系作者獲得授權,非商業(yè)轉(zhuǎn)載請注明出處。



該文章在 2024/8/6 11:22:59 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調(diào)度、堆場、車隊、財務費用、相關報表等業(yè)務管理,結(jié)合碼頭的業(yè)務特點,圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved