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

高性能JavaScript DOM編程以及重排與重繪

開發 前端
我們知道,DOM是用于操作XML 和HTML文檔的應用程序接口,用腳本進行DOM操作的代價很昂貴。有個貼切的比喻,把DOM和JavaScript(這里指ECMScript)各自想 象為一個島嶼,它們之間用收費橋梁連接,ECMAScript每次訪問DOM,都要途徑這座橋,并交納“過橋費”,訪問DOM的次數越多,費用也就越高。 因此,推薦的做法是盡量減少過橋的次數,努力待在ECMAScript島上。我們不可能不用DOM的接口,那么,怎樣才能提高程序的效率?

我們知道,DOM是用于操作XML 和HTML文檔的應用程序接口,用腳本進行DOM操作的代價很昂貴。有個貼切的比喻,把DOM和JavaScript(這里指ECMScript)各自想 象為一個島嶼,它們之間用收費橋梁連接,ECMAScript每次訪問DOM,都要途徑這座橋,并交納“過橋費”,訪問DOM的次數越多,費用也就越高。 因此,推薦的做法是盡量減少過橋的次數,努力待在ECMAScript島上。我們不可能不用DOM的接口,那么,怎樣才能提高程序的效率?

 高性能JavaScript DOM編程以及重排與重繪

1、DOM訪問與修改


訪問DOM元素是有代價的(“過橋費”你懂的),修改元素代價更是昂貴,因為它會導致瀏覽器重新計算頁面的幾何變化(重排和重繪)。

當然最壞的情況是在循環中訪問或者修改元素,看下面兩段代碼:

var times = 15000;

// code1
console.time(1);
for(var i = 0; i < times; i++) {
  document.getElementById('myDiv1').innerHTML += 'a';
}
console.timeEnd(1);

// code2
console.time(2);
var str = '';
for(var i = 0; i < times; i++) {
  str += 'a';
}
document.getElementById('myDiv2').innerHTML = str;
console.timeEnd(2);

結果***次運行的時間居然是第二次的千倍!(chrome 版本 44.0.2403.130 m)

1: 2846.700ms
2: 1.046ms

***段代碼的問題在于,每次循環迭代,該元素都會被訪問兩次:一次讀取innerHTML的值,另一次重寫它,也就是說,每次循環都在過橋(重排和重繪將在下一篇講解)!結果充分表明,訪問DOM的次數越多,代碼的運行速度越慢。因此,能減少DOM訪問的次數則盡量減少,盡量留在ECMAScript這端處理。

2、HTML集合 & 遍歷DOM


操作DOM另一個耗能點就是遍歷DOM,一般我們會收集一個HTML集合,比如用getElementsByTagName(),或者用document.links等,我想大家對此都不陌生。收集的結果是一個類似數組的集合,它處于一種“實時狀態”實時存在,這意味著當底層文檔對象更新時,它也會自動更新。怎么講?很簡單舉個栗子:

<body>
  <ul id='fruit'>
    <li> apple </li>
    <li> orange </li>
    <li> banana </li>
  </ul>
</body>
<script type="text/javascript"> var lis = document.getElementsByTagName('li'); var peach = document.createElement('li'); peach.innerHTML = 'peach'; document.getElementById('fruit').appendChild(peach); console.log(lis.length); // 4 </script>

而這正是低效之源!很簡單,跟數組的優化操作一樣,緩存個length變量就ok了(讀取一個集合的length比讀取一個普通數組的lengh要慢很多,因為每次都要查詢):

console.time(0);
var lis0 = document.getElementsByTagName('li');
var str0 = '';
for(var i = 0; i < lis0.length; i++) {
  str0 += lis0[i].innerHTML;
}
console.timeEnd(0);


console.time(1);
var lis1 = document.getElementsByTagName('li');
var str1 = '';
for(var i = 0, len = lis1.length; i < len; i++) {
  str1 += lis1[i].innerHTML;
}
console.timeEnd(1);

我們看看性能提升能有多少?

0: 0.974ms
1: 0.664ms

當集合的長度大的時候(demo是1000),性能提升還是很明顯的。

而《高性能JavaScript》提出了另一個優化策略,它指出,“由于遍歷數組比遍歷集合快,因此如果先將集合元素拷貝到數組中,那么訪問它的屬性會更快”,經過測試,并沒有很好地發現這個規律,所以還是不要多此一舉了,測試代碼如下:(有疑義歡迎與我交流探討)

console.time(1);
var lis1 = document.getElementsByTagName('li');
var str1 = '';
for(var i = 0, len = lis1.length; i < len; i++) {
  str1 += lis1[i].innerHTML;
}
console.timeEnd(1);


console.time(2);
var lis2 = document.getElementsByTagName('li');
var a = [];
for(var i = 0, len = lis2.length; i < len; i++)
  a[i] = lis2[i];

var str2 = '';
for(var i = 0, len = a.length; i < len; i++) {
  str2 += a[i].innerHTML;
}
console.timeEnd(2);

本節的***介紹兩個原生DOM方法,querySelector()querySelectorAll(),相信大家都不陌生,前者返回一個數組(注意,它們的返回值不像HTML集合一樣會動態變化),后者返回匹配的***個元素。好吧,其實并不是所有時候它的性能都優于前者的HTML集合遍歷。

console.time(1);
var lis1 = document.getElementsByTagName('li');
console.timeEnd(1);

console.time(2);
var lis2 = document.querySelectorAll('li');
console.timeEnd(2);

// 1: 0.038ms
// 2: 3.957ms

但是因為它是類似CSS的選擇方法,所以在做組合選擇的時候,效率會提升,又方便。比如做如下的組合查詢:

var elements = document.querySelectorAll('#menu a');
var elements = document.querySelectorAll('div.warning, div.notice');

#p#

先回顧下前文高性能JavaScript DOM編程,主要提了兩點優化,一是盡量減少DOM的訪問,而把運算放在ECMAScript這一端,二是盡量緩存局部變量,比如length等等,***介紹了兩個新的API querySelector()以及querySelectorAll(),在做組合選擇的時候可以大膽使用。而本文主要講的是DOM編程可能最耗時的地方,重排和重繪。

1、什么是重排和重繪


瀏覽器下載完頁面中的所有組件——HTML標記、JavaScript、CSS、圖片之后會解析生成兩個內部數據結構——DOM樹渲染樹。

DOM樹表示頁面結構,渲染樹表示DOM節點如何顯示。DOM樹中的每一個需要顯示的節點在渲染樹種至少存在一個對應的節點(隱藏的DOM元素 disply值為none 在渲染樹中沒有對應的節點)。渲染樹中的節點被稱為“幀”或“盒",符合CSS模型的定義,理解頁面元素為一個具有填充,邊距,邊框和位置的盒子。一旦 DOM和渲染樹構建完成,瀏覽器就開始顯示(繪制)頁面元素。

當DOM的變化影響了元素的幾何屬性(寬或高),瀏覽器需要重新計算元素的幾何屬性,同樣其他元素的幾何屬性和位置也會因此受到影響。瀏覽器會使渲染樹中受到影響的部分失效,并重新構造渲染樹。這個過程稱為重排。完成重排后,瀏覽器會重新繪制受影響的部分到屏幕,該過程稱為重繪。由于瀏覽器的流布局,對渲染樹的計算通常只需要遍歷一次就可以完成。但table及其內部元素除外,它可能需要多次計算才能確定好其在渲染樹中節點的屬性,通常要花3倍于同等元素的時間。這也是為什么我們要避免使用table做布局的一個原因。

并不是所有的DOM變化都會影響幾何屬性,比如改變一個元素的背景色并不會影響元素的寬和高,這種情況下只會發生重繪。

2、重排和重繪的代價究竟多大


重排和重繪的代價有多大?我們再回到前文那個過橋的例子上,細心的你可能會發現了,千倍的時間差并不是由于“過橋”一手造成的,每次“過橋”其實都伴隨著重排和重繪,而耗能的絕大部分也正是在這里!

var times = 15000;

// code1 每次過橋+重排+重繪
console.time(1);
for(var i = 0; i < times; i++) {
  document.getElementById('myDiv1').innerHTML += 'a';
}
console.timeEnd(1);

// code2 只過橋
console.time(2);
var str = '';
for(var i = 0; i < times; i++) {
  var tmp = document.getElementById('myDiv2').innerHTML;
  str += 'a';
}
document.getElementById('myDiv2').innerHTML = str;
console.timeEnd(2);

// code3
console.time(3);
var _str = '';
for(var i = 0; i < times; i++) {
  _str += 'a';
}
document.getElementById('myDiv3').innerHTML = _str;
console.timeEnd(3);


// 1: 2874.619ms
// 2: 11.154ms
// 3: 1.282ms

數據是不會撒謊的,看到了吧,多次訪問DOM對于重排和重繪來說,耗時簡直不值一提了。

3、重排何時發生


很顯然,每次重排,必然會導致重繪,那么,重排會在哪些情況下發生?

  1. 添加或者刪除可見的DOM元素

  2. 元素位置改變

  3. 元素尺寸改變

  4. 元素內容改變(例如:一個文本被另一個不同尺寸的圖片替代)

  5. 頁面渲染初始化(這個無法避免)

  6. 瀏覽器窗口尺寸改變

這些都是顯而易見的,或許你已經有過這樣的體會,不間斷地改變瀏覽器窗口大小,導致UI反應遲鈍(某些低版本IE下甚至直接掛掉),現在你可能恍然大悟,沒錯,正是一次次的重排重繪導致的!

4、渲染樹變化的排隊和刷新


思考下面代碼:

var ele = document.getElementById('myDiv');
ele.style.borderLeft = '1px';
ele.style.borderRight = '2px';
ele.style.padding = '5px';

乍一想,元素的樣式改變了三次,每次改變都會引起重排和重繪,所以總共有三次重排重繪過程,但是瀏覽器并不會這么笨,它會把三次修改“保存”起來 (大多數瀏覽器通過隊列化修改并批量執行來優化重排過程),一次完成!但是,有些時候你可能會(經常是不知不覺)強制刷新隊列并要求計劃任務立即執行。獲 取布局信息的操作會導致隊列刷新,比如:

  1. offsetTop, offsetLeft, offsetWidth, offsetHeight

  2. scrollTop, scrollLeft, scrollWidth, scrollHeight

  3. clientTop, clientLeft, clientWidth, clientHeight

  4. getComputedStyle() (currentStyle in IE)

將上面的代碼稍加修改:

var ele = document.getElementById('myDiv');
ele.style.borderLeft = '1px';
ele.style.borderRight = '2px';

// here use offsetHeight
// ...
ele.style.padding = '5px';

因為offsetHeight屬性需要返回***的布局信息,因此瀏覽器不得不執行渲染隊列中的“待處理變化”并觸發重排以返回正確的值(即使隊列中 改變的樣式屬性和想要獲取的屬性值并沒有什么關系),所以上面的代碼,前兩次的操作會緩存在渲染隊列中待處理,但是一旦offsetHeight屬性被請 求了,隊列就會立即執行,所以總共有兩次重排與重繪。所以盡量不要在布局信息改變時做查詢

5、最小化重排和重繪


我們還是看上面的這段代碼:

var ele = document.getElementById('myDiv');
ele.style.borderLeft = '1px';
ele.style.borderRight = '2px';
ele.style.padding = '5px';

三個樣式屬性被改變,每一個都會影響元素的幾何結構,雖然大部分現代瀏覽器都做了優化,只會引起一次重排,但是像上文一樣,如果一個及時的屬性被請求,那么就會強制刷新隊列,而且這段代碼四次訪問DOM,一個很顯然的優化策略就是把它們的操作合成一次,這樣只會修改DOM一次:

var ele = document.getElementById('myDiv');

// 1. 重寫style
ele.style.cssText = 'border-left: 1px; border-right: 2px; padding: 5px;';

// 2. add style
ele.style.cssText += 'border-;eft: 1px;'

// 3. use class
ele.className = 'active';

6、fragment元素的應用


看如下代碼,考慮一個問題:

<ul id='fruit'>
  <li> apple </li>
  <li> orange </li>
</ul>

如果代碼中要添加內容為peach、watermelon兩個選項,你會怎么做?

var lis = document.getElementById('fruit');
var li = document.createElement('li');
li.innerHTML = 'apple';
lis.appendChild(li);

var li = document.createElement('li');
li.innerHTML = 'watermelon';
lis.appendChild(li);

很容易想到如上代碼,但是很顯然,重排了兩次,怎么破?前面我們說了,隱藏的元素不在渲染樹中,太棒了,我們可以先把id為fruit的ul元素隱藏(display=none),然后添加li元素,***再顯示,但是實際操作中可能會出現閃動,原因這也很容易理解。這時,fragment元素就有了用武之地了。

var fragment = document.createDocumentFragment();

var li = document.createElement('li');
li.innerHTML = 'apple';
fragment.appendChild(li);

var li = document.createElement('li');
li.innerHTML = 'watermelon';
fragment.appendChild(li);

document.getElementById('fruit').appendChild(fragment);

文檔片段是個輕量級的document對象,它的設計初衷就是為了完成這類任務——更新和移動節點。文檔片段的一個便利的語法特性是當你附加一個片斷到節點時,實際上被添加的是該片斷的子節點,而不是片斷本身。只觸發了一次重排,而且只訪問了一次實時的DOM。

7、讓元素脫離動畫流


用展開/折疊的方式來顯示和隱藏部分頁面是一種常見的交互模式。它通常包括展開區域的幾何動畫,并將頁面其他部分推向下方。

一般來說,重排只影響渲染樹中的一小部分,但也可能影響很大的部分,甚至整個渲染樹。瀏覽器所需要重排的次數越少,應用程序的響應速度就越快。因此 當頁面頂部的一個動畫推移頁面整個余下的部分時,會導致一次代價昂貴的大規模重排,讓用戶感到頁面一頓一頓的。渲染樹中需要重新計算的節點越多,情況就會 越糟。

使用以下步驟可以避免頁面中的大部分重排:

  1. 使用絕對位置定位頁面上的動畫元素,將其脫離文檔流

  2. 讓元素動起來。當它擴大時,會臨時覆蓋部分頁面。但這只是頁面一個小區域的重繪過程,不會產生重排并重繪頁面的大部分內容。

  3. 當動畫結束時恢復定位,從而只會下移一次文檔的其他元素

8、總結


重排和重繪是DOM編程中耗能的主要原因之一,平時涉及DOM編程時可以參考以下幾點:

  1. 盡量不要在布局信息改變時做查詢(會導致渲染隊列強制刷新)

  2. 同一個DOM的多個屬性改變可以寫在一起(減少DOM訪問,同時把強制渲染隊列刷新的風險降為0)

  3. 如果要批量添加DOM,可以先讓元素脫離文檔流,操作完后再帶入文檔流,這樣只會觸發一次重排(fragment元素的應用)

  4. 將需要多次重排的元素,position屬性設為absolute或fixed,這樣此元素就脫離了文檔流,它的變化不會影響到其他元素。例如有動畫效果的元素就***設置為絕對定位。

 

責任編輯:王雪燕 來源: 博客園
相關推薦

2018-11-14 19:30:57

前端Javascript性能優化

2013-08-27 14:23:18

瀏覽器重繪

2021-04-28 06:00:36

CSS contain技巧

2011-04-25 10:11:57

高性能web開發

2013-11-20 14:09:37

重繪重排瀏覽器

2025-07-10 01:45:00

2022-03-16 09:02:46

渲染路徑瀏覽器重排和重繪

2010-09-28 14:12:50

Javascript

2022-03-21 14:13:22

Go語言編程

2024-10-06 14:37:52

2024-08-06 08:22:18

2024-09-03 09:15:37

2014-11-25 10:03:42

JavaScript

2012-12-17 13:51:22

Web前端JavaScriptJS

2024-10-16 11:03:30

Linux高性能編程

2011-02-23 12:59:08

JSJavaScript瀏覽器

2024-03-18 13:43:20

Linux架構

2009-06-24 15:00:39

Javascript代

2010-09-10 16:21:58

JavaScript

2023-11-01 11:59:13

點贊
收藏

51CTO技術棧公眾號

日韩不卡在线播放| 人妻巨大乳一二三区| 日本一级在线观看| 蜜臀av亚洲一区中文字幕| 久久精品国产久精国产一老狼| 亚洲成人激情小说| av资源亚洲| 亚洲人午夜精品天堂一二香蕉| 国产精品日韩高清| 中文字幕一二区| 韩日精品在线| 中文字幕欧美亚洲| 午夜剧场免费看| 黑人一区二区三区| 精品久久久久久久大神国产| 致1999电视剧免费观看策驰影院| 无码精品黑人一区二区三区 | 一区二区三区麻豆| 亚洲欧美亚洲| 中文字幕在线看视频国产欧美在线看完整| 亚洲一区二区三区四区精品| 手机看片久久| 五月天视频一区| 日本三级福利片| 国产专区在线播放| 99亚偷拍自图区亚洲| 91免费电影网站| 国产一级片av| 国产视频一区三区| 欧美激情视频网| 亚洲女人久久久| 欧美一二区在线观看| 亚洲国模精品私拍| 91精品人妻一区二区三区四区| 韩国精品视频在线观看| 色综合久久久久综合体| www.com毛片| gogo久久| 亚洲图片欧美综合| 成人在线观看毛片| 成人在线app| 中文字幕中文字幕一区| 图片区小说区区亚洲五月| 精品美女视频在线观看免费软件| www..com久久爱| 97se亚洲综合| 精品国产无码AV| 久久99国产精品久久99| 国产精品视频播放| 中文字幕第一页在线播放| 久久午夜视频| 国产精品成人在线| 中文字幕第99页| 美女脱光内衣内裤视频久久网站 | 无码 制服 丝袜 国产 另类| 性国产高清在线观看| 亚洲天堂福利av| 秋霞在线一区二区| 91香蕉在线观看| 亚洲精品日韩综合观看成人91| 影音先锋男人的网站| 成人短视频在线| 一级精品视频在线观看宜春院 | 日韩精彩视频在线观看| 国产成人在线视频| 在线观看免费高清视频| 久久电影网电视剧免费观看| 成人福利网站在线观看11| 91肉色超薄丝袜脚交一区二区| 久久99精品久久久久久久久久久久| 国产精品视频一区二区三区四| 亚洲熟妇无码久久精品| 国产做a爰片久久毛片| 99r国产精品视频| 国内爆初菊对白视频| 91在线一区二区| 欧美极品jizzhd欧美| 国产精品二线| 日韩毛片高清在线播放| 4444在线观看| 综合另类专区| 91精品国产综合久久精品图片 | 伊人免费在线观看| 国产风韵犹存在线视精品| 激情伦成人综合小说| 久久经典视频| 亚洲精品亚洲人成人网 | 国产免费一区二区三区四区| 国产精品videosex极品| 欧亚精品在线观看| 一级爱爱免费视频| 成人国产亚洲欧美成人综合网| 另类欧美小说| a毛片在线播放| 欧美日韩国产限制| 中文av字幕在线观看| 老司机在线精品视频| 最近免费中文字幕视频2019| 国产午夜久久久| 蜜臀av性久久久久蜜臀av麻豆| 成人性生交xxxxx网站| 天堂成人在线| 亚洲色图视频网| 欧美日韩第二页| 99久久免费精品国产72精品九九| 亚洲天堂一区二区三区| 欧美精品色哟哟| 青椒成人免费视频| 97视频中文字幕| 成人在线二区| 天天亚洲美女在线视频| 亚洲一级片av| 成人av动漫在线观看| 性欧美xxxx交| a在线观看免费| 国产日产欧美精品一区二区三区| 久草免费福利在线| 99精品国产九九国产精品| 亚洲女人天堂视频| 久久精品这里有| 国产美女一区二区| 小说区图片区图片区另类灬| 日韩av影片| 精品欧美一区二区在线观看| 亚洲欧美另类日本| 日本中文字幕不卡| 麻豆传媒一区| segui88久久综合| 欧美一级高清片| 小嫩苞一区二区三区| 日韩电影免费在线看| 蜜桃成人在线| 日韩欧美一中文字暮专区| 精品少妇一区二区三区在线播放| 国产精品白丝喷水在线观看| 久久9热精品视频| 亚洲成人网上| a屁视频一区二区三区四区| 国产视频自拍一区| 日韩中文字幕在线观看视频| 菠萝蜜视频在线观看一区| 欧美做暖暖视频| 一区二区精彩视频| 欧美高清第一页| 国产成人精品毛片| 一区二区在线观看不卡| 国产探花在线观看视频| 91精品国产调教在线观看| 国产精品主播视频| 蜜桃视频在线观看免费视频网站www| 欧美系列亚洲系列| 女人裸体性做爰全过| 奇米影视一区二区三区| 亚洲欧洲精品在线 | a级在线观看| 日韩欧美一区二区视频| 免费一级全黄少妇性色生活片| 国产一区二区在线观看视频| 亚洲国产一二三精品无码| 成人三级毛片| 欧美亚洲日本网站| 国产理论电影在线观看| 欧美午夜一区二区| 久久99久久99精品免费看小说| 国产一区二区女| 婷婷五月综合缴情在线视频| 老司机精品在线| 国产精品99蜜臀久久不卡二区| 春暖花开成人亚洲区| 欧美日韩中文精品| 欧美人禽zoz0强交| 成人成人成人在线视频| 成年人免费在线播放| 日韩一区二区三区免费播放| 亚洲一区二区三区四区在线播放| 大桥未久在线播放| 亚洲人成网在线播放| 亚洲中文一区二区三区| 一区二区三区在线观看视频| 北岛玲一区二区| 美国三级日本三级久久99| 在线成人av电影| 国产suv精品一区| 国产成人精品久久二区二区91| 免费在线看a| 亚洲国产高潮在线观看| 国产三级理论片| 一区二区三区四区在线免费观看| 国产精品无码专区| 久久99最新地址| 春日野结衣av| 亚洲高清影视| 久久久久久久久久久久久久一区 | 欧洲一区二区三区在线| 精品欧美一区二区久久久久| 久久婷婷国产综合精品青草| av在线网站免费观看| 新狼窝色av性久久久久久| 中文字幕中文字幕99| 亚洲调教一区| 99re视频在线观看| www.com.cn成人| 久久亚洲精品一区二区| 黄色免费在线播放| 欧美成人性福生活免费看| 中文字幕一区二区人妻视频| 亚洲综合久久久久| 国产在线免费av| 成人av免费网站| 国产精品久久久久久9999| 天堂在线亚洲视频| 亚洲 欧美 综合 另类 中字| 999国产精品999久久久久久| 欧美精品与人动性物交免费看| 一区中文字幕| 91中文在线视频| 成人激情视屏| 国产精品第七十二页| 日韩电影免费看| 久久91亚洲人成电影网站| av在线免费一区| 亚洲女人被黑人巨大进入al| 丰满熟女一区二区三区| 日韩亚洲欧美高清| 中文字幕人妻互换av久久| 欧美视频精品一区| 亚洲天堂日韩av| 亚洲成人精品影院| 国产一级视频在线| 一区二区视频在线| 校园春色 亚洲| 亚洲黄色尤物视频| 青青草免费av| 亚洲男人天堂一区| 日本午夜在线观看| 亚洲欧洲精品成人久久奇米网| 正在播放国产对白害羞| 国产天堂亚洲国产碰碰| 人妻aⅴ无码一区二区三区| 久久婷婷综合激情| 三上悠亚影音先锋| 国产午夜久久久久| 日韩人妻无码精品综合区| 久久午夜羞羞影院免费观看| 中文字幕一区二区人妻在线不卡| 91麻豆精品在线观看| 亚洲精品乱码久久久久久久| 99re这里只有精品6| 香港三级日本三级| 26uuu国产日韩综合| 亚洲av无码一区二区三区网址| 99re亚洲国产精品| av网站免费在线看| 中文字幕不卡一区| 免费国产羞羞网站美图| 亚洲精品亚洲人成人网| 精品在线免费观看视频| 性感美女极品91精品| 久久久久久久极品| 色琪琪一区二区三区亚洲区| 少妇一级淫片日本| 欧美精品一二三四| 精品国产九九九| 日韩av在线网页| 国产免费永久在线观看| 日韩最新av在线| 污污网站在线观看| 91国语精品自产拍在线观看性色| 天堂av中文在线观看| 国产精品久久久久免费a∨大胸| 日本在线一区二区| 国产精品手机在线| 欧洲vs亚洲vs国产| 在线精品亚洲一区二区| 欧美三级第一页| 黄色a级片免费| 精品一区二区三区香蕉蜜桃| 91传媒理伦片在线观看| 2024国产精品视频| 91动漫免费网站| 亚洲综合成人在线视频| 欧美一区二区三区网站| 欧美另类高清zo欧美| 亚洲精品无码专区| 亚洲香蕉伊综合在人在线视看| 日本美女在线中文版| 国内精品久久久久伊人av| 九色成人搞黄网站| 国产日韩欧美精品| 99久久久久| 黄色免费视频大全| 激情av综合网| 国产免费看av| 一区二区三区资源| 波多野结衣一本一道| 欧美zozozo| 成人高潮成人免费观看| 欧美激情奇米色| 成人全视频免费观看在线看| 激情久久av| 这里只有精品在线| 无码内射中文字幕岛国片| 国产sm精品调教视频网站| 国产探花视频在线播放| 午夜影院在线观看欧美| 国产老妇伦国产熟女老妇视频| 日韩成人免费视频| av在线免费网站| 国产精品久久久久久超碰| 国产精品tv| 97精品国产97久久久久久粉红| 亚洲免费网站| 深田咏美中文字幕| 亚洲欧洲www| 中文字幕人妻互换av久久| 亚洲免费av网址| 电影k8一区二区三区久久| 69堂成人精品视频免费| 999久久久精品国产| 国语对白做受xxxxx在线中国| 不卡电影一区二区三区| 免费毛片在线播放免费 | 久久99爱视频| 久久精品夜色噜噜亚洲aⅴ| 日韩免费黄色片| 亚洲成人免费在线视频| 性欧美高清come| 99九九视频| 你懂的国产精品| 北条麻妃亚洲一区| 亚洲伦理在线精品| 国产一区二区网站| 日韩性xxxx爱| 欧美日韩免费电影| 亚洲日本理论电影| 美女在线一区二区| av片在线免费看| 欧美日韩高清在线播放| 日本在线人成| 国产日韩欧美视频| 国产精品成人a在线观看| gogogo高清免费观看在线视频| 国产精品久久久久影院色老大| 亚洲 小说区 图片区| 色香阁99久久精品久久久| 岛国精品在线| 亚洲人体一区| 国产毛片一区二区| 天天看片中文字幕| 欧美成人精品3d动漫h| h片在线观看下载| 国产一级二级三级精品| 国产精品免费看| 亚洲自拍偷拍一区二区| 色88888久久久久久影院野外| 久久视频www| 国产精品视频久| 亚洲无中文字幕| 韩国av中国字幕| 福利视频导航一区| 国产在线观看免费网站| 国产日韩专区在线| 欧美另类女人| 亚洲国产综合视频| 在线视频欧美精品| 米奇777四色精品人人爽| 51国产成人精品午夜福中文下载 | 特级黄色片视频| 亚洲尤物视频在线| 三区在线观看| 国产精品久久久久久久久久免费 | 日本一区二区三区四区在线视频 | 这里只有精品66| 高清视频一区二区| 欧美一区二区三区不卡视频| 在线日韩第一页| 97一区二区国产好的精华液| 国产成人a亚洲精v品无码| 国产精品另类一区| 亚洲欧美国产高清va在线播放| 97在线观看免费| 久久人体视频| 激情综合丁香五月| 欧美日韩精品福利| 182在线视频观看| 色噜噜狠狠色综合网| 国产91精品一区二区| 午夜精品免费观看| 欧美精品福利在线| 精品日本12videosex| 日本人妻一区二区三区| 日本精品一区二区三区高清| 青春草视频在线观看| 欧美日韩在线播放一区二区| 国产一区二区毛片| 人人爽人人爽人人片av| 九九久久精品一区| 国产精品免费大片| 逼特逼视频在线观看| 欧美日韩一级视频|