国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

Data URI和MHTML完整解決所有瀏覽器_0

2020-03-24 18:19:45
字體:
來源:轉載
供稿:網友
Data URIData URI 是由 RFC 2397 定義的一種把小文件直接嵌入文檔的方案。通過如下語法就可以把小文件變成指定編碼直接嵌入到頁面中:data:[ MIME-type base64], data MIME-type:指定嵌入數據的 MIME。其形式是[type]/[subtype]; parameter,比如png圖片對應的MIME是image/png。parameter可以用來指定附加的信息,更多情況下是用于指定text/plain和text/htm等的文字編碼方式的charset參數。默認是text/plain;charset=US-ASCII。 base64:聲明后面的數據的編碼是base64的,否則數據必須要用百分號編碼(即對內容進行urlencode)。 在上個世紀 HTML4.01引入了Data URI方案,到今天為止除了IE6和IE7之外,所有主流瀏覽器都支持,但IE8對Data URI的支持還是有限制的,只支持object(僅是圖片時)、img、input type=image、link和CSS中的URL,且數據量不能大于32K。優點: 減少HTTP請求數,沒有了TCP連接消耗和同一域名下瀏覽器的并發數限制。 對于小文件會降低帶寬。雖然編碼后數據量會增加,但是卻減少了http頭,當http頭的數據量大于文件編碼的增量,那么就會降低帶寬。 對于HTTPS站點,HTTPS和HTTP混用會有安全提示,而HTTPS相對于HTTP來講開銷要大更多,所以Data URI在這方面的優勢更明顯。 可以把整個多媒體頁面保存為一個文件。 缺點: 無法被重復利用,同一個文檔應用多次同一個內容,則需要重復多次,數據量大量增加,增加了下載時間。 無法被獨自緩存,所以其包含文檔重新加載時,它也要重新加載。 客戶端需要重新解碼和顯示,增加了點消耗。 不支持數據壓縮,base64編碼會增加1/3大小,而urlencode后數據量會增加更多。 不利于安全軟件的過濾,同時也存在一定的安全隱患。 MHTMLMHTML是MIME HTML (Multipurpose Internet Mail Extension HTML)的縮寫,是由RFC 2557定義的把一個多媒體的頁面所有內容都保存到同一個文檔解決方案。這個方案是由微軟提出從IE5.0開始支持,另外Opera9.0也開始支持,Safari可以把文件保存為.mht(MHTML文件的后綴)格式,但不支持顯示它。MHTML和Data URI還比較類似,有更強大的功能和更復雜的語法,并且沒有Data URI中 無法被重復利用 的缺點,但MHTML使用起來不夠靈活方便,比如對資源引用的URL在mht文件中可以是相對地址,否則必須是絕對地址。hedger在《Cross Browser Base64 Encoded Images Embedded in HTML》針對IE的解決方案使用的是相對路徑就是因為聲明了Content-type:message/rfc822使IE按照MHTML來解析,如果不修改Content-type則需要使用MHTML協議,這個時候必須使用絕對路徑,如《MHTML when you need data: URIs in IE7 and under》。應用Data URI和MHTML兩者的配合可以完整的解決所有的主流瀏覽器,它們由于無法被緩存和重復利用的缺陷,所以并不適合直接在頁面中使用,但在CSS和JavaScript文件中對圖片適當地使用有非常大的優越性: 大大減少請求數,現在大型網站的CSS引用了大量的圖片資源。 CSS和JavaScript都可以被緩存,間接的實現了數據的緩存。 利用CSS可以解決Data URI的重復利用問題 告別CSS Sprites,CSS Sprites的出現是為了減少請求數,但它除了帶來在不確定情況下的異常外,CSS Sprites還需要人為的圖片合并,即使有合并工具也依舊必須人為地在如何有效的拼圖上耗費大量的時間,并帶來維護的困難。當你遵循一定的設計原則后,你就可以完全拋棄CSS Sprites來編寫CSS,最后使用工具在上傳到服務器環節把圖片轉換成Data URI和MHTML,如《利用data-uri合并樣式表和圖片》中用python實現的工具,這可以節約大量的時間。 base64編碼把圖片文件增加了1/3,Data URI和MHTML同時使用相當于增加了2/3,但CSS和JavaScript可以使用gzip壓縮,其可以節省2/3的數據量,所以使用gzip壓縮后的最終數據量是(1 + 1/3) * 2 * (1/3) = 8/9,所以最終流量是減少的。 為了方便在CSS中實現Data URI和MHTML,我寫了一個Data URI MHTML 生成器,你可以看利用其生成Data URI MHTML應用實例。在CSS文件中使用應用MHTML時URL必須使用絕對路徑,導致非常不靈活,所以可以考慮使用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));html教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 磐安县| 达拉特旗| 东方市| 华阴市| 巨野县| 阜城县| 潞西市| 休宁县| 闽清县| 宁乡县| 大兴区| 长武县| 澎湖县| 鲜城| 定襄县| 封丘县| 星座| 阿克苏市| 清水县| 东海县| 阿克苏市| 禄劝| 辽宁省| 进贤县| 泰宁县| 江口县| 来凤县| 崇阳县| 祁阳县| 四川省| 东台市| 襄樊市| 陈巴尔虎旗| 中阳县| 密山市| 新兴县| 东乡族自治县| 平武县| 洛南县| 剑川县| 临澧县|