精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

HTTP網絡協議中的HTTP Client Hints 技術

網絡 網絡管理
最近幾年各種 Web 技術一直在爆炸式發展,每天都有大量新東西涌現出來。今天我要向大家介紹的技術是:HTTP Client Hints,也與性能優化有關。

最近幾年各種 Web 技術一直在爆炸式發展,每天都有大量新東西涌現出來。針對這個現象,業內兩位大佬最近先后發文表達了自己的觀點:Stop pushing the web forward、Is the web platform getting too big?。其實很早之前我就意識到以我目前的精力,吃透所有 Web 新技術幾乎是不可能完成的任務,我關注新技術的側重點放在了性能優化上。

今天我要向大家介紹的技術是:HTTP Client Hints,也與性能優化有關。利用這項技術,HTTP 客戶端(通常可以認為是瀏覽器)能夠主動將一些特性告訴服務端,以便服務端更有針對性地輸出內容。這項技術由我們熟知的 Ilya Grigorik 提出,目前還處在較為早期的階段,較為正式的描述文檔可以在這里找到。目前 Chrome 46 (beta) 已支持它,IE 和 Firefox 則還在考慮中。

其實之前瀏覽器已經將很多自身特性放在 HTTP 請求中,例如下面這些頭部字段:

User-Agent:提供瀏覽器類型及版本、操作系統及版本、瀏覽器內核等信息;

Accept:表明瀏覽器支持哪些 MIME type(例如 Chrome 通過 Accept 表明自己支持 image/webp 圖片格式);

Accept-Encoding:表明本瀏覽器支持哪些內容編碼方式(例如:gzip、deflate、sdch);

Accept-Language:表明本瀏覽器支持那些語言;

通過以上這些頭部字段,我們已經可以針對不同客戶端輸出不同內容。例如本博客對支持 Webp 格式的瀏覽器會使用 Webp 來減少圖片大小;本博客還會通過 User-Agent 針對 IE 老版本禁用 localStorage 緩存策略。

但是有一些瀏覽器特性,我們無法直接獲取,如屏幕分辨率、設備像素比(devicePixelRatio)、用戶帶寬等。而在移動 Web 中,為了盡可能節省用戶流量,需要輸出尺寸最合適的圖片資源。為了解決這個問題,常見的方案有:1)使用 JS 獲取這些特性,動態拼接圖片 URL;2)使用 HTML 中的 sizes 和 srcset 屬性、picture 標簽或 CSS 中的 image-set 屬性來實現響應式圖片。方案 1 很簡單,這里略過;方案 2 網上有很多相關文章,不熟悉的同學可以自行搜索「響應式圖片」了解下。

這里看一個使用方案 2 中提到的 picture、sizes 和 srcset 實現的響應式圖片代碼(via):

HTML
media="(min-width: 50em)"
sizes="50vw"
srcset="/image/thing-200.webp 200w, /image/thing-400.webp 400w,
/image/thing-800.webp 800w, /image/thing-1200.webp 1200w,
/image/thing-1600.webp 1600w, /image/thing-2000.webp 2000w"
type="image/webp">
sizes="(min-width: 30em) 100vw"
srcset="/image/thing-crop-200.webp 200w, /image/thing-crop-400.webp 400w,
/image/thing-crop-800.webp 800w, /image/thing-crop-1200.webp 1200w,
/image/thing-crop-1600.webp 1600w, /image/thing-crop-2000.webp 2000w"
type="image/webp">
media="(min-width: 50em)"
sizes="50vw"
srcset="/image/thing-200.jpgxr 200w, /image/thing-400.jpgxr 400w,
/image/thing-800.jpgxr 800w, /image/thing-1200.jpgxr 1200w,
/image/thing-1600.jpgxr 1600w, /image/thing-2000.jpgxr 2000w"
type="image/vnd.ms-photo">
sizes="(min-width: 30em) 100vw"
srcset="/image/thing-crop-200.jpgxr 200w, /image/thing-crop-400.jpgxr 400w,
/image/thing-crop-800.jpgxr 800w, /image/thing-crop-1200.jpgxr 1200w,
/image/thing-crop-1600.jpgxr 1600w, /image/thing-crop-2000.jpgxr 2000w"
type="image/vnd.ms-photo">
media="(min-width: 50em)"
sizes="50vw"
srcset="/image/thing-200.jpg 200w, /image/thing-400.jpg 400w,
/image/thing-800.jpg 800w, /image/thing-1200.jpg 1200w,
/image/thing-1600.jpg 1600w, /image/thing-2000.jpg 2000w">
sizes="(min-width: 30em) 100vw"
srcset="/image/thing-crop-200.jpg 200w, /image/thing-crop-400.jpg 400w,
/image/thing-crop-800.jpg 800w, /image/thing-crop-1200.jpg 1200w,
/image/thing-crop-1600.jpg 1600w, /image/thing-crop-2000.jpg 2000w">

這段冗長的代碼只是為了實現一張響應式圖片,盡管有一些夸張,實際使用時一般不會寫這么全,但從中可以得到一個結論:在客戶端實現的策略越多,HTML 體積就越大越冗余,可維護性和可讀性就越差。

而使用了 HTTP Client Hints 之后,瀏覽器在頁面發起子資源請求時,會通過新增的一系列頭部字段帶上分辨率、設備像素比、圖片寬度等信息,使得各種復雜的策略可以挪到服務端去實現了。下面來看一看具體細節:

首先,有了支持 HTTP Client Hints 的瀏覽器之后,頁面上還需要顯式啟用它。這是因為不是所有服務端都實現了響應式輸出策略,每次都發送這些新增的頭部可能會造成浪費。

與往常一樣,這個功能也可以通過 HTTP 響應頭和 meta 標簽兩種方式開啟并配置:

Accept-CH: DPR, Width, Viewport-Width

或:

<meta http-equiv="Accept-CH" content="DPR, Width, Viewport-Width">

 

在啟用了 HTTP Client Hints 的頁面中,所有子資源請求(無論什么類型,無論什么方式創建),都會攜帶 Accept-CH 屬性中所指明的頭部,例如:

BASHAccept: image/webp,image/*,*/*;q=0.8
Accept-Encoding: gzip, deflate, sdch
Accept-Language: zh-CN,zh;q=0.8,en;q=0.6,en-US;q=0.4,ja;q=0.2,de;q=0.2,zh-TW;q=0.2,cs;q=0.2,pt;q=0.2,ko;q=0.2
Connection: keep-alive
DPR: 2
Host: qgy18.imququ.com
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2490.13 Safari/537.36
Viewport-Width: 1280
Width: 128

有了這些頭部,圖片服務器可以知道客戶端的 devicePixelRatio 是 2、圖片寬度是 128px、支持 Webp 格式,所以輸出 256px 的雙倍 Webp 圖最合適。但是瀏覽器怎么知道這個圖片需要作為雙倍圖來使用呢(也就是說還是顯示為 128px)?這就需要在響應頭中增加下面這個字段作為 DPR 的回應:

Content-DPR: 2

需要注意的是,請求頭中的 Width 字段,是根據 img 標簽上的 sizes 屬性算出來的。如果圖片沒有指定 sizes,或者圖片請求是通過 JS 創建的,瀏覽器無法得知 Width,也就不會攜帶這個頭部。

實際上,除了 DPR、Viewport-Width 和 Width 之外,文檔還規定了兩個字段,但是經過我的測試 Chrome 46 并沒有支持它們,這里簡單介紹下:

Downlink:用來指示當前網絡的下行鏈路帶寬,單位是 Mbps;

Save-Data:用來指示當前瀏覽器是否工作在省流模式之下,取值為 1 或 0;

可以看出這兩個屬性,也是為了盡可能給用戶節省帶寬而設計的。可以預見,后續還會有更多字段加到 HTTP Client Hints 協議中來。隨著 HTTP/2 的普及,頭部壓縮使得增加幾個頭部字段帶來的開銷變得很小了。

值得注意的是,使用了 HTTP Client Hints 之后,服務端針對同一個 URL 可能會輸出不同的內容,所以無論是中間節點,還是瀏覽器,在實現響應 Cache 時必須小心,需要針對不同的情況緩存多份內容。這需要用到 HTTP/1 中的 Vary 響應頭,例如:

Vary: DPR, Width, Downlink

表明如果需要緩存這個響應,在生成緩存 Key 的時候需要將請求頭中的 DPR、Width 和 Downlink 的值計算進去。

好了,HTTP Client Hints 技術就介紹到這里。很欣慰地看到,大部分 Web 新技術都是在給 HTML、CSS 和 JavaScript 增加功能和特性,而這項技術卻是把之前復雜的代碼和邏輯往后移,讓我們的 HTML 代碼能夠輕裝上陣。一些開源圖片處理系統已經開始支持這個新特性了,國外的一些 CDN 托管服務肯定也在蠢蠢欲動,我十分期待它的未來。

責任編輯:何妍 來源: Jerry Qu的小站
相關推薦

2015-09-16 13:11:52

Http網絡協議Proxy-Conne

2015-09-17 10:29:07

Http網絡協議X-Forwarded

2015-09-16 09:50:35

HTTP 網絡協議響應頭

2014-10-22 09:36:41

TCPIP

2015-10-09 15:07:02

HTTP網絡協議

2015-09-14 15:31:40

HTTP網絡協議

2009-07-23 16:20:48

HTTP協議ASP.NET

2017-05-26 10:35:13

前端HTTP

2015-10-19 09:52:11

2018-04-17 16:29:24

Java面試HTTP

2020-06-17 21:39:11

HTTP協議服務器

2022-03-09 18:54:30

HTTP緩存協議cache

2015-09-07 13:52:04

2015-09-06 13:40:02

HTTP網絡協議

2015-09-08 10:06:15

2015-10-20 09:46:33

HTTP網絡協議

2015-09-06 10:54:29

HTTP網絡協議

2010-06-08 12:31:15

HTTP協議實體

2010-07-01 16:01:05

HTTP協議

2011-08-09 14:08:51

iPhoneHTTP請求協議
點贊
收藏

51CTO技術棧公眾號

国产成人精品一区二| 欧美一区二区性| 欧美日韩另类视频| 欧美激情第六页| 一级片免费网站| 国产精品大片免费观看| 日韩精品极品视频| 五月婷婷六月丁香激情| 毛片大全在线观看| 国产视频一区二区三区在线观看| 91沈先生在线观看| 欧美亚韩一区二区三区| 四虎国产精品免费观看| 亚洲国产精品电影在线观看| 亚洲黄色av网址| www欧美xxxx| 国产精品免费丝袜| 狠狠色狠狠色综合人人| 国产精品九九九九| 久久综合狠狠| 国内久久久精品| 亚洲 欧美 变态 另类 综合| 国产精品999久久久| 91精品久久| 国产亚洲短视频| aa成人免费视频| 在线黄色av网站| 麻豆久久婷婷| 欧美富婆性猛交| 99久久久无码国产精品不卡| 亚洲成在人线免费观看| 欧美r级在线观看| 亚欧激情乱码久久久久久久久| 678在线观看视频| 自拍偷拍亚洲欧美日韩| 蜜桃欧美视频| 日韩在线视频第一页| 国内成人精品2018免费看| 欧洲亚洲免费视频| av大片免费在线观看| 在线国产一区| 久久精品一区中文字幕| 制服丨自拍丨欧美丨动漫丨| 国产日韩欧美一区二区三区| 日韩高清中文字幕| www.88av| 色88888久久久久久影院| 精品噜噜噜噜久久久久久久久试看| 午夜剧场高清版免费观看| 88xx成人网| 欧美一a一片一级一片| 国产日韩一区二区在线观看| 天堂网在线最新版www中文网| 亚洲国产欧美日韩另类综合| 蜜桃视频一区二区在线观看| 爆操欧美美女| 亚洲愉拍自拍另类高清精品| 国产在线视频在线| 牛牛电影国产一区二区| 亚洲国产精品久久不卡毛片| 久久久久久久香蕉| segui88久久综合| 午夜国产精品影院在线观看| 男人添女荫道口图片| av漫画网站在线观看| 午夜成人在线视频| 亚洲熟妇av一区二区三区漫画| 欧美另类老肥妇| 色综合久久88色综合天天6 | 空姐吹箫视频大全| 国产99久久久久| 国产在线视频欧美一区二区三区| 欧美 中文字幕| 91麻豆国产精品久久| 日本10禁啪啪无遮挡免费一区二区 | 日韩一区二区三区在线视频| 波多野结衣中文字幕在线播放| 日本精品国产| 亚洲精品狠狠操| 三上悠亚ssⅰn939无码播放 | 成人免费av在线| 精品国产免费一区二区三区 | 美女精品一区最新中文字幕一区二区三区| 精品偷拍一区二区三区在线看| mm131美女视频| 99久久99热这里只有精品| 欧美成人精品在线观看| 亚欧洲精品在线视频| 玖玖在线精品| 亚洲综合视频1区| 无码精品人妻一区二区| 国产校园另类小说区| 国产又大又长又粗又黄| 91福利区在线观看| 欧美亚洲日本国产| 香蕉久久久久久av成人| 欧美日韩性在线观看| 欧美精品午夜视频| 国产一级片免费在线观看| 国内精品伊人久久久久av影院| 国产日韩三区| 久草免费在线| 一本久久综合亚洲鲁鲁五月天| 日本在线播放一区二区| 美女呻吟一区| 色七七影院综合| www.国产高清| 国产精品伊人色| 国产在线欧美日韩| www久久日com| 色88888久久久久久影院按摩| 永久av免费在线观看| 一区二区美女| 久久久久久九九九| 亚洲视频一区在线播放| 99久久久久久| 欧美日韩激情四射| h1515四虎成人| 日韩精品在线播放| 免费网站看av| 极品少妇一区二区三区精品视频| 久久久久久久免费| 超碰97国产精品人人cao| 欧美精品自拍偷拍| 国产人妻大战黑人20p| 国产欧美一区二区三区国产幕精品| 国产日本欧美一区| 国产福利第一视频在线播放| 午夜日韩在线观看| 亚洲欧洲国产视频| 午夜电影亚洲| 91老司机精品视频| 日本中文字幕视频在线| 色激情天天射综合网| 精品人妻一区二区三区日产| 欧美 日韩 国产 一区| 国产日韩精品入口| 大胆av不用播放器在线播放 | 国产精品无码白浆高潮| 亚洲国产精品激情在线观看| 国产又大又硬又粗| 思热99re视热频这里只精品| 2019中文字幕全在线观看| 成人黄色在线观看视频| 亚洲美女在线一区| 亚洲在线观看网站| 欧美三级小说| 超碰97国产在线| 国产区美女在线| 精品国产91洋老外米糕| 久草视频免费播放| 成人午夜大片免费观看| 日本福利视频一区| 久久成人福利| 欧美最顶级的aⅴ艳星| 天天影院图片亚洲| 色婷婷av久久久久久久| 欧美三级视频网站| 蜜桃精品视频在线| 大地资源第二页在线观看高清版| 99久久99九九99九九九| 久久亚洲私人国产精品va| 国产激情久久久久久熟女老人av| 亚洲精品网站在线观看| 国产a√精品区二区三区四区| 黄色在线一区| 国产在线精品一区二区三区| 国模冰冰炮一区二区| 亚洲性无码av在线| 国产一区二区视频免费观看| 亚洲精品一二三区| 永久免费未满蜜桃| 久久精品一区二区三区中文字幕 | zjzjzjzjzj亚洲女人| 亚洲毛片网站| 日韩国产高清一区| 2019中文亚洲字幕| 欧美黄色片视频| 免费在线一级视频| 欧美剧情片在线观看| 欧美日韩在线观看成人| av在线播放成人| 激情五月婷婷久久| 永久91嫩草亚洲精品人人| 国产在线一区二区三区欧美| 亚洲mmav| 欧美贵妇videos办公室| 欧美一区二区三区少妇| 欧美日本在线看| 懂色av.com| 中文字幕不卡在线| 色欲欲www成人网站| 美女精品在线| 国产精品视频一二三四区| 九九热线有精品视频99| 91日韩在线播放| 欧美成人性网| 久久91亚洲人成电影网站| 精品美女视频在线观看免费软件| 欧美精品乱码久久久久久| 色播视频在线播放| 国产色综合久久| 国产欧美视频一区| 免费观看日韩av| 黄色av网址在线播放| 91精品国产自产拍在线观看蜜| 久久99精品久久久久久青青日本 | 亚洲国产美女视频| 久久精品欧美一区二区三区不卡 | 欧美黑人性生活视频| 成人免费在线观看| 日韩国产一区三区| 亚洲毛片欧洲毛片国产一品色| 欧美日韩一区三区四区| aaa人片在线| 亚洲在线视频一区| 91高清免费看| 国产欧美一区二区精品忘忧草| 免费不卡的av| 国产传媒一区在线| www.com操| 视频一区中文字幕| 丰满爆乳一区二区三区| 欧美ab在线视频| 一区二区日本| 成人激情免费视频| 欧洲一区二区日韩在线视频观看免费 | 久久久久久久久艹| 国产精品福利av| 青娱乐国产视频| 久久久精品tv| 在线不卡av电影| 99久久99久久久精品齐齐| 国产成人精品一区二区三区在线观看| 久久精品国产77777蜜臀| 成人一区二区三| 丝袜美腿亚洲综合| 日韩一级在线免费观看| 欧美亚洲三级| 欧美三级午夜理伦三级| 美女91精品| 亚洲色精品三区二区一区| 久久国产精品毛片| 免费在线观看的av网站| 国产亚洲福利| 激情网站五月天| 肉色丝袜一区二区| 国产福利影院在线观看| 日本不卡视频一二三区| 亚洲一级免费观看| 蜜桃av一区二区在线观看 | 可以免费在线观看的av| 五月综合激情网| 亚洲精品男人天堂| 在线亚洲免费视频| 一区二区三区免费在线| 69堂成人精品免费视频| 99久久国产免费| 精品国产伦一区二区三区观看方式| www.黄色国产| 亚洲精品ady| 九一在线视频| www.日韩视频| 欧美人与牲禽动交com| 孩xxxx性bbbb欧美| av有码在线观看| 欧美在线亚洲在线| 国产亚洲精品精品国产亚洲综合| 成人黄色网免费| 91成人午夜| 欧美国产视频在线观看| 欧美日韩中文一区二区| 中文字幕中文字幕在线中心一区| 欧美激情综合色综合啪啪| 加勒比成人在线| 日韩中文字幕不卡| 久久久久久综合网| 99久久伊人精品| 国产午夜福利一区| 一区二区三区四区av| 九九热在线视频播放| 欧美日韩一级二级三级| 精品久久久无码中文字幕| 日韩电影中文字幕| 欧美天天影院| 亚洲 日韩 国产第一| 国产美女久久| 国产欧美日韩视频一区二区三区| 啪啪亚洲精品| 成人午夜视频免费观看| 三级不卡在线观看| 欧美激情一区二区三区p站| 久久精品一区二区三区不卡| caoporn91| 91久久人澡人人添人人爽欧美 | 国产大陆精品国产| 免费看的黄色网| 亚洲电影激情视频网站| 91成人国产综合久久精品| 亚洲精品国产福利| av毛片在线看| 国产精品久久久久久久久久免费 | 国产亚洲精彩久久| 国产主播一区二区三区四区| 久久精品亚洲人成影院 | 亚洲精品中文字幕在线| 亚洲黄色三级| 亚洲国产综合av| 欧美经典一区二区三区| 国产成人在线免费观看视频| 4438x亚洲最大成人网| 国产精品久久久久一区二区国产 | 久久综合九色九九| 久久久成人av毛片免费观看| 国产日产精品一区二区三区四区| 亚洲啊v在线观看| 浓精h攵女乱爱av| 久久久久国产精品麻豆ai换脸| 久久综合久久鬼| 欧美一级二级在线观看| 香蕉视频网站在线观看| 欧美在线免费视频| 精品嫩草影院| 久久成人福利视频| 国产精品888| 国产免费美女视频| 欧美色图在线观看| 国产一二三区在线| 日韩av电影在线网| 亚洲制服一区| 久草青青在线观看| 91免费国产在线| 日韩av男人天堂| 亚洲白虎美女被爆操| 影音先锋男人在线资源| 91传媒视频在线观看| 性xxxx欧美老肥妇牲乱| 一起操在线视频| 亚洲欧洲av在线| 91theporn国产在线观看| 中文字幕精品网| 日韩一区二区三区在线免费观看 | 欧美精品第1页| 色综合久久久久综合一本到桃花网| 国产精品精品国产| 不卡在线一区二区| 日韩av片专区| 亚洲视频资源在线| 亚洲av无码乱码国产精品久久| 精品中文字幕视频| 91综合精品国产丝袜长腿久久| h无码动漫在线观看| 大尺度一区二区| 国产成人在线免费观看视频| 日韩av在线最新| 午夜av成人| 美国av在线播放| 国产传媒欧美日韩成人| 日韩字幕在线观看| 亚洲精品视频免费在线观看| free欧美| 一区二区冒白浆视频| 国产高清不卡一区| 中文字幕亚洲精品在线| 亚洲欧洲成视频免费观看| 成人国产激情在线| 今天免费高清在线观看国语| 成人免费高清在线观看| 亚洲乱码国产乱码精品| 正在播放亚洲1区| 精品视频在线观看网站| 自拍日韩亚洲一区在线| 久久久国产午夜精品| 国产一区二区波多野结衣| 久久久久久国产| 成人同人动漫免费观看| 中文字幕无码毛片免费看| 偷窥少妇高潮呻吟av久久免费| 成人在线视频成人| 97视频资源在线观看| 久久不射网站| 久久国产美女视频| 精品亚洲永久免费精品| 欧美大片网站| 成人免费性视频| 国产情人综合久久777777| 国产高清视频免费观看| 日韩av理论片| 欧美在线资源| 免费在线观看a视频| 欧美tk—视频vk| 国产一区二区三区朝在线观看| 国风产精品一区二区| 国产视频在线观看一区二区三区| 国内老熟妇对白xxxxhd| 日本亚洲欧洲色α| 欧美精品aa| 欧美一区二区三区粗大| 亚洲国产高清自拍| 永久免费观看精品视频|