中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > Data URI 和 MHTML
解讀javascript的計時器 II 回到列表 關(guān)于浮動的前世今生
 Data URI 和 MHTML

作者:秦歌 時間: 2009-08-19 文檔類型:原創(chuàng) 來自:隨網(wǎng)之舞

秦歌(YanKaven) 的站點http://dancewithnet.com/

Data URI

Data URI 是由 RFC 2397 定義的一種把小文件直接嵌入文檔的方案。通過如下語法就可以把小文件變成指定編碼直接嵌入到頁面中:

data:[<MIME-type>][;base64],<data>

  1. MIME-type:指定嵌入數(shù)據(jù)的 MIME。其形式是[type]/[subtype]; parameter,比如png圖片對應(yīng)的MIME是image/png。parameter可以用來指定附加的信息,更多情況下是用于指定text/plain和text/htm等的文字編碼方式的charset參數(shù)。默認是text/plain;charset=US-ASCII。
  2. base64:聲明后面的數(shù)據(jù)的編碼是base64的,否則數(shù)據(jù)必須要用百分號編碼(即對內(nèi)容進行urlencode)。

在上個世紀 HTML4.01引入了Data URI方案 ,到今天為止除了IE6和IE7之外,所有主流瀏覽器都支持,但IE8對Data URI的支持還是有限制的,只支持object(僅是圖片時)、img、input type=image、link和CSS中的URL,且數(shù)據(jù)量不能大于32K。

優(yōu)點:

  1. 減少HTTP請求數(shù),沒有了TCP連接消耗和同一域名下瀏覽器的并發(fā)數(shù)限制。
  2. 對于小文件會降低帶寬。雖然編碼后數(shù)據(jù)量會增加,但是卻減少了http頭,當http頭的數(shù)據(jù)量大于文件編碼的增量,那么就會降低帶寬。
  3. 對于HTTPS站點,HTTPS和HTTP混用會有安全提示,而HTTPS相對于HTTP來講開銷要大更多,所以Data URI在這方面的優(yōu)勢更明顯。
  4. 可以把整個多媒體頁面保存為一個文件。

缺點

  1. 無法被重復(fù)利用,同一個文檔應(yīng)用多次同一個內(nèi)容,則需要重復(fù)多次,數(shù)據(jù)量大量增加,增加了下載時間。
  2. 無法被獨自緩存,所以其包含文檔重新加載時,它也要重新加載。
  3. 客戶端需要重新解碼和顯示,增加了點消耗。
  4. 不支持數(shù)據(jù)壓縮,base64編碼會增加1/3大小,而urlencode后數(shù)據(jù)量會增加更多。
  5. 不利于安全軟件的過濾,同時也存在一定的安全隱患。

MHTML

MHTML是MIME HTML (Multipurpose Internet Mail Extension HTML)的縮寫,是由RFC 2557定義的把一個多媒體的頁面所有內(nèi)容都保存到同一個文檔解決方案。這個方案是由微軟提出從IE5.0開始支持,另外Opera9.0也開始支持,Safari可以把文件保存為.mht(MHTML文件的后綴)格式,但不支持顯示它。

MHTML和Data URI還比較類似,有更強大的功能和更復(fù)雜的語法,并且沒有Data URI中“無法被重復(fù)利用”的缺點,但MHTML使用起來不夠靈活方便,比如對資源引用的URL在mht文件中可以是相對地址,否則必須是絕對地址。hedger在《Cross Browser Base64 Encoded Images Embedded in HTML》針對IE的解決方案使用的是相對路徑就是因為聲明了Content-type:message/rfc822使IE按照MHTML來解析,如果不修改Content-type則需要使用MHTML協(xié)議,這個時候必須使用絕對路徑,如《MHTML – when you need data: URIs in IE7 and under》。

應(yīng)用

Data URI和MHTML兩者的配合可以完整的解決所有的主流瀏覽器,它們由于無法被緩存和重復(fù)利用的缺陷,所以并不適合直接在頁面中使用,但在CSS和JavaScript文件中對圖片適當?shù)厥褂糜蟹浅4蟮膬?yōu)越性:

  1. 大大減少請求數(shù),現(xiàn)在大型網(wǎng)站的CSS引用了大量的圖片資源。
  2. CSS和JavaScript都可以被緩存,間接的實現(xiàn)了數(shù)據(jù)的緩存。
  3. 利用CSS可以解決Data URI的重復(fù)利用問題
  4. 告別CSS Sprites,CSS Sprites的出現(xiàn)是為了減少請求數(shù),但它除了帶來在不確定情況下的異常外,CSS Sprites還需要人為的圖片合并,即使有合并工具也依舊必須人為地在如何有效的拼圖上耗費大量的時間,并帶來維護的困難。當你遵循一定的設(shè)計原則后,你就可以完全拋棄CSS Sprites來編寫CSS,最后使用工具在上傳到服務(wù)器環(huán)節(jié)把圖片轉(zhuǎn)換成Data URI和MHTML,如《利用data-uri合并樣式表和圖片》中用python實現(xiàn)的工具,這可以節(jié)約大量的時間。
  5. base64編碼把圖片文件增加了1/3,Data URI和MHTML同時使用相當于增加了2/3,但CSS和JavaScript可以使用gzip壓縮,其可以節(jié)省2/3的數(shù)據(jù)量,所以使用gzip壓縮后的最終數(shù)據(jù)量是(1 + 1/3) * 2 * (1/3) = 8/9,所以最終流量是減少的。

為了方便在CSS中實現(xiàn)Data URI和MHTML,我寫了一個Data URI & MHTML 生成器,你可以看利用其生成Data URI & MHTML應(yīng)用實例。

在CSS文件中使用應(yīng)用MHTML時URL必須使用絕對路徑,導(dǎo)致非常不靈活,所以可以考慮使用CSS expression來解決(DEMO),比如:

   /*
   http://old9.blogsome.com/2008/10/26/css-expression-reloaded/
   http://dancewithnet.com/2009/07/27/get-right-url-from-html/
   */
  *background-image:expression(function(ele){
    ele.style.backgroundImage = 'url(mhtml:' +
         document.getElementById('data-uri-css').getAttribute('href',4) +
         '!03114501408821761.gif)';
   }(this));

原文:http://dancewithnet.com/2009/08/15/data-uri-mhtml/

本文鏈接:http://m.95time.cn/tech/web/2009/6955.asp 

出處:隨網(wǎng)之舞
責任編輯:bluehearts

◎進入論壇網(wǎng)頁制作、WEB標準化版塊參加討論,我還想發(fā)表評論。

相關(guān)文章
CFMX For F2K4 WebService
作者文章 更多作者文章
在HTML中獲取正確的URL屬性值
用doctype激活瀏覽器模式
border-radius與圓角
連續(xù)字符自動換行的解決方案
JavaScript的陷阱
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大福“敬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2