由于客戶要求,打印時需把打印的按鈕去掉。這個時候就用到了控制打印的樣式表了。 link rel=”stylesheet” type=”text/css” media=”print” href=”print.css” / 正因為xhtml和css是分離的,所以我們可以在print.css里自由書寫需要打印顯示的內(nèi)容和表現(xiàn)形式。那么這也要求我們在書寫xhtml的時候更 多考慮到打印顯示效果的需求,良好的擴展標記和結(jié)構(gòu)嵌套,使得我們輕松的使用display:none將內(nèi)容設(shè)置為不顯示。然后就是去書寫 print.css內(nèi)容的時候了,你象設(shè)置word一樣去寫你想打印的頁面吧。 后來想了想,其實單獨寫一個css增加了請求次數(shù),就想到了@media print{}的作用,代碼如下 @media print{ .printdesc { right: 0; width: 685px; height: 69px; background-color: #FFFFFF; float:left; overflow:auto; border:0px; } .text{ float:right; width: 688px; margin-top:20px; } .printlink{ height:0px; display:none; width:0px; z-index:-10; } .printlink a{ display:none; } } 后來想到如果打印頁面的某一部分,可以使用iframe來進行操作,現(xiàn)在的打印頁面的局部內(nèi)容基本上就是使用iframe進行處理。
華池ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18982081108(備注:SSL證書合作)期待與您的合作!
首先,你需要確定使用下面的?link 鏈接到一個專門的打印樣式表
link?rel=”stylesheet”?href=”print.css”?media=”print”?/
其次,放棄使用 padding-top 來控制每個打印頁的頭部樣式,而是使用下面的語句來控制每頁的上邊距
@page:first?{margin-top:30px}
其中 30 為你要設(shè)置的上邊距
CSS控制網(wǎng)頁打印樣式:
使用CSS控制打印樣式,剛剛使用時一塌糊涂,根本不知道CSS中的midia的作用是什么,問到別人說導(dǎo)入這個樣式,還傻乎乎的不知所措。
如果你也有這種現(xiàn)象,那么我告訴你吧,在W3school查到CSS的midia的作用。
link rel="stylesheet" media="print" type="text/css" href="print.css" /
style midia="print"http://midia必須聲明,不然無效了
#my_hidden{display:none;}
/style
2017-01-31
本文主要講解如何使用 CSS 控制打印樣式。
使用 CSS 可以控制文檔如何正確的顯示在不同的媒介 (Media) 上。其中分頁媒介 (Paged Media) ,不同于連續(xù)媒介 (Continuous Media),它可以控制文檔內(nèi)容,將其分隔至一個或多個不相關(guān)聯(lián)的頁面 (如:書、幻燈片)。
頁面 (Page Sheet) 是物理介質(zhì) (如:紙張) 的表面,它包含可打印區(qū)域 (Printable Areas) 和不可打印區(qū)域 (Non-printable Areas)。用戶代理可以調(diào)整文檔內(nèi)容的格式,使其顯示在可打印區(qū)域。
頁面盒子 (Page Box) 是一個由長邊 (Long Edge) 和短邊 (Short Edge) 組成的矩形。長邊的方向決定了頁面朝向 (Page Orientation),長邊是垂直方向,則頁面朝向為縱向 (Portrait Orientation),反之為橫向 (Landscape Orientation)。
CSS 打印無法指定文檔是否為雙面打印 (Duplex Printing),是否雙面打印應(yīng)該通過用戶代理指定。不管是否雙面打印,CSS 打印總是包含左頁和右頁 (分別通過 :left , :right 指定) 。(或者說 CSS 打印假定所有文檔是雙面打?。?/p>
和 CSS 盒子模型一樣,頁面盒子模型由外邊距 (margin)、邊框 (border)、內(nèi)邊距 (padding) 和 內(nèi)容區(qū)域 (content area) 構(gòu)成。
其中內(nèi)容區(qū)域和外邊距有著特殊的功能:
頁面進度 (Page Progression)方向 是文檔被分隔后的頁面的排列方向。比如:現(xiàn)代中文頁面進度多是從左至右;而古代中文的頁面進度則相反。可以通過設(shè)置根元素 (root element) 的 direction 和 writing-mode 屬性來改變頁面進度。
頁面的“第一頁”是左頁還是右頁,可以由頁面進度的方向決定,當頁面進度方向為從左至右時,第一頁是右頁;反之為左頁。(事實上也可以通過設(shè)置根元素的 break-before 屬性來強制改變第一頁是左頁還是右頁)
在 CSS 中使用 @media print
在 CSS 中使用 @import
在 HTML 中使用 link 標簽
在 @media print 或 my-print-style.css 中,可以自由的修改大部分樣式。
使用打印媒介查詢可以自定義很多樣式,當希望改變頁面大小、邊距等,就需要用到 @page 了。頁面上下文 (Page Context) 中僅支持部分 CSS 屬性,支持的屬性有: margin 、 size 、 marks 、 bleed 以及頁面外邊距盒子等,不支持的屬性將會被忽略。
注:常見瀏覽器都不支持該屬性,推薦使用 Prince
頁面的外邊距被分成了 16 個頁面外邊距盒子。每個外邊距盒子都有自己的外邊距、邊框、內(nèi)邊距和內(nèi)容區(qū)域。頁面外邊距盒子用于創(chuàng)建頁眉和頁腳,頁眉和頁腳是頁面的一部分,用于補充信息,如頁碼或標題。
頁面外邊距盒子需要在 @page 下使用,使用起來和偽類類似,也包含 content 屬性。
margin 系列屬性( margin-top 、 margin-right 、 margin-bottom 、 margin-left 和 margin )用于指定頁面外邊距大小。
在 CSS2.1 中,頁面上下文中只支持 margin 系列屬性。而且因為 CSS2.1 的頁面上下文中沒有字體的概念, margin 系列屬性的值的單位不支持 em 和 ex 。
size 屬性支持 auto 、 landscape 、 portrait 、 length{1,2} 和 page-size 。
頁面上下文也支持使用偽類,其中支持的偽類有: :left 、 :right 、 :first 和 :blank 。
需要雙面打印時,通常需要將左頁和右頁設(shè)置不同的樣式(如頁邊距、頁碼位置)。這時左頁和右頁可以分別用 :left 和 :right 表示。再次強調(diào), 通過 :left 和 :right 設(shè)置左右頁面不同樣式,并不代表用戶代理會將頁面雙面打印
偽類 :first 用于匹配到文檔的第一頁。
偽類 :blank 用于匹配文檔的空白頁。
注意,空白頁既可能是左頁,又可能是右頁,設(shè)置左頁或右頁的樣式也會顯示在空白頁上,如果不希望顯示在空白頁上,可以清除這些樣式。
用于控制元素之前、之后或之中是否分頁, 沒有生成盒子的塊元素不會生效 。
page-break-before 、 page-break-after 屬性支持 auto 、 always 、 avoid 、 left 、 right 、 recto 和 verso 。
page-break-inside 屬性僅支持 auto 和 avoid ,表示在元素內(nèi)允許或禁止分頁。
orphans 和 windows 用于指定在頁面的底部或頂部,元素中允許剩余的最少行數(shù),默認為 2 行。
示例:
參考鏈接:
套正常的css網(wǎng)頁展示的樣式,另一套專門給打印的時候用的CSS樣式,只要用戶打印,就會通過媒體查詢自動用打印的專門樣式。這樣,既可以在瀏覽器很好展示效果,也不影響具體打印出來的效果。
正常瀏覽器用的樣式
link rel="stylesheet" type="text/css" media="screen" href="/css/styles.css" /專門打印用的樣式link rel="stylesheet" type="text/css" media="print" href="/css/print.css" /
其中media指定的屬性就是設(shè)備,顯示器上就是screen,打印機則是print,電視是tv,投影儀是projection。