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

探究網頁資源究竟是如何阻塞瀏覽器加載的

系統 瀏覽器
一個頁面允許加載的外部資源有很多,常見的有腳本、樣式、字體、圖片和視頻等,對于這些外部資源究竟是如何影響整個頁面的加載和渲染的呢?今天我們來一探究竟。

[[374280]]

一個頁面允許加載的外部資源有很多,常見的有腳本、樣式、字體、圖片和視頻等,對于這些外部資源究竟是如何影響整個頁面的加載和渲染的呢?今天我們來一探究竟。

閱讀完這篇文章你將解開如下謎團:

  • 如何用 Chrome 定制網絡加載速度?
  • 圖片/視頻/字體會阻塞頁面加載嘛?
  • CSS 是如何阻塞頁面加載的?
  • JS 又是如何阻塞頁面加載的?
  • JS 一定會阻塞 DOM 加載嘛?
  • defer 和 async 是什么?又有何特點?
  • 動態腳本會造成阻塞嘛?
  • 阻塞是怎么和 DOMContentLoaded 與 onload 扯上關系的?

測試前環境準備

測試之前我們需要對瀏覽器下載資源的速度進行控制,將它重新設置為 50kb/s,操作方式:

  1. 打開 Chrome 開發者工具;
  2. 在 Network 面板下找到 Disable cache 右側的下拉列表,然后選擇 Add 添加自定義節流配置;
  3. 添加一個下載速度為 50kb/s 的配置;
  4. 最后在第二步驟中的下拉列表選擇剛剛配置的選項即可;
  5. 注意:如果當前選擇的自定義選項被修改了,則需要切換到別的選項再切回來才可生效。

為什么是這個速度?因為如下的一些資源,比如圖片、樣式或者腳本體積都是 50kb 的好幾倍,方便測試。

圖片會造成阻塞嘛

直接寫個示例來看下結果:

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"/> 
  5.     <script> 
  6.         document.addEventListener('DOMContentLoaded', () => { 
  7.             console.log('DOMContentLoaded'
  8.         }) 
  9.         window.onload = function() { 
  10.             console.log('onload'
  11.         } 
  12.     </script> 
  13. </head> 
  14. <body> 
  15.     <h1>我是 h1 標簽</h1> 
  16.     <img src="https://xxx.oss-cn-shenzhen.aliyuncs.com/images/flow.png" /> 
  17.     <h2>我是 h2 標簽</h2> 
  18. </body> 
  19. </html> 

上面這張圖片的大小大概是 200kb,當把網絡下載速度限制成 50kb/s,打開該頁面,可以看到如下結果:當 h1 和 h2 標簽渲染出來且打印了 DOMContentLoaded 的時候,此時圖片還在加載中,這就說明了圖片并不會阻塞 DOM 的加載,更加不會阻塞頁面渲染;當圖片加載完成的時候,會打印 onload,說明圖片延遲了 onload 事件的觸發。

視頻、字體和圖片其實是一樣的,也不會阻塞 DOM 的加載和渲染。

CSS 加載阻塞

同樣的,我們還是直接用代碼來測試 CSS 加載對頁面阻塞的情況,因為下面代碼加載的 bootstrap.css 是 192kb 的,所以理論上下載它應該需要花費 3 到 4 秒左右。

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"/> 
  5.     <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet" /> 
  6. </head> 
  7. <body> 
  8.     <h1>我是 h1 標簽</h1> 
  9. </body> 
  10. </html> 

測試過程如下:

  1. 在 Elements 面板下,選中 h1 這個標簽,然后按 delete 鍵將它從 DOM 中刪掉,從而模擬首次加載;
  2. 刷新瀏覽器,馬上 Elements 面板下就加載出 h1 標簽,繼續加載 3 到 4 秒后(此時正在加載 bootstrap.css),頁面出現 我是 h1 標簽 字樣,此時頁面已經渲染完成。

從而得出結論:

  • bootstrap.css 還沒加載完成,而 DOM 中就已經出現 h1 標簽,說明 CSS 不會阻塞 DOM 的解析;
  • 頁面直到 bootstrap.css 加載完成才出現 h1 里的文案,說明 CSS 會阻塞 DOM 的渲染。

為什么是這個結論呢?試想一下頁面渲染的流程就知道了。瀏覽器首先解析 HTML 生成 DOM樹,解析 CSS 生成 CSSOM 樹,然后 DOM 樹和 CSSOM 樹進行合成生成渲染樹,通過渲染樹進行布局并且計算每個節點信息,繪制頁面。


可以說解析 DOM 和 解析 CSS 其實是并列進行的,既然是并列進行的,那 CSS 和 DOM 就不會互相影響了,這和結論一相符;另外渲染頁面一定是在得到 CSSOM 樹之后進行的,這和結論二相符。

CSS 一定會阻塞 DOM 的渲染嘛?答案是否定的,當把外鏈樣式放到 最尾部去加載:

  1. <body> 
  2.     <h1>我是 h1 標簽</h1> 
  3.     <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet" /> 
  4. </body> 

此時刷新瀏覽器,頁面上會馬上顯示出 我是 h1 標簽 字樣,當 3 到 4 秒過后樣式加載完成的時會造成二次渲染,頁面重新渲染出該字樣,這就說明 CSS 阻塞 DOM 的渲染只阻塞定義在 CSS 后面的 DOM。二次渲染會對用戶造成不好的體驗且加重了瀏覽器的負擔,所以這也就是為什么需要把外鏈樣式提前到 里加載的原因。

CSS 會阻塞后面 JS 的執行嘛

CSS 阻塞了后面 DOM 的渲染,那它會阻塞 JS 的執行嘛?

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"/> 
  5.     <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet" /> 
  6. </head> 
  7. <body> 
  8.     <h1>我是 h1 標簽</h1> 
  9.     <script> 
  10.         console.log('888'
  11.     </script> 
  12. </body> 
  13. </html> 

刷新瀏覽器的時候可以看到,瀏覽器 Console 面板下沒有打印內容,而當樣式加載完成的時候打印了 888,這就說明 CSS 會阻塞定義在其之后 JS 的執行。

為什么會這樣呢?試想一下,如果 JS 里執行的操作需要獲取當前 h1 標簽的樣式,而由于樣式沒加載完成,所以就無法得到想要的結果,從而證明了 CSS 需要阻塞定義在其之后 JS的執行。

JS 加載阻塞

CSS 會阻塞 DOM 的渲染和阻塞定義在其之后的 JS 的執行,那 JS 加載會對渲染過程造成什么影響呢?

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"/> 
  5.     <script src="https://cdn.bootcss.com/jquery/2.1.4/jquery.min.js"></script> 
  6. </head> 
  7. <body> 
  8.     <h1>我是 h1 標簽</h1> 
  9. </body> 
  10. </html> 

首先刪除頁面中已經存在的 h1 標簽(如果存在的話),仔細觀察 Elements 面板,當刷新瀏覽器的時候,一直未加載出 h1 標簽(期間頁面一直白屏),直到 JS 加載完成后,DOM中才出現,這足以說明了 JS 會阻塞定義在其之后的 DOM 的加載,所以應該將外部 JS 放到 的最尾部去加載,減少頁面加載白屏時間。

defer 和 async

JS 一定會阻塞定義在其之后的 DOM 的加載嘛?來測試一下:

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"/> 
  5.     <script async src="https://cdn.bootcss.com/jquery/2.1.4/jquery.min.js"></script> 
  6. </head> 
  7. <body> 
  8.     <h1>我是 h1 標簽</h1> 
  9. </body> 
  10. </html> 

上面這段代碼的測試結果是當頁面中顯示出 h1 標簽的時候,腳本還沒有加載完成,這就說明了 async 腳本不會阻塞 DOM 的加載;同理我們可以用同樣的方式測試 defer,也會得到這個結論。

現在我們知道了通過 defer 或者 async 方式加載 JS 的時候,它是不會阻塞 DOM 加載的。那么你知道 defer 和 async 是什么嘛?它們兩者有什么區別呢?

回答這些疑問之前,我們先來看下當瀏覽器解析 HTML 遇到 script 標簽的時候會發生什么?

  • 暫停解析 DOM;
  • 執行 script 里的腳本,如果該 script 是外鏈,則會先下載它,下載完成后立刻執行;
  • 執行完成后繼續解析剩余 DOM。

上面這是解析時遇到一個正常的外鏈的情況,正常外鏈的下載和執行都會阻塞頁面解析;而如果外鏈是通過 defer 或者 async 加載的時候又會是如何呢?


defer 特點

  • 對于 defer 的 script,瀏覽器會繼續解析 html,且同時并行下載腳本,等 DOM 構建完成后,才會開始執行腳本,所以它不會造成阻塞;
  • defer 腳本下載完成后,執行時間一定是 DOMContentLoaded 事件觸發之前執行;
  • 多個 defer 的腳本執行順序嚴格按照定義順序進行,而不是先下載好的先執行;

asyn 特點

  • 對于 async 的 script,瀏覽器會繼續解析 html,且同時并行下載腳本,一旦腳本下載完成會立刻執行;和 defer 一樣,它在下載的時候也不會造成阻塞,但是如果它下載完成后 DOM 還沒解析完成,則執行腳本的時候是會阻塞解析的;
  • async 腳本的執行 和 DOMContentLoaded 的觸發順序無法明確誰先誰后,因為腳本可能在 DOM 構建完成時還沒下載完,也可能早就下載好了;
  • 多個 async,按照誰先下載完成誰先執行的原則進行,所以當它們之間有順序依賴的時候特別容易出錯。

defer 和 async 都只能用于外部腳本,如果 script 沒有 src 屬性,則會忽略它們。

動態腳本會造成阻塞嘛

對于如下這段代碼,當刷新瀏覽器的時候會發現頁面上馬上顯示出 我是 h1 標簽,而過幾秒后才加載完動態插入的腳本,所以可以得出結論:動態插入的腳本不會阻塞頁面解析。

  1. <!-- 省略了部分內容 --> 
  2. <script> 
  3.     function loadScript(src) { 
  4.         let script = document.createElement('script'
  5.         script.src = src 
  6.         document.body.append(script) 
  7.     } 
  8.     loadScript('https://cdn.bootcss.com/jquery/2.1.4/jquery.min.js'
  9. </script> 
  10. <h1>我是 h1 標簽</h1> 

動態插入的腳本在加載完成后會立即執行,這和 async 一致,所以如果需要保證多個插入的動態腳本的執行順序,則可以設置 script.async = false,此時動態腳本的執行順序將按照插入順序執行和 defer 一樣。

DOMContentLoaded 和 onload

在瀏覽器中加載資源涉及到 2 個事件,分別是 DOMContentLoaded 和 onload,那么它們之間有什么區別呢?

  • onload:當頁面所有資源(包括 CSS、JS、圖片、字體、視頻等)都加載完成才觸發,而且它是綁定到 window 對象上;
  • DOMContentLoaded:當 HTML 已經完成解析,并且構建出了 DOM,但此時外部資源比如樣式和腳本可能還沒加載完成,并且該事件需要綁定到 document 對象上;

細心的你一定看到了上面的可能二字,為什么當 DOMContentLoaded 觸發的時候樣式和腳本是可能還沒加載完成呢?

DOMContentLoaded 遇到腳本

當瀏覽器處理一個 HTML 文檔,并在文檔中遇到

  1. <script> 
  2.     document.addEventListener('DOMContentLoaded', () => { 
  3.         console.log('DOMContentLoaded'
  4.     }) 
  5. </script> 
  6. <h1>我是 h1 標簽</h1> 
  7. <script src="https://cdn.bootcss.com/jquery/2.1.4/jquery.min.js"></script> 

那么一定是腳本執行完成后才會觸發 DOMContentLoaded 嘛?答案也是否定的,有兩個例外,對于 async 腳本和動態腳本是不會阻塞 DOMContentLoaded 觸發的。

DOMContentLoaded 遇到樣式

前面我們已經介紹到 CSS 是不會阻塞 DOM 的解析的,所以理論上 DOMContentLoaded 應該不會等到外部樣式的加載完成后才觸發,這么分析是對的,讓我們用下面代碼進行測試一翻就知道了:

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"/> 
  5.     <script> 
  6.         document.addEventListener('DOMContentLoaded', () => { 
  7.         console.log('DOMContentLoaded'
  8.     }) 
  9.     </script> 
  10.     <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet"/> 
  11. </head> 
  12. <body> 
  13.     <h1>我是 h1 標簽</h1> 
  14. </body> 
  15. </html> 

測試結果:當樣式還沒加載完成的時候,就已經打印出 DOMContentLoaded,這和我們分析的結果是一致的。但是一定是這樣嘛?顯然不一定,這里有個小坑,(基于上面代碼)在樣式后面再加上 <script> 標簽的時候,會發現只有等樣式加載完成了才會打印出 DOMContentLoaded,為什么會這樣呢?正是因為 <script> 會阻塞 DOMContentLoaded 的觸發,所以當外部樣式后面有腳本(async 腳本和動態腳本除外)的時候,外部樣式就會阻塞 DOMContentLoaded 的觸發。

  1. <!-- 只顯示了部分內容 --> 
  2. <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet"/> 
  3. <script></script> 
  4. </head> 

參考文章:

DOMContentLoaded

https://html.spec.whatwg.org/multipage/scripting.html

 

責任編輯:姜華 來源: 大海我來了
相關推薦

2019-06-04 14:15:08

JavaScript V8前端

2019-07-22 15:29:53

JavaScriptGitHub語言

2019-04-26 13:55:02

Istio微服務架構

2021-01-05 09:23:49

網頁端消息

2011-02-28 09:51:43

內省

2011-02-16 16:13:40

Debian

2020-06-11 09:18:34

動靜分離架構架構設計開發

2018-07-05 16:15:26

緩存數據cache miss

2010-08-24 09:19:59

2011-11-19 15:55:41

虛擬化存儲虛擬化日立數據

2017-11-21 14:56:59

2011-05-30 20:51:49

2015-08-26 09:54:19

物聯網

2022-06-13 09:51:35

UWB超寬帶無線載波通信技術

2021-02-19 20:38:01

互聯網衛星系統

2011-08-04 13:24:28

IT運維

2012-05-28 22:49:50

PureView

2015-12-14 15:34:35

開源投資創業

2018-09-10 13:47:21

數據科學統計學決策

2019-05-27 15:30:44

Node.jsJavaScript前端
點贊
收藏

51CTO技術棧公眾號

欧美久久久久久久久久久久久久| 国产精品三级久久久久久电影| 中国老熟女重囗味hdxx| 草草视频在线观看| 国产午夜精品美女毛片视频| 国产精品露脸av在线| 亚洲av鲁丝一区二区三区 | 国产精品一区二区久久| 美女的奶胸大爽爽大片| 要久久电视剧全集免费| 91精品午夜视频| www黄色日本| 成人在线网址| 中文字幕欧美国产| 国产精品久久亚洲7777| 夜夜嗨aⅴ一区二区三区| 亚洲午夜黄色| 最近中文字幕日韩精品| 精品国产一区在线| 日韩精品视频中文字幕| 色成人在线视频| 成人免费在线视频播放| 永久免费av片在线观看全网站| 国产风韵犹存在线视精品| 国产精品大片wwwwww| 黄色小说在线观看视频| 国产精品久久久久无码av| 亚洲精选在线观看| 色哟哟网站在线观看| 国产精品第一| 色狠狠av一区二区三区| www.av中文字幕| 尤物yw193can在线观看| 国产精品久久久久婷婷二区次| 蜜桃av噜噜一区二区三| 亚洲欧美激情在线观看| 韩国一区二区在线观看| 国产精品视频网| 99re热视频| 三级欧美韩日大片在线看| 欧美大尺度在线观看| 日本成人免费在线观看| 精品国产乱码久久久| 国产网站欧美日韩免费精品在线观看 | 91麻豆精品国产91久久久使用方法| 国产精品50p| 成av人片在线观看www| 亚洲午夜久久久久久久久久久| 欧美少妇一级片| 欧美jizzhd69巨大| 中文字幕在线视频一区| 在线不卡日本| 国产在线高清理伦片a| 国产精品久久久久aaaa| 亚洲日本一区二区三区在线不卡| av中文资源在线| 欧美国产精品一区| 一本一本久久a久久精品综合妖精| 国产免费a∨片在线观看不卡| 久久夜色精品国产噜噜av| 久久久影院一区二区三区| 五月婷婷丁香花| 久久久亚洲精品一区二区三区 | 国产精品高清免费在线观看| 日韩精品在线一区二区三区| av大片在线免费观看| 欧美成人xxxx| 欧美美女视频在线观看| 免费av不卡在线| 欧美影院精品| 精品国产区一区| 免费黄色三级网站| 国内成人自拍| 久久综合色88| 日韩 欧美 精品| 免费永久网站黄欧美| 国产成人鲁鲁免费视频a| 特级西西444www大胆免费看| 美国一区二区三区在线播放| 亚洲自拍偷拍网址| 人妻中文字幕一区| 久久精品欧美一区二区三区不卡 | 91亚洲一线产区二线产区| 免费欧美网站| 日韩精品免费综合视频在线播放| www.色天使| 欧美国产美女| 97国产在线观看| 最新在线中文字幕| 国产精品小仙女| 免费在线成人av电影| 欧美边添边摸边做边爱免费| 亚洲第一av色| 天天操天天爽天天射| 日韩中文在线| 亚洲午夜精品久久久久久性色| 肉色超薄丝袜脚交69xx图片| 在线欧美三区| 国产裸体写真av一区二区| 亚洲精品喷潮一区二区三区| 久久精品视频在线免费观看| 91精品国产吴梦梦| 成人视屏在线观看| 精品国产欧美一区二区| 亚洲色图第四色| 亚洲黄色大片| 国产在线观看不卡| 欧美偷拍视频| 亚洲激情网站免费观看| 精品视频无码一区二区三区| 深夜福利一区| 中文字幕欧美国内| 国产成人精品网| 国产高清在线精品| 亚洲国产精品综合| 涩涩网在线视频| 日韩一区二区在线观看| 91在线无精精品白丝| 亚洲美女黄色| 亚洲一区二区三区在线免费观看| 黄色av网址在线免费观看| 亚洲午夜精品久久久久久久久| 2025韩国理伦片在线观看| 国产劲爆久久| 精品中文字幕在线2019| 中文字幕第31页| 久久日一线二线三线suv| a天堂资源在线观看| 涩涩涩久久久成人精品| 国产亚洲精品久久| 7799精品视频天天看| 成av人片一区二区| 青青在线视频免费观看| 美女精品久久| 久久色在线播放| 在线播放国产一区| 中文字幕欧美国产| 国产三级三级三级看三级| 奇米影视777在线欧美电影观看| 欧美日韩国产成人高清视频| 国产影视一区二区| 国产精品久久久久久久裸模| 黄色片在线免费| 国产日产一区| 日韩免费不卡av| 男人天堂综合| 日本久久电影网| b站大片免费直播| 美女精品网站| 欧美一区国产一区| 欧美free嫩15| 一本一本久久a久久精品牛牛影视| 激情视频网站在线观看| 国产欧美日韩三级| 狠狠躁狠狠躁视频专区| 欧美xxxxx视频| 91精品免费视频| 黄视频网站在线| 日韩欧美一区二区免费| 欧美极品视频在线观看| 不卡的看片网站| 国产成人a亚洲精v品无码| 精品一区三区| 国产日产欧美a一级在线| 久久77777| 日韩精品中文字幕在线不卡尤物| 不卡的免费av| 久久久久久久久久美女| 高清av免费看| 夜间精品视频| 国严精品久久久久久亚洲影视| 男人av在线播放| 在线日韩日本国产亚洲| 国产日韩欧美一区二区东京热 | 久久艹免费视频| 国产亚洲欧美在线| 亚洲激情在线看| 狠狠爱综合网| 欧洲精品国产| 成人动漫视频在线观看| 久久久久久久久久久久av| 欧美另类自拍| 91精品久久久久久久99蜜桃 | 久热国产在线| 日韩av综合网| 国产又粗又大又爽| 午夜精品久久久| 国产一二三四区在线| 国产一二精品视频| 欧美黄网站在线观看| 99国产精品免费视频观看| 国产精品v欧美精品v日韩| 欧美日韩视频网站| 久久99热精品这里久久精品| 欧美挠脚心网站| 日韩亚洲欧美一区| 波多野结衣大片| 亚洲制服丝袜av| 色噜噜噜噜噜噜| www.亚洲国产| 奇米视频7777| 男人的天堂亚洲在线| 2022中文字幕| 欧美天天综合| 韩国成人av| www.成人| 国产精品视频久久| 美女网站在线看| 色综合91久久精品中文字幕| 国产69精品久久app免费版| 精品日韩成人av| 一起草av在线| 色婷婷综合在线| 国产精品第九页| 亚洲少妇最新在线视频| 欧美大波大乳巨大乳| 成人av免费在线观看| www.桃色.com| 免费高清视频精品| 久章草在线视频| 亚洲激情精品| 国产在线无码精品| 欧美国产美女| 亚洲亚洲精品三区日韩精品在线视频| 欧美成人午夜77777| 成人影片在线播放| 视频一区视频二区欧美| 91精品在线国产| 岛国精品在线| 国产精品aaaa| **在线精品| 热99在线视频| 自拍网站在线观看| 97香蕉久久夜色精品国产| 欧美24videosex性欧美| 美日韩精品免费视频| 免费av在线网址| 精品国产一区二区三区久久久| 国产一级免费在线观看| 亚洲欧洲一区二区三区在线观看| 天天操天天操天天| 精品国产a毛片| 免费看黄色一级视频| 精品女同一区二区| 日本免费网站在线观看| 精品日韩99亚洲| 日韩一级在线播放| 亚洲电影在线看| 免费国产精品视频| 日韩精品免费综合视频在线播放| 亚洲 美腿 欧美 偷拍| 日韩精品免费在线视频| 男女网站在线观看| 亚洲天堂2020| chinese偷拍一区二区三区| 伊人久久精品视频| 三区四区在线视频| 久久中文字幕一区| 青青青国内视频在线观看软件| 欧美大片在线免费观看| av小说在线播放| 68精品久久久久久欧美| 电影一区二区三| 国产一区玩具在线观看| 国产一区二区三区黄网站| 99精彩视频| 亚洲动漫在线观看| 视频一区不卡| 亚洲高清影视| xxxx18hd亚洲hd捆绑| 每日更新成人在线视频| 五月天中文字幕在线| 成人在线综合网| 丰满少妇一区二区| 一区在线播放视频| 精品一级少妇久久久久久久| 欧美性少妇18aaaa视频| 91精品国产乱码久久久| 精品乱人伦一区二区三区| 亚洲色图另类小说| 最新91在线视频| 国产福利在线免费观看| 国产91色在线播放| 亚洲一二av| 欧美日韩三区四区| 亚洲二区三区不卡| 成人在线免费观看av| 蜜桃久久av一区| 一边摸一边做爽的视频17国产| 久久蜜桃一区二区| 精品人妻伦九区久久aaa片| 精品久久香蕉国产线看观看亚洲 | 日韩精品1区2区3区| 天天久久综合网| 久久色.com| 久久中文字幕无码| 欧美色中文字幕| 欧美 日韩 国产 成人 在线| 在线免费观看羞羞视频一区二区| 成年网站在线视频网站| 国产精品免费网站| 里番精品3d一二三区| 青青草影院在线观看| 久久伊人亚洲| 第一页在线视频| 国产精品日日摸夜夜摸av| 成人毛片18女人毛片| 日韩欧美亚洲国产另类 | 欧美大肥婆大肥bbbbb| 午夜欧美巨大性欧美巨大 | 精品视频久久| 岛国大片在线播放| 国产一区二区三区免费播放| a天堂中文字幕| 疯狂蹂躏欧美一区二区精品| 国产成人精品a视频| 色av中文字幕一区| 中文字幕这里只有精品| 国产精品日韩二区| 欧美一区二区三区久久精品茉莉花 | 黄色成人在线| 国产精品视频久久久| 国产毛片一区二区三区| 你懂的av在线| 国产成人精品1024| 欧美亚洲日本在线| 欧美男人的天堂一二区| 二区三区在线| 国产精品白嫩初高中害羞小美女| 美国一区二区| 僵尸世界大战2 在线播放| 丰满白嫩尤物一区二区| 麻豆视频在线免费看| 制服丝袜成人动漫| 欧美日本高清| 91精品久久久久久久久中文字幕 | 少妇av一区二区三区| 日韩av大片站长工具| 久久久久久久久久码影片| 亚洲青涩在线| 国产精品无码一区二区三| 亚洲自拍偷拍图区| 狠狠综合久久av一区二区| 欧美另类交人妖| 亚洲国产视频二区| 成人免费a级片| 丁香婷婷综合网| 日本少妇做爰全过程毛片| 亚洲经典中文字幕| 中文字幕资源网在线观看免费| 欧美二区在线看| 狂野欧美性猛交xxxx巴西| 尤物视频最新网址| 欧美亚洲一区二区三区四区| eeuss影院www在线播放| 成人福利视频在线观看| 久久久久亚洲| 欧美久久久久久久久久久| 午夜一区二区三区视频| 日本在线视频1区| 国产精品黄色av| 97精品中文字幕| 极品人妻一区二区| 午夜欧美大尺度福利影院在线看| 三区在线视频| 国产精品香蕉在线观看| 亚洲最新色图| 五十路六十路七十路熟婆 | 性色av一区二区三区| 亚洲国产最新| www.99r| 亚洲在线成人精品| 亚洲色图欧美视频| 国产精品永久免费视频| 欧美在线网站| 制服丝袜第二页| 欧美日韩亚州综合| 欧美大片黄色| 青青草久久网络| 国产在线精品免费| 波多野结衣国产| 精品国产一区二区三区久久| 女仆av观看一区| 91 在线视频观看| 亚洲二区视频在线| 国产高清美女一级毛片久久| 亚洲伊人久久综合| 国产亚洲精品久久久久婷婷瑜伽| 污污视频网站在线免费观看| 精品国产一区二区三区久久久蜜月 | 激情小说欧美色图| 色综合天天综合狠狠| 久草免费在线观看| 久久精品ww人人做人人爽| 久久99精品久久久久久国产越南| 国产精品suv一区二区69| 在线观看91久久久久久| 粉嫩av一区二区| 中文字幕久久av| 色综合一个色综合亚洲|