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

HTML、CSS和JS是如何變成頁面的?

開發 前端
我們經常寫 HTML 、 CSS 和 JavaScript ,寫好這些之后,我們就會在瀏覽器中看到頁面,那瀏覽器究竟在這背后做了一些什么事情呢?本篇文章將揭曉答案!

我們經常寫 HTML 、 CSS 和 JavaScript ,寫好這些之后,我們就會在瀏覽器中看到頁面,那瀏覽器究竟在這背后做了一些什么事情呢?本篇文章將揭曉答案!

了解瀏覽器的渲染原理是我們在通往更深層次的前端開發中不可缺少的,它可以讓我們從更深層次、角度去考慮性能優化等~

下面進入正文~

進程、線程

瀏覽器會分配一個線程“自上而下,從左到右”依次解析和渲染代碼,那么進程和線程是什么,它們之間有著怎樣的關系呢?

進程

一個進程就是一個程序運行的實例。當啟動一個程序的時候,操作系統會為該程序創建一塊內存,用來存放代碼,運行中的數據和一個執行任務的主線程,這樣的一個運行環境就叫進程

線程

線程不能單獨存在,它是由進程來啟動和管理的。線程依附于進程,進程中使用多線程并行處理能提升運算效率

兩者之間的關系

1、進程中的任意一線程執行出錯,都會導致整個進程的崩潰

2、線程之間可以共享數據

3、當一個進程關閉后,操作系統會回收進程所占用的內存

4、進程之間的內容相互隔離

渲染機制

從HTML、CSS和JavaScript開始

了解瀏覽器的渲染原理,我們就要從理解 HTML 、 CSS 和 JavaScrip 開始,我們先來看一張圖

【瀏覽器】HTML、CSS和JS如何變成頁面的?

HTML (超文本標記語言),顧名思義,由標記(標簽)和文本組成,每個標簽都有自己的語意,瀏覽器會根據標簽和文本展示對應的內容。

CSS (層疊樣式表),由選擇器和屬性組成,它可以改變 HTML 的樣式,比如上圖中,我們改變了 span 的顏色由藍色為綠色。

JavaScript ,我們可以通過 JS 完成很多事情,例如上圖中修改樣式。

下面開始分析渲染的原理

渲染流水線

渲染模塊由于渲染的機制的復雜,被劃分為了很多子階段,輸入的 HTML 經過這些子階段,最后會輸出為像素。這樣的處理流程就叫做 渲染流水線

【瀏覽器】HTML、CSS和JS如何變成頁面的?

按照渲染的時間順序,流水線可分為幾個子階段:構建 DOM 樹、樣式計算、布局階段、分層、繪制、分塊、光柵化和合成

構建DOM樹

由于瀏覽器無法直接理解和使用 HTML ,所以需要將 HTML 轉換為瀏覽器能夠理解的結構( DOM 樹)

樹結構示意圖

【瀏覽器】HTML、CSS和JS如何變成頁面的?

DOM樹的構建過程

我們來分析一下下面這段代碼會構建出一棵什么樣的 DOM 樹

【瀏覽器】HTML、CSS和JS如何變成頁面的?

我們先將上面的代碼運行,然后在瀏覽器控制臺輸入 document ,看看會有什么效果

【瀏覽器】HTML、CSS和JS如何變成頁面的?

我們一層級一層級的打開就會看到如上圖的效果,我們可以根據這每一層級展開的效果,繪制出一棵 DOM 樹結構,如下:

【瀏覽器】HTML、CSS和JS如何變成頁面的?

接下來,我們試一下利用 JS 修改一下內容,看有什么改變:

【瀏覽器】HTML、CSS和JS如何變成頁面的?

我們可以看到“瀏覽器”的文字變成了“chrome”

【瀏覽器】HTML、CSS和JS如何變成頁面的?

再來看一下 DOM 樹是否有改變

【瀏覽器】HTML、CSS和JS如何變成頁面的?

我們看到在“瀏覽器”的位置換成了“chrome”,那么如何讓 DOM 節點擁有樣式?

樣式計算

樣式計算,顧名思義,就是 計算出 DOM 節點中每個元素的具體樣式 ,這個階段會分為三部分:

  • 把 CSS 轉換為瀏覽器能夠理解的結構
  • 轉換樣式表中的屬性值,使其標準化
  • 計算出 DOM 樹中每個節點的樣式

CSS樣式來源

  • link 導入外部樣式資源

瀏覽器會新開辟一個線程,去服務器獲取對應的資源文件(不阻礙主線程的渲染)

  • style 內嵌樣式

從上到下解析,解析完繼續解析 DOM 結構。在真實項目中,如果 css 代碼不是很多,或是移動端項目,我們應該使用內嵌式,以此來減少 http 資源的請求,提高頁面渲染速度

  • 行內樣式
  • @import 導入

它是同步的,不會開辟新線程去加載資源文件,而是讓主線程去獲取,這阻礙 DOM 結構的繼續渲染;只有把外部樣式導入進來,并且解析后,才會繼續渲染 DOM 結構

把CSS轉換為瀏覽器能夠理解的結構

瀏覽器就像不能理解 HTML 一樣,不理解 CSS ,所以當渲染引擎接收到 CSS 文件時,會執行轉換操作,將 CSS 文本轉換為瀏覽器可以理解的 styleSheets 結構。

在 HTML 中,在瀏覽器中輸入 document 可以查看 html 的結構。在 css 中,可以輸入 document.styleSheets 看到 css 的結構

【瀏覽器】HTML、CSS和JS如何變成頁面的?

現在的結構是空的,我們來加一些樣式,看看效果

【瀏覽器】HTML、CSS和JS如何變成頁面的?

轉換樣式表中的屬性值,使其標準化

屬性值標準化就是將所有值轉換為渲染引擎容易理解的、標準化的計算值。我們大致看一下效果:

  • 標準化前
  1. body { 
  2.     font-size: 2em; 
  3.     color: black; 
  4.     font-weight: bold; 
  5.     ... 
  • 標準化后
  1. body { 
  2.     font-size: 16px; 
  3.     color: rgb(0, 0, 0); 
  4.     font-weight: 700; 
  5.     ... 

計算出DOM樹中每個節點的具體樣式

樣式計算有兩個CSS的規則:繼承規則和層疊規則

  • CSS繼承規則

CSS 繼承就是每個 DOM 節點都包含有父節點的樣式。我們來看一下下面這段代碼中如何應用到 DOM 節點上

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"
  5.     <title>Document</title> 
  6.     <style> 
  7.         h1 { 
  8.             color: red; 
  9.         } 
  10.  
  11.         div { 
  12.             color: blue; 
  13.         } 
  14.  
  15.         span { 
  16.             font-size: 16px; 
  17.         } 
  18.     </style> 
  19. </head> 
  20. <body> 
  21.     <h1>掘金</h1> 
  22.     <div> 
  23.         <span>瀏覽器</span> 
  24.         <span>渲染原理</span> 
  25.         構建DOM樹 
  26.     </div> 
  27. </body> 
  28. </html> 


子節點會擁有父節點的樣式,由此我們可以畫出這樣一張圖

【瀏覽器】HTML、CSS和JS如何變成頁面的?

我們還可以打開控制臺,看一下選中 span 標簽,都會看到哪些內容

【瀏覽器】HTML、CSS和JS如何變成頁面的?

通過上圖,我們可看到一個元素的樣式、繼承過程等, userAgent 樣式是瀏覽器默認的內置樣式,如果我們不提供任何樣式,就會使用此樣式。

  • 樣式層疊規則

層疊在 CSS 處于核心地位,它是 CSS 的一個基本特征,它定義了如何合并來自多個源的屬性值的算法。

樣式計算階段最終輸出的內容是每個 DOM 節點的樣式,并且保存在了 ComputedStyle 中。我們可以通過控制臺看到某個 DOM 元素最終的計算樣式

【瀏覽器】HTML、CSS和JS如何變成頁面的?

布局階段

現在我們不知道 DOM 元素的幾何位置信息,所以現在我們需要計算出 DOM 樹中可見元素的幾何位置,這個計算過程就叫做布局。布局階段有兩個過程:

  • 創建布局樹
  • 布局計算

創建布局樹

創建布局樹的意思就是創建一棵只包含可見元素的樹。我們來看下面一段代碼創建布局樹的過程

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"
  5.     <title>Document</title> 
  6.     <style> 
  7.         h1 { 
  8.             color: red; 
  9.         } 
  10.  
  11.         div { 
  12.             color: blue; 
  13.         } 
  14.  
  15.         div span { 
  16.             font-size: 16px; 
  17.         } 
  18.  
  19.         div span:last-child { 
  20.             display: none; 
  21.         } 
  22.     </style> 
  23. </head> 
  24. <body> 
  25.     <h1>掘金</h1> 
  26.     <div> 
  27.         <span>瀏覽器</span> 
  28.         <span>渲染原理</span> 
  29.         構建DOM樹 
  30.     </div> 
  31. </body> 
  32. </html> 


構建布局樹的過程中, DOM 樹中所有不可見的節點都不會包含在這棵樹中。瀏覽器會遍歷 DOM 樹中所有能看見的節點,然后把這些節點加入到布局中;不可見的節點就會被忽略, head 標簽下面的內容、 div 下最后一個 span 節點都不會在布局樹中,我們看一下這個過程圖感受一下~

【瀏覽器】HTML、CSS和JS如何變成頁面的?

布局計算

布局計算就是計算布局樹節點的坐標位置。這個計算過程極為復雜。

分層

渲染引擎會為特定的節點生成專用的圖層,并生成一棵對應的圖層樹。這樣做是因為頁面中可能含有很多復雜的效果,我們可以打開控制臺看一下頁面的分層情況

【瀏覽器】HTML、CSS和JS如何變成頁面的?

 

【瀏覽器】HTML、CSS和JS如何變成頁面的?

我們可以看到,渲染引擎給頁面分了很多圖層,這些圖層會按照一定順序疊加在一起,形成最終的頁面

【瀏覽器】HTML、CSS和JS如何變成頁面的?

那么圖層的來源有哪些?

1、擁有層疊上下文屬性的元素會被提升為單獨的一層

層疊上下文可以使能夠使 HTML 元素具有三維的概念,這些 HTML 元素按照自身屬性的優先級分布在垂直于這個二維平面的 z 軸上。哪些元素具有層疊上下文屬性?

【瀏覽器】HTML、CSS和JS如何變成頁面的?

2、需要剪裁的地方會被創建為圖層

當我們創建一個有寬度和高度的 div 時,里面的文字內容可能會超出這個區域,這時候渲染引擎會把裁剪文字內容的一部分用于顯示在 div 區域,例如

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"
  5.     <meta name="viewport" content="width=device-width, initial-scale=1.0"
  6.     <title>Document</title> 
  7.     <style> 
  8.         div { 
  9.             width: 100px; 
  10.             height: 100px; 
  11.             background: yellow; 
  12.             overflow: auto; 
  13.         } 
  14.     </style> 
  15. </head> 
  16. <body> 
  17.     <div> 
  18.         我們經常寫`HTML`、`CSS`和`JavaScript`,寫好這些之后,我們就會在瀏覽器中看到頁面,那瀏覽器究竟在這背后做了一些什么事情呢?本篇文章將揭曉答案! 
  19.  
  20.         了解瀏覽器的渲染原理是我們在通往更深層次的前端開發中不可缺少的,它可以讓我們從更深層次、角度去考慮性能優化等~ 
  21.     </div> 
  22. </body> 
  23. </html> 


運行結果

【瀏覽器】HTML、CSS和JS如何變成頁面的?

我們再打開控制臺的 layers 看一下效果

【瀏覽器】HTML、CSS和JS如何變成頁面的?

可以看到渲染引擎為文字部分單獨創建了一個圖層。

在布局樹中的節點如果擁有對應的圖層,這個節點就是一個圖層,如果沒有,這個節點就屬于父節點的圖層,如下圖:

【瀏覽器】HTML、CSS和JS如何變成頁面的?

圖層繪制

創建好圖層樹后,渲染引擎會繪制圖層樹中的每個圖層。渲染引擎會將圖層繪制分解為很多小的繪制指令,然后將這些指令按照順序組成待繪制列表,我們可以打開控制臺的 layers ,選擇 document 層,看一下效果

【瀏覽器】HTML、CSS和JS如何變成頁面的?

柵格化操作

柵格化就是將圖塊轉換位位圖,圖塊是柵格化執行的最小單位。渲染進程維護了一個柵格化的線程池,所有圖塊的柵格化都是在線程池內執行的。

圖層繪制列表準備好之后,主線程會把這個繪制列表提交給合成線程,繪制操作由渲染引擎中的合成線程來完成。

合成線程將圖層劃分為圖塊,然后合成線程會按照視口(可見區域)附近的圖塊優先生成位圖。

合成與顯示

所有的圖塊都被光柵化后,合成線程會生成一個繪制圖塊的命令( DrawQuad ),然后將該命令提交給瀏覽器進程。瀏覽器進程里面 viz 組件用來接收 DrawQuad 命令,將其頁面內容繪制到內存中,最后將內存顯示到屏幕。這個時候,我們就看到了頁面

完善渲染流水線示意圖

根據上文中描述,我們可以畫出這樣一張圖

【瀏覽器】HTML、CSS和JS如何變成頁面的?

我還在網上找到了另外一張圖

【瀏覽器】HTML、CSS和JS如何變成頁面的?

這兩張圖都是描述瀏覽器的渲染流程的。

 

責任編輯:龐桂玉 來源: 今日頭條
相關推薦

2019-12-05 15:30:21

HTMLCSSJavaScript

2018-10-22 16:21:50

ChromeHTMLCSS

2011-03-29 13:45:55

HTMLCSSjavascript

2022-09-22 16:03:07

CSS-in-JS代碼

2009-07-06 18:23:56

Struts和JSPJSP頁面

2011-09-08 15:06:33

HTML 5

2013-09-16 10:19:08

htmlcssJavaScript

2010-08-27 15:16:26

htmlbodyCSS

2021-04-28 06:00:36

CSS contain技巧

2018-05-15 10:34:50

JavaScript語言互聯網

2009-07-03 18:12:49

JSP頁面

2021-08-19 06:58:48

CSS頁面布局

2012-10-31 10:36:17

js前端JavaScript頁面構建

2017-05-10 12:05:17

pyspiderHTMLCSS

2010-10-09 10:56:50

DHTMLJS

2012-07-25 09:15:16

盜版者客戶

2021-09-01 09:54:10

IP地址域名

2016-08-18 01:45:05

數據科學數據產品

2022-11-11 08:16:51

2015-11-20 11:20:54

js開發
點贊
收藏

51CTO技術棧公眾號

亚洲二区视频在线| 粉嫩嫩av羞羞动漫久久久| 亚洲一二三不卡| 57pao精品| 国产熟人av一二三区| 在线免费av网站| 成人免费视频caoporn| 日韩免费黄色av| 放荡的美妇在线播放| 欧美黄色录像| 91麻豆精品国产91久久久久 | 国产精品国产自产拍在线| 91在线在线观看| 午夜久久久久久久久久影院| 自拍日韩欧美| 在线精品91av| 日本少妇xxxx| 亚洲在线资源| 欧美性少妇18aaaa视频| 欧洲精品视频在线| h网站在线免费观看| 成人av在线观| 亚洲字幕在线观看| 性色av一区二区三区四区| 一区在线免费观看| 欧美成人免费全部| 美国黄色片视频| 亚洲欧美日韩成人在线| 裸体在线国模精品偷拍| 欧美专区在线观看| 懂色av.com| 久久久国产精品| 中文字幕一区二区精品| 在线观看福利片| 老牛影视av一区二区在线观看| 欧美一区二区三级| 国产aⅴ爽av久久久久| 日韩免费小视频| 欧美性色视频在线| 国产性xxxx18免费观看视频| 91高清视频在线观看| 亚洲激情中文1区| 中文精品视频一区二区在线观看| 成人午夜影视| 国产精品人人做人人爽人人添| 久久久久久亚洲精品不卡4k岛国| 精品国产一级片| 久久国产剧场电影| 国产精品亚洲视频在线观看| 欧美激情一区二区三区免费观看| 久久精品动漫| 国产精品99久久久久久白浆小说| 国产精品自拍99| 国产精品一国产精品k频道56| 久久人人爽人人爽人人片av高清| 国产亚洲成人av| 影音先锋日韩资源| 7777kkkk成人观看| 久久精品五月天| 日本美女一区二区三区视频| 国产精品色视频| 一二三区在线播放| 国产在线观看免费一区| 69堂成人精品视频免费| 亚洲男人天堂久久| 99久久精品免费看国产免费软件| 国产精品国产亚洲精品看不卡15 | 免费网站观看www在线观| 欧美先锋影音| 91精品国产网站| 一二三区免费视频| 老司机精品视频一区二区三区| 成人精品久久av网站| 国产视频在线一区| 成人av高清在线| 日本不卡一区二区三区视频| 日本在线看片免费人成视1000| 亚洲欧美二区三区| 精品视频免费在线播放| 日本精品在线一区| 欧美一级淫片007| 久久久国产精品无码| 狠狠做六月爱婷婷综合aⅴ| 久久久国产成人精品| 精品肉丝脚一区二区三区| 欧美亚洲在线| 91久久久久久国产精品| 人妻夜夜爽天天爽| 国产精品毛片久久久久久久| 台湾无码一区二区| 欧美国产大片| 日韩视频一区二区在线观看| 日本japanese极品少妇| 天天做天天爱天天综合网2021| 欧美黄色小视频| 黄色av网站免费观看| 国产伦精品一区二区三区免费迷 | 一区二区毛片| 国产日韩在线播放| 头脑特工队2免费完整版在线观看| 亚洲国产精品成人综合 | 性欧美精品高清| 成人中文字幕+乱码+中文字幕| 色欲久久久天天天综合网| 中文字幕不卡一区| 日本在线xxx| 成人豆花视频| 亚洲日韩第一页| 久久久久噜噜噜亚洲熟女综合| 奇米色一区二区| 久久久www免费人成黑人精品| 国产一二三区在线观看| 色综合咪咪久久| 香蕉视频免费网站| 51精产品一区一区三区| 国产999精品久久久影片官网| 午夜美女福利视频| 中文字幕一区二区三区在线播放| 激情深爱综合网| 久久久精品区| 色综合伊人色综合网站| 黄色av网站免费| 9色porny自拍视频一区二区| 九九久久九九久久| 成人网av.com/| 最近的2019中文字幕免费一页| 狠狠躁夜夜躁人人爽天天高潮| 国产精品中文字幕一区二区三区| 日韩美女一区| sis001欧美| 亚洲精品日韩久久久| 精品一级少妇久久久久久久| 国产在线精品一区二区不卡了| 亚洲欧洲精品一区| 精品肉辣文txt下载| 亚洲欧洲国产一区| 亚洲GV成人无码久久精品| av电影一区二区| 91成人在线观看喷潮教学| 2021年精品国产福利在线| 美女啪啪无遮挡免费久久网站| 91丨九色丨蝌蚪丨对白| 久久精品一区二区三区不卡| 日韩网址在线观看| 综合亚洲色图| 日本精品视频在线| 欧美在线观看在线观看| 欧美午夜宅男影院在线观看| 国产伦精品一区二区三区妓女 | www亚洲成人| 成人a'v在线播放| 国产精品丝袜久久久久久高清| 丁香婷婷在线| 欧美日韩黄色影视| 欧美特黄一级片| 国产乱理伦片在线观看夜一区| 8x8x华人在线| 成午夜精品一区二区三区软件| 久久久久久尹人网香蕉| 免费看日韩av| 色哟哟一区二区在线观看| 韩国三级hd中文字幕| 蜜桃视频一区二区| 永久免费在线看片视频| 综合久久成人| 热99久久精品| 天堂аⅴ在线地址8| 欧美日韩国产影片| 欧美精品一区二区成人| 91美女福利视频| 波多野结衣天堂| 中文字幕免费一区二区| 国产精品免费一区二区三区在线观看 | aaaaaaaa毛片| 国产欧美亚洲一区| 亚洲第一综合| 777久久精品| 清纯唯美日韩制服另类| 欧美日韩xx| 亚洲成人黄色网| 成人黄色三级视频| 有码一区二区三区| av中文字幕免费观看| 九九**精品视频免费播放| 欧洲精品在线播放| 国产成人黄色| 超碰97国产在线| 伊人久久在线| 欧美成人精品一区| 精品999视频| 日韩女优视频免费观看| 久久久精品视频网站| 亚洲欧美一区二区三区国产精品 | 人妻少妇偷人精品久久久任期| 伊人精品视频| 手机福利在线视频| 国产不卡一区| 91网免费观看| free欧美| 午夜精品久久久久久久久久久久 | 手机看片国产1024| 欧美日韩亚洲综合在线| 精品美女久久久久| 亚洲乱码国产乱码精品精98午夜 | 一级黄色片在线免费观看| 国产精品久久久久久模特 | 欧美一区二区播放| 无码人妻丰满熟妇区bbbbxxxx| 一区二区三区自拍| 三级黄色免费观看| 久久亚区不卡日本| www.555国产精品免费| 蜜桃视频在线观看一区二区| 欧美亚洲日本一区二区三区| 亚洲精品一区二区妖精| 日本不卡一区二区三区视频| 欧美黑人巨大videos精品| 91麻豆精品秘密入口| 亚洲欧美在线人成swag| 国产91久久婷婷一区二区| 国产亚av手机在线观看| 久久av在线看| bt在线麻豆视频| 色偷偷av一区二区三区乱| 九色网友自拍视频手机在线| 亚洲国产中文字幕在线观看 | 亚洲欧洲第一视频| 亚洲人成色777777精品音频| 精品噜噜噜噜久久久久久久久试看| 亚洲天堂手机版| 欧美影院精品一区| 69亚洲精品久久久蜜桃小说| 欧美日韩国产在线看| 日本午夜小视频| 亚洲一二三四区| 强行糟蹋人妻hd中文| 亚洲免费观看高清完整| 小早川怜子一区二区的演员表| 国产精品污网站| 国产人妻大战黑人20p| 久久亚洲精品国产精品紫薇| 亚洲第一成人网站| 久久久五月婷婷| 精品欧美一区二区久久久| 国产校园另类小说区| 极品人妻videosss人妻| 中文字幕精品一区| 99热6这里只有精品| 国产精品美女久久久久久久久 | 完美搭档在线观看| www.爱久久.com| 国产精品久久AV无码| 91捆绑美女网站| 亚洲综合色一区| 国产精品无人区| www.毛片com| 亚洲精品视频一区二区| 久青草免费视频| 香蕉乱码成人久久天堂爱免费| 国产成人自拍视频在线| 一本久久综合亚洲鲁鲁五月天| 天天操天天干天天摸| 欧美日韩成人一区| 亚洲毛片在线播放| 精品视频—区二区三区免费| 国产香蕉视频在线看| xvideos亚洲人网站| 午夜av在线免费观看| 97在线观看免费| 国产精品亚洲d| 91久久久一线二线三线品牌| 欧美韩一区二区| 午夜精品一区二区在线观看| 羞羞色午夜精品一区二区三区| 青青在线视频免费观看| 亚洲影院在线| 成年网站在线播放| 高清日韩电视剧大全免费| 在线观看国产免费视频| 国产精品丝袜91| 精品无码久久久久| 欧美性大战久久久久久久蜜臀| 国产又大又黄又爽| 亚洲国产欧美一区二区三区同亚洲| 天堂а√在线8种子蜜桃视频| 色哟哟入口国产精品| av今日在线| 成人免费视频网址| 日日狠狠久久偷偷综合色| 中文字幕一区二区三区最新 | 欧美国产日韩一区二区| 一区二区电影免费观看| 亚洲free嫩bbb| 亚洲视频分类| 日韩一二区视频| 日韩av电影免费观看高清完整版| 性一交一黄一片| 国产午夜精品久久| 日韩欧美国产亚洲| 91麻豆精品国产自产在线观看一区 | 成人国产精品免费观看动漫| 在线观看日本黄色| 亚洲成a人片综合在线| 一本久道久久综合无码中文| 日韩久久午夜影院| 国产一二区在线| 国产精品成人av在线| 成人av综合网| 国产精品电影网| 18国产精品| 日韩第一页在线观看| 天堂蜜桃91精品| xxxwww国产| 樱桃视频在线观看一区| 一级黄色大毛片| 亚洲视频视频在线| 美女高潮视频在线看| 不卡日韩av| 91综合久久| 婷婷丁香激情网| 久久久噜噜噜久久中文字幕色伊伊| 国产一级做a爰片在线看免费| 欧美三级视频在线播放| 青梅竹马是消防员在线| 国语自产精品视频在线看抢先版图片| va天堂va亚洲va影视| 五码日韩精品一区二区三区视频| 国产欧美日韩亚洲一区二区三区| 国产国语老龄妇女a片| 亚洲免费观看在线视频| 91黄色在线视频| www.久久色.com| 欧美日韩免费电影| 性欧美videosex高清少妇| 丝袜诱惑制服诱惑色一区在线观看 | 亚洲欧美校园春色| 亚洲熟妇av一区二区三区漫画| 成人综合婷婷国产精品久久| 激情综合网五月天| 精品国产在天天线2019| 欧美人体视频xxxxx| 91在线在线观看| 激情久久五月| 国产真实乱人偷精品| 婷婷成人综合网| 蜜桃视频在线免费| 国产成人拍精品视频午夜网站| 精品免费在线| 九色porny自拍| 亚洲人精品午夜| 成人激情四射网| 98精品国产高清在线xxxx天堂| 奇米影视777在线欧美电影观看 | 蜜桃视频在线观看一区二区| 色www亚洲国产阿娇yao| 国产精品久久久免费视频| 国产丝袜一区视频在线观看| 日韩精品一区二区三区| 亚洲精品日韩在线观看| 激情综合网av| 国产一级在线视频| 亚洲免费电影在线观看| 日韩一区二区三区免费视频| 一区二区在线观| 国产 欧美在线| 区一区二在线观看| 神马久久久久久| 亚洲网址在线观看| 欧美日韩国产精品激情在线播放| 国产午夜精品美女毛片视频| 国产欧美一级片| 91精品国产91久久久| 国产一区毛片| 国产又粗又猛大又黄又爽| 五月综合激情网| 日本在线观看www| 国产成人一区二区三区免费看| 国产欧美日韩一区二区三区在线| 国产性猛交xx乱| 欧美大片顶级少妇| 三上悠亚激情av一区二区三区| 在线免费观看成人| 99久久精品国产麻豆演员表| 啪啪小视频网站| 欧美日韩福利电影| 国产精品欧美三级在线观看| 性久久久久久久久久久久久久| 性欧美疯狂xxxxbbbb| 中文日本在线观看| 精品综合久久久| 韩日av一区二区| 亚洲自拍一区在线观看| 日韩亚洲精品电影| 青青草久久爱| 国模大尺度视频| 欧美在线综合视频| caoporn视频在线| 不卡中文字幕在线| 久久精品欧美一区二区三区不卡 | 亚洲免费在线视频观看|