從" />

日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

把XHTML/CSS頁面轉(zhuǎn)換成為打印機(jī)頁面

系統(tǒng) 2399 0

把XHTML/CSS頁面轉(zhuǎn)換成為打印機(jī)頁面
作者: Builder.com
2004-03-23 03:3 PM

在以前,為Web頁面創(chuàng)建一個(gè)打印機(jī)友好的版本意味著要設(shè)計(jì)一個(gè)布局和格式都經(jīng)過修改的單獨(dú)頁面,這樣才能夠在打印的時(shí)候獲得令人滿意的效果。現(xiàn)在,通過使用結(jié)構(gòu)化的XHTML和CSS,你可以實(shí)現(xiàn)同樣的效果而只用花費(fèi)少得多的精力。

<!--start banner ad--><!--ba--> <noscript></noscript> <!--end banner ad-->

從屏幕顯示到打印效果

大多數(shù)的Web頁面都是設(shè)計(jì)適用于在計(jì)算機(jī)屏幕上觀看的。然而,有的時(shí)候用戶需要將某些頁面打印出來,也許就是為了保留一個(gè)長期的記錄,或者將其用作方便的離線參考資料。

現(xiàn)在的麻煩是,讓W(xué)eb頁面在計(jì)算機(jī)彩色屏幕上看起來引人注目和五彩繽紛的很多特性,都無法在打印版的Web頁面上表現(xiàn)出相同的效果——尤其當(dāng)打印機(jī)是黑白的時(shí)候。在被降級(jí)為灰度打印的時(shí)候,彩色的組合會(huì)失去(原有的)對(duì)比效果;圖形會(huì)看起來失真,而且耗費(fèi)太長的打印時(shí)間;在Web頁面上起著重要作用的導(dǎo)航按鈕在打印頁面上也毫無用處。

為了克服這些問題,Web的創(chuàng)建者常常會(huì)為頁面專門設(shè)計(jì)一個(gè)打印機(jī)友好的版本,這樣訪問者就有打印的欲望。打印機(jī)友好的版本通常都包括有和主要Web頁面相同的內(nèi)容,但是會(huì)省略掉大多數(shù)的圖形、背景和導(dǎo)航元素。頁面還會(huì)把彩色轉(zhuǎn)換成某種形式,以便生成能夠讓人接受的灰度圖像。

CSS的解決方案

使用結(jié)構(gòu)化的XHTML標(biāo)示和CSS格式將內(nèi)容和表示分離開來的一個(gè)優(yōu)勢(shì)在于,通過更改CSS樣式,你可以很輕易就把內(nèi)容重新格式化。因此,創(chuàng)建一個(gè)打印機(jī)友好的頁面就是把一個(gè)不同的CSS文件鏈接到相同的XHTML頁面上。

你可以同時(shí)把屏幕樣式表和打印樣式表鏈接到同一個(gè)XHTML文件里,所以就沒有必要單獨(dú)創(chuàng)建一個(gè)打印機(jī)友好的頁面,只需要一個(gè)打印機(jī)友好的樣式表就行了。當(dāng)你在鏈接代碼里加入多媒體類型的文件時(shí),這就是在告訴瀏覽器為了進(jìn)行屏幕輸出要遵循或者忽略哪些CSS的規(guī)則,而為了打印輸出要使用哪些規(guī)則。

下面是鏈接到一對(duì)CSS文件的例子:

<link rel="stylesheet" type="text/css" media="screen" href="mysite-screen.css"
/>
<link rel="stylesheet" type="text/css" media="print" href="mysite-print.css" />

如果需要支持老版本的瀏覽器,那你就必須堅(jiān)持使用CSS1的媒體描述符 screen print 。它們是相互排斥的,因此在為屏幕顯示而生成頁面的時(shí)候,瀏覽器會(huì)忽略掉打印樣式表,反之亦然。所以,每個(gè)樣式表都需要包含相同的樣式選擇器,但是有不同的規(guī)則聲明,以便為不同的輸出設(shè)備分別生成頁面樣式。

簡化的CSS
<!--start banner ad--><!--ba--> <noscript></noscript> <!--end banner ad-->

如果你愿意放棄照顧老版本的瀏覽器,并假設(shè)你的用戶正在使用支持CSS2的瀏覽器(比如說IE5及以上版本或者Netscape 6及以上版本),你可以使用新的 all 媒體描述符來極大地簡化CSS代碼。

下面就是使用CSS2媒體描述符的鏈接的例子:

<link rel="stylesheet" type="text/css" media="all" href="mysite-all.css" />
<link rel="stylesheet" type="text/css" media="print" href="mysite-print2.css"
/>

這些鏈接幾乎和前面的完全一樣;不同之處在于CSS文件里包含有用于打印媒體的樣式。

CSS文件里同 media="all" 聯(lián)系在一起的樣式可以應(yīng)用于屏幕顯示、打印,以及其他所有的媒體,所以你可以把所有創(chuàng)建的樣式都放到這個(gè)文件里。同 media="print" 單獨(dú)聯(lián)系在一起的CSS文件可以小得多,因?yàn)轫撁鎻乃械拿襟w文件繼承了所有的樣式,這就沒有必要再復(fù)制打印媒體文件里的這些樣式了。

打印媒體CSS文件里唯一需要的樣式是那些為打印輸出而更改或者添加頁面樣式。一般來說,這只不過是一些禁止顯示包含有圖形和導(dǎo)航內(nèi)容的div的樣式,和把主體標(biāo)簽以及主要div的寬度和空白設(shè)置替換成適合打印輸出的設(shè)置。

這個(gè)技巧能夠起作用是因?yàn)樗械拿襟wCSS文件和打印媒體CSS文件都組合成了相同的層疊樣式規(guī)則。因此,對(duì)這些CSS文件的鏈接順序相當(dāng)重要。所有的媒體文件鏈接都必須要放在打印媒體文件鏈接之前。

下面是一些關(guān)于使用打印媒體CSS文件的提示:

  • 如果禁止某個(gè)div的顯示,就要使用display: none而不能用visibility: hidden。
  • 點(diǎn)(pt)和英寸(in)都不是用于屏幕顯示的正確度量單位,但是它們是打印輸出的正確度量單位。
  • 在打印媒體文件里使用的選擇器要和你在所有媒體文件里使用的選擇器完全相同。例如,如果你使用div#sidenav來選擇所有媒體文件里id為sidenav的div,那么在打印媒體文件里使用#sidenav就可能無法成功地達(dá)到你的目的。
  • 不要忘記明確地強(qiáng)制替代從一個(gè)文件到另一個(gè)文件都會(huì)發(fā)生改變的規(guī)則聲明。例如,如果你在所有的媒體文件里為一個(gè)元素設(shè)置了padding,并希望在打印輸出里去掉這個(gè)padding,那么在打印媒體文件里加入一個(gè)忽略padding聲明的樣式是不夠的——你必須明確地設(shè)置padding: 0pt,以取代前面的設(shè)置。
  • 如果你正在使用諸如Dreamweaver這樣的圖形編輯器,你就可以預(yù)覽生成頁面的屏幕效果,而不是打印輸出的效果。要在Dreamweaver的設(shè)計(jì)(Design)查看窗里預(yù)覽打印樣式,就要把到打印媒體CSS文件的鏈接改成media="screen"。這就讓你可以預(yù)覽打印媒體文件里的CSS樣式。不要忘了在發(fā)布你的頁面之前把媒體描述符改回到media="print"。

當(dāng)你需要為自己的訪問者提供一個(gè)打印機(jī)友好的Web頁面,你不再需要為原有的頁面創(chuàng)建一個(gè)單獨(dú)的版本。添加一個(gè)對(duì)帶有 media="print" 媒體描述符的CSS樣式表的鏈接,就能夠把任何XHTML/CSS頁面轉(zhuǎn)換成為一個(gè)打印機(jī)友好的頁面。


本文作者:Michael Meadhra在Web發(fā)展的最初階段就在這一領(lǐng)域從事開發(fā)。他出版的書已累積幾十種,包括即將上市的由Osborne/McGraw-Hill發(fā)行的《如何用Dreamweaver MX 2004做到一切(How to Do Everything with Dreamweaver MX 2004)》。

把XHTML/CSS頁面轉(zhuǎn)換成為打印機(jī)頁面


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 揭阳市| 安龙县| 和顺县| 观塘区| 马公市| 桃源县| 读书| 丹巴县| 大邑县| 诸城市| 曲麻莱县| 台安县| 全椒县| 读书| 中牟县| 托里县| 灵丘县| 永胜县| 乐陵市| 庆阳市| 拉孜县| 田林县| 昌邑市| 灵丘县| 常州市| 江城| 小金县| 大安市| 吕梁市| 南江县| 长白| 益阳市| 迭部县| 龙口市| 常德市| 元氏县| 皋兰县| 钦州市| 绥化市| 都安| 扬州市|