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

教你如何實現(xiàn)一個完美的移動端瀑布流組件

開發(fā) 開發(fā)工具
我們設計與開發(fā)了一個兼容多場景的瀑布流組件。

背景

瀑布流是大家日常開發(fā)過程中經(jīng)常遇到的一個場景,我們公司內(nèi)部的組件庫中也提供了一些解決方案。但這些方案適用場景都很單一,且每個實現(xiàn)方案都或多或少存在一些問題,基于此,我們設計與開發(fā)了一個兼容多場景的瀑布流組件。

目前轉轉展示商品流時會采用三種布局方式:分別是卡片流、固定式瀑布流、交錯式瀑布流。

其中卡片流以一個下拉列表的形式呈現(xiàn)。這種布局可以讓用戶專注于單個列表項,有利于閱讀。主要應用于轉轉的二級列表頁入口,效果如下

卡片流

固定式瀑布流圖片區(qū)域大小高度保持不變。統(tǒng)一的高度會使整個界面看起來比較整齊,視覺上不亂。主要應用于一些頻道頁場景,效果如下

固定式瀑布流

交錯式瀑布流視覺表現(xiàn)為寬度相等、高度不定的元素組成參差不齊的多欄布局,轉轉的首頁以及商詳推薦頁面會選擇以這種方式來做承載

交錯式瀑布流

現(xiàn)有方案的問題

以上三種場景中,第一種和第二種場景圖片高度固定,實現(xiàn)相對簡單,直接使用無限加載 List 組件即可。經(jīng)常出問題的是第三種場景: 交錯式瀑布流 。這種場景下需要等圖片加載完后,獲取到圖片高度,再添加到瀑布流的最低列,否則會影響最低列的計算,從而出現(xiàn)長短不一的列。

轉轉公司內(nèi)部針對交錯式瀑布流的實現(xiàn)主要有以下幾種方案

優(yōu)點:采用 IntersectionObserve 實現(xiàn)瀑布流的懶加載,邏輯實現(xiàn)簡單

缺點:

  • 方案 1:采用左右兩欄布局,先左右均分第一頁瀑布流數(shù)據(jù)并進行渲染。等到第二頁數(shù)據(jù)渲染時,會先將第二頁第一個數(shù)據(jù)取出并渲染到最低列,并且進行 IntersectionObserve 監(jiān)聽,等到該元素出現(xiàn)在視窗內(nèi),再從數(shù)據(jù)源中取出第二個數(shù)據(jù)并添加到新的最低渲染列中,如此順環(huán)往復實現(xiàn)懶加載的瀑布流
  1. 分欄布局只支持兩欄,不支持參數(shù)配置多列;
  2. 第一頁數(shù)據(jù)不符合瀑布流的規(guī)范,有概率出現(xiàn)一列長,一列短的情況;
  3. IntersectionObserve 的兼容性問題;
  4. 沒有暴露數(shù)據(jù)加載完畢的事件,這樣在配合無限加載組件時,容易出現(xiàn)下拉請求兩次接口的問題
  • 方案 2:采用寬度百分比進行樣式布局,首屏渲染就開啟 IntersectionObserve 監(jiān)聽,元素出現(xiàn)在視窗后,設置一個 setTimeout 加載下一個瀑布流元素,同時在該 dom 上添加一個屬性標識,防止二次觸發(fā)。
  • 優(yōu)點: 支持參數(shù)配置多欄布局,首屏符合瀑布流的規(guī)范,同時暴露了瀑布流加載完畢后的事件,配合無限加載時不會出現(xiàn)兩次請求接口的問題
  • 缺點: IntersectionObserve 的兼容性問題依舊沒有解決;內(nèi)部 DOM 查詢、操作頻率較高;耦合無限加載 List 的邏輯,維護成本較高; setTimeout 無法保證圖片按照正確時序加載,會導致獲取最低列時不夠準確
  • 方案 3:使用絕對定位布局方案。實現(xiàn)原理是在每一個子組件 waterall-item 的內(nèi)部新建一個 image 對象,監(jiān)聽 onload 事件然后觸發(fā)父組件 waterfall 進行瀑布流的重排。
  • 優(yōu)點:內(nèi)部邏輯簡單,便于維護的同時也符合瀑布流規(guī)范,提供了瀑布流常用的幾個配置項,完全加載后也會觸發(fā)事件通知外部組件
  • 缺點:不支持圖片懶加載;重繪次數(shù)過多(1+2+...+N),對性能不太友好;觸發(fā)重繪的時機并不是最精確的時間節(jié)點(通過 new image 后的 onload 事件觸發(fā),而不是在當前 image 上綁定 onload 事件)

然后又去網(wǎng)上找了下開源方案,這里列舉 Github 上的 Star 數(shù)排行前 4 的解決方案

  • 缺點:需要在組件渲染前知道圖片的寬度和高度,而我們一般并不會在接口中返回這些數(shù)據(jù)
  • vue-waterfall [1] :Star 數(shù)最多的一個方案
  • vue-waterfall-easy [2] :無需提前獲取圖片的寬高信息,采用圖片預加載后再進行排版。
  • 缺點:耦合下拉、無限加載組件;包含 PC 端等邏輯,包體積較大,對于追求性能的頁面并不友好(作為開源方案,兼容更多的場景其實無可厚非,只是這些功能我們都已經(jīng)有單獨的組件實現(xiàn));一次加載所有圖片,不支持懶加載
  • vue-waterfall2 [3] :支持高度自適應,支持懶加載
  • 缺點:內(nèi)部多次創(chuàng)建 image 對象,同時還伴隨著大量的計算和滾動監(jiān)聽。
  • vue2-waterfall [4] :通過對 masonry-layout 和 imagesloaded 這兩個開源方案的封裝來實現(xiàn),邏輯簡單明了。
  • 缺點:不支持懶加載

用一張圖來簡單總結下

新瀑布流方案設計

目前并沒有一款簡單、易用的移動端瀑布流組件,所以打算整合已知方案,再重新實現(xiàn)一個新的瀑布流組件。新的瀑布流會包含以下一些優(yōu)點:

  • 簡單的 CSS 布局
  • 精簡邏輯層面的實現(xiàn)
  • 支持高度自適應
  • 支持懶加載

布局方案

了解到瀑布流 CSS 布局方案主要分為三種

  • 絕對定位:上述的方案 3 以及開源方案 vue-waterfall-easy 采用這種布局,比較適用于 PC 端瀑布流
  • 寬度百分比:上述方案 2 以及開源方案 vue-waterfall2 采用這種布局,但這種方案會存在一些精度問題
  • Flex 布局:一些大的電商網(wǎng)站像蘑菇街等采用這種布局

其中,F(xiàn)lex 布局兼容性、適配都沒什么問題,應該是移動端布局方案的最優(yōu)解。所以新的瀑布流會采用這種布局方案

瀑布流邏輯實現(xiàn)

對于瀑布流的邏輯實現(xiàn),也分為三種

  • image onload DOM
  • 直接在接口返回的圖片 url 中拼接圖片的寬高信息,提前布局,蘑菇街等采用這種方案
  • IntersectionObserver 監(jiān)聽圖片元素,出現(xiàn)在視圖當中開始從瀑布流數(shù)據(jù)隊列的列頭中取出一個數(shù)據(jù)并渲染到當前瀑布流的最低列,如此循環(huán)往復實現(xiàn)瀑布流的懶加載

三種方案中,第一種比較常規(guī),大部分開源方案就是這么實現(xiàn)的。但是內(nèi)部需要進行高度換算,同時也不支持圖片懶加載。

第二種方案應該是比較好的一個方案,圖片加載前就可以開始進行排版,方便簡單,也支持懶加載,用戶體驗也好。蘑菇街、天貓、京東等都是采用這種方案。但這種場景需要進行一些改造,比如在圖片入庫前將圖片信息拼接到 url 上,或者后端接口讀取圖片對象,然后將圖片信息返回給前端。要么改造成本較大,要么會增加服務器壓力,并不太適合我們業(yè)務。

而第三種方案可以在不需要其他改造的情況下支持懶加載,應該是目前最合適的一個方案。所以新的瀑布流組件會采用 IntersectionObserver 來實現(xiàn)瀑布流的排版

新瀑布流具體實現(xiàn)

IntersectionObserver 兼容性

首先面臨的一個問題就是 IntersectionObserver 的兼容性問題。 IntersectionObserver 在解決傳統(tǒng)的滾動監(jiān)聽帶來的性能問題的同時,兼容性一直并沒有得到一個主流的支持,可以看到 iOS 上的支持并不完美

官方提供了一個 polyfill [5] 來解決上述問題,但是這個 polyfill 體積較大,直接引入對一些追求極致性能的頁面不太友好,所以我們采用了動態(tài)引入 polyfill 的方法

// 不支持IntersectionObserver的場景下,動態(tài)引入polyfill
const ioPromise = checkIntersectionObserver()
? Promise.resolve()
: import('intersection-observer')

ioPromise.then(() => {
// do something
})

不支持的 IntersectionObserver 的環(huán)境才會去加載這個 polyfill,其中檢測方法摘抄自 Vue lazyload

const inBrowser = typeof window !== 'undefined' && window !== null

function checkIntersectionObserver() {
if (
inBrowser &&
'IntersectionObserver' in window &&
'IntersectionObserverEntry' in window &&
'intersectionRatio' in window.IntersectionObserverEntry.prototype
) {
// Minimal polyfill for Edge 15's lack of `isIntersecting`
// See: https://github.com/w3c/IntersectionObserver/issues/211
if (!('isIntersecting' in window.IntersectionObserverEntry.prototype)) {
Object.defineProperty(window.IntersectionObserverEntry.prototype, 'isIntersecting', {
get: function() {
return this.intersectionRatio > 0
}
})
}
return true
}
return false
}

瀑布流圖片加載時序

圖片加載是個異步過程, 如何保證瀑布流圖片的加載時序呢?

直接在 IntersectionObserver 的回調函數(shù)觸發(fā)后就開始進行下一張瀑布流圖片的加載極易出現(xiàn)長短不一列以及頁面抖動的情況,因為觸發(fā)回調時圖片可能只加載了一部分。上述方案 1 和方案 2 均存在這個問題

查看文檔,可以看到 IntersectionObserver 的回調函數(shù)中提供的 IntersectionObserverEntry 對象會提供以下屬性

  • time:可見性發(fā)生變化的時間,是一個高精度時間戳,單位為毫秒
  • target:被觀察的目標元素,是一個 DOM 節(jié)點對象
  • rootBounds:根元素的矩形區(qū)域的信息, getBoundingClientRect() 方法的返回值,如果沒有根元素(即直接相對于視口滾動),則返回 null
  • boundingClientRect:目標元素的矩形區(qū)域的信息
  • intersectionRect:目標元素與視口(或根元素)的交叉區(qū)域的信息
  • intersectionRatio:目標元素的可見比例,即 intersectionRect  boundingClientRect 的比例,完全可見時為 1,完全不可見時小于等于 0

我們可以在 target 上綁定 onload 事件,onload 之后再執(zhí)行下一次瀑布流數(shù)據(jù)渲染,這樣能保證下一次渲染時獲取最低列時的準確性

// 瀑布流布局:取出隊列中位于隊頭的數(shù)據(jù)并添加到瀑布流高度最小的那一列進行渲染,等圖片完全加載后重復該循環(huán)
observerObj = new IntersectionObserver(
(entries) => {
for (const entry of entries) {
const { target, isIntersecting } = entry
if (isIntersecting) {
if (target.complete) {
done()
} else {
target.onload = target.onerror = done
}
}
}
}
)

IntersectionObserver 二次觸發(fā)問題

我們知道,采用 IntersectionObserver 監(jiān)聽目標元素,當目標元素的可見性發(fā)生變化時,回調函數(shù)一般會觸發(fā)兩次。一次是目標元素剛剛進入視口(開始可見),另一次是完全離開視口(開始不可見)。為了避免第二次再次觸發(fā)監(jiān)聽邏輯,可以在第一次觸發(fā)的時候停止觀察

if (isIntersecting) {
const done = () => {
// 停止觀察,防止回拉時二次觸發(fā)監(jiān)聽邏輯
observerObj.unobserve(target)
}

if (target.complete) {
done()
} else {
target.onload = target.onerror = done
}
}

首屏渲染時的白屏問題

由于是串行加載圖片,圖片一張一張依次渲染出來,這種情況在網(wǎng)絡不好的時候白屏現(xiàn)象會很嚴重,如下圖

目前提供兩種解決方案

  • 方法一:首屏渲染時的圖片采取并行渲染,后續(xù)再采取串行渲染。假設接口返回的一頁瀑布流元素有 20 個,那么前 1-4 張圖片會用并行渲染,后 5-20 張圖片會用串行渲染。可以根據(jù)實際情況調整 firstPageCount,一般情況下首屏大概會渲染 4-6 張圖片。
waterfall() {
// 更新瀑布流高度最小列
this.updateMinCol()
// 取出數(shù)據(jù)源中最靠前的一個并添加到瀑布流高度最小的那一列
this.appendColData()
// 首屏采用并行渲染,非首屏采用串行渲染
if (++count < this.firstPageCount) {
this.$nextTick(() => this.waterfall())
} else {
this.$nextTick(() => this.startObserver())
}
}

  • 方法二:加動畫,從視覺感官上消除白屏帶來的影響,組件內(nèi)置了兩個動畫,通過 animation 傳參即可

懶加載時的白屏問題

我們采取懶加載的方案:當圖片出現(xiàn)在視圖后才去加載下一個瀑布流圖片,這樣對性能比較友好。但是這種情況下用戶在滾動瀏覽時,如果下一張圖片加載過慢,可能會有短暫的白屏時間,如何解決這個體驗問題呢

IntersectionObserver 有一個 rootMargin 屬性,我們可以利用它來擴大交叉區(qū)域,從而提前加載后面的數(shù)據(jù)。這樣既可以防止用戶滾動到底部的時候的白屏,也可以防止渲染過多影響性能。默認設置的是 400px,大約是提前渲染半屏的數(shù)據(jù)。

// 擴展intersectionRect交叉區(qū)域,可以提前加載部分數(shù)據(jù),優(yōu)化用戶瀏覽體驗
rootMargin: {
type: String,
default: '0px 0px 400px 0px'
}

如何配合無限加載組件

一般我們?yōu)榱司S護方便,會將無限加載和瀑布流這兩部分邏輯分開,所以當瀑布流數(shù)據(jù)渲染完后需要通知外部組件,否則很容易造成瀑布流還未渲染完又觸發(fā)了無限加載的邏輯,發(fā)送兩次接口請求的問題。

可以在進行瀑布流渲染的過程中增加一個判斷,如果隊列中沒有數(shù)據(jù)了,就通知外部無限加載組件進行下一次請求

const done = () => {
if (this.innerData.length) {
this.waterfall()
} else {
this.$emit('rendered')
}
}

總結

以上就是在做新瀑布流組件時遇到的一些問題以及對應的解決方案。當然,這套方案還有待優(yōu)化的空間,目前作為公司內(nèi)部一個組件區(qū)塊在使用中。

責任編輯:張燕妮 來源: 大轉轉FE
相關推薦

2021-03-05 10:13:45

Python 開發(fā)編程語言

2024-06-20 07:59:49

2020-07-24 20:49:10

代碼Request審查

2015-10-16 10:19:01

2020-10-26 09:53:44

Dropbox攻擊網(wǎng)絡安全

2020-10-23 10:36:08

Dropbox

2014-07-17 15:38:43

UI設計師移動端

2022-09-22 12:38:46

antd form組件代碼

2022-05-25 11:24:25

CalendarNutUI移動端

2019-05-15 09:00:00

決策樹機器學習人工智能

2024-09-03 17:04:15

前端算法布局

2014-11-26 09:56:42

企業(yè)郵箱移動辦公解決方案

2013-06-24 13:51:47

手機用戶體驗移動應用移動互聯(lián)網(wǎng)市場

2018-10-11 21:00:18

2023-05-10 09:04:10

promise場景業(yè)務

2009-09-11 09:36:53

李開復

2020-12-15 08:58:07

Vue編輯器vue-cli

2020-11-11 09:49:12

計算架構

2017-02-13 16:47:13

iOSDSL開發(fā)

2021-01-28 06:11:40

導航組件Sidenav Javascript
點贊
收藏

51CTO技術棧公眾號

久久久不卡网国产精品二区| 欧美日韩亚洲一区| 一本大道av一区二区在线播放| 好吊色欧美一区二区三区四区| youjizz在线视频| 日韩aaaa| 亚洲国产精品国自产拍av秋霞| 国产极品美女高潮无套久久久| 91最新在线| 成人性生交大片免费看视频在线 | 成人激情av| 亚洲 欧美 中文字幕| 欧美激情自拍| 国产亚洲美女精品久久久| www.久久com| 欧美黄色三级| 亚洲国产精品一区二区www| 三区精品视频观看| 色欲久久久天天天综合网| 琪琪一区二区三区| 欧美亚洲另类激情另类| 777777国产7777777| 奇米狠狠一区二区三区| 日韩美女视频一区二区在线观看| 国产男女激情视频| 2021中文字幕在线| 亚洲女人小视频在线观看| 欧美日韩电影一区二区| 亚洲精品久久久久久久久久久久久久| 日韩福利电影在线观看| 91国产高清在线| 国产大学生自拍| 国产影视一区| 国产视频精品免费播放| 亚洲婷婷在线观看| 精品欧美视频| 91精品国产高清一区二区三区| 欧美一级黄色影院| 亚洲优女在线| 婷婷亚洲久悠悠色悠在线播放| 狠狠干视频网站| 秋霞成人影院| 中文字幕一区二区不卡| 日韩欧美精品一区二区三区经典| 香蕉视频网站在线| 99久久免费视频.com| 国产福利一区二区三区在线观看| 国产原创中文av| 激情偷乱视频一区二区三区| 国产精品视频一区二区三区四| 日韩一区二区视频在线| 国产精品免费看| 97视频在线免费观看| 国产午夜福利一区二区| 亚洲黄色免费| 欧美性资源免费| 特黄视频免费看| 欧美亚洲网站| 国产精品成久久久久三级| 日韩精品一区二区亚洲av| 久久蜜桃精品| 国产精品久久久久久超碰| 国模私拍一区二区| 免费高清在线一区| 91精品国产综合久久久久久蜜臀 | 尤物tv国产一区| 亚洲精品国产精品国自| 国产精品久久久久久久| 麻豆国产va免费精品高清在线| 99热这里只有精品4| 欧美在线网站| 97av在线影院| 最近中文字幕免费在线观看| 精东粉嫩av免费一区二区三区| 91成人免费在线观看| 亚洲欧美另类一区| 久久久精品2019中文字幕之3| 日韩偷拍一区二区| 国产福利视频在线| 亚洲国产视频一区二区| 国产精品va无码一区二区| 深夜成人影院| 在线播放欧美女士性生活| 久久人妻少妇嫩草av蜜桃| 欧美深夜视频| 色噜噜久久综合伊人一本| 欧美片一区二区| 一本色道久久精品| 国产一区香蕉久久| 国产 日韩 欧美 综合| 久久久久久久久99精品| eeuss中文| 在线最新版中文在线| 欧美日韩国产欧美日美国产精品| 麻豆tv在线观看| 精品欧美激情在线观看| 中文字幕av一区二区三区谷原希美| 国产精品白丝喷水在线观看| 国产视频一区在线观看一区免费| 国产精品免费一区| 秋霞网一区二区| 中文字幕巨乱亚洲| 国产中文字幕二区| 亚洲欧美在线综合| 亚洲美女av黄| 久久久久性色av无码一区二区| 天堂av在线一区| av日韩免费电影| aaa日本高清在线播放免费观看| 一区二区三区免费在线观看| 日本精品久久久久中文字幕| 白嫩白嫩国产精品| 日韩中文第一页| 国产精品午夜影院| 国产乱码精品1区2区3区| 清纯唯美一区二区三区| 精品日韩av| 欧美日韩国产123区| 特级西西人体4444xxxx| 欧美精品黄色| 国产日韩欧美视频| 国产在线你懂得| 偷窥少妇高潮呻吟av久久免费| 91日韩精品视频| 红桃成人av在线播放| 91禁外国网站| 丰满人妻一区二区三区免费视频| 亚洲视频在线一区观看| 一区二区三区国产免费| 天堂俺去俺来也www久久婷婷| 九九精品视频在线| 99久久精品无免国产免费| 国产精品日产欧美久久久久| 久久综合久久色| 四虎5151久久欧美毛片| 5566日本婷婷色中文字幕97| 欧美一级做性受免费大片免费| 亚洲嫩草精品久久| 色婷婷激情视频| 午夜片欧美伦| 成人在线一区二区| 麻豆tv免费在线观看| 欧美日高清视频| 五月婷婷综合激情网| 美腿丝袜亚洲综合| 亚洲蜜桃av| 久久青草免费| 搡老女人一区二区三区视频tv| 久久国产香蕉视频| 亚洲国产成人在线| 依人在线免费视频| 97精品视频在线看| 91亚洲国产成人久久精品网站| 黄视频网站在线| 欧美一级一区二区| 欧美黄色免费观看| 成人动漫一区二区在线| 777av视频| 日韩成人午夜| 国产成人精品在线视频| www免费网站在线观看| 欧美性猛片aaaaaaa做受| 91麻豆精品国产91久久综合| 蜜桃视频在线一区| 在线无限看免费粉色视频| 国产日韩一区二区三免费高清| 麻豆成人在线看| 天天操天天插天天射| 欧美性xxxxx极品| 国产视频不卡在线| 国产精品一二二区| 国产精品网站免费| 国内成人自拍| 亚洲综合小说区| 黄频免费在线观看| 最新国产成人av网站网址麻豆| 国产一区二区三区视频免费观看| 一区二区免费在线| 极品粉嫩小仙女高潮喷水久久| 可以看av的网站久久看| 影音欧美亚洲| 美女av一区| 国产欧美精品久久久| 欧美卡一卡二| 亚洲天堂影视av| 国产女主播福利| 欧美性色19p| 日本福利片在线观看| 99久久婷婷国产综合精品 | 成人中文字幕电影| 少妇人妻互换不带套| 中文字幕一区二区av| 九九九九精品| 国产精品久一| 国产成人福利网站| 欧洲一区二区三区| 这里只有视频精品| 欧美一级淫片aaaaaa| 欧美日韩国产首页在线观看| www.国产成人| 综合亚洲深深色噜噜狠狠网站| 玖草视频在线观看| 国产精品 日产精品 欧美精品| 黑森林福利视频导航| 欧美精品网站| 亚洲一区二区三区精品视频| 欧美日韩夜夜| 超碰97人人在线| 日韩电影精品| 国产成人精品电影| xxx性欧美| 萌白酱国产一区二区| 国产在线超碰| 日韩av中文在线| 亚洲AV无码国产精品午夜字幕| 欧洲国内综合视频| youjizz在线视频| 亚洲成人av电影| 欧美成人三级视频| 亚洲丝袜自拍清纯另类| 人妻精品久久久久中文| 97精品久久久久中文字幕| 九色91porny| 狠狠色丁香久久婷婷综合丁香| 日日碰狠狠躁久久躁婷婷| 亚洲高清成人| 欧美视频在线第一页| 国产精品99视频| 亚洲精品一区二区三| 亚洲另类av| 激情小说综合区| 加勒比色老久久爱综合网| 亚洲字幕在线观看| 成人在线精品| 成人自拍性视频| 精品国产18久久久久久二百| 国产欧美va欧美va香蕉在线| 日韩另类视频| 国产精品99导航| 欧美大片1688网站| 国产精品久久久久久亚洲影视| 最新日韩三级| 国产精品成人一区二区| 成人性生交大片免费网站| …久久精品99久久香蕉国产| 激情国产在线| 欧美亚洲成人精品| 精品国产免费人成网站| 欧亚精品中文字幕| 日韩国产激情| 国产精品视频资源| 日韩av懂色| 444亚洲人体| 国产成人一二| 欧美精品七区| 欧美精品色图| 偷拍盗摄高潮叫床对白清晰| 围产精品久久久久久久| 日韩精品免费一区| 亚洲久久一区| 日韩中文字幕二区| 美日韩一区二区| 奇米777在线视频| 成人精品免费看| 国产熟妇搡bbbb搡bbbb| 国产农村妇女精品| 永久免费看mv网站入口| 一区二区三区中文字幕| 国产手机在线视频| 欧美在线观看视频在线| 国产精品毛片久久久久久久av| 日韩视频123| 日本又骚又刺激的视频在线观看| 亚洲视频在线免费观看| 免费av网站在线观看| 久久免费精品视频| se01亚洲视频| 99re在线视频观看| 一区二区三区四区在线看 | 亚洲美女网站| 久久九九国产视频| 国产一区二区三区免费播放| 精品影片一区二区入口| 欧美国产激情二区三区| avove在线播放| 欧美日韩一区二区在线播放| 亚洲视频在线观看免费视频| 日韩免费高清av| 川上优的av在线一区二区| 欧美精品在线免费| 成人软件在线观看| 国产成人精品日本亚洲11| 精品久久久久久久| 丁香婷婷综合激情| 奇米精品一区二区三区在线观看一 | 日韩欧美一二三区| 黄色电影免费在线看| 欧美老妇交乱视频| 777午夜精品电影免费看| 超碰97在线播放| 99久久.com| 成熟老妇女视频| 成人午夜av影视| 少妇高潮在线观看| 色综合中文字幕| 黄色一级大片在线免费看国产一| 在线精品国产成人综合| av电影在线地址| 亚洲综合av影视| 久久亚洲国产| 久草综合在线观看| 26uuu色噜噜精品一区二区| 国产这里有精品| 欧美日韩免费一区二区三区 | 91精品短视频| 国产系列第一页| 蜜芽一区二区三区| 少妇久久久久久久久久| 午夜日韩在线观看| 不卡的日韩av| 欧美超级乱淫片喷水| 97成人超碰| 日韩欧美精品一区二区| 蜜桃视频一区| 波多野结衣办公室33分钟| 午夜伦理一区二区| 刘亦菲久久免费一区二区| 成人97在线观看视频| 成人黄色91| 欧美少妇一级片| 精品一区在线看| 国产成人免费在线观看视频| 91国产精品成人| 国产三级电影在线| 国产成人精品网站| 国产精品一区二区av日韩在线| 免费看国产一级片| 99精品久久久久久| av大片在线免费观看| 亚洲精品国产综合区久久久久久久| a毛片不卡免费看片| 国产伦精品一区二区三区| 极品裸体白嫩激情啪啪国产精品| 日本美女久久久| 亚洲最快最全在线视频| 丰满少妇一级片| 97视频免费在线看| 日韩精品福利一区二区三区| 国产精品网站免费| 久久久国产一区二区三区四区小说| 亚洲视频 欧美视频| 亚洲欧美综合区自拍另类| 亚洲精品.com| 亚洲午夜高清视频| 国产曰批免费观看久久久| 欧美色图亚洲天堂| 精品播放一区二区| 僵尸再翻生在线观看| 日本高清视频一区二区三区 | 国产在线久久久| 综合天堂久久久久久久| 成人欧美精品一区二区| 亚洲成a人v欧美综合天堂 | av毛片精品| 久久成人免费观看| 日本一区二区三区免费乱视频| 91午夜交换视频| 久久久亚洲网站| 国产精品手机在线播放| 一级黄色片国产| 午夜伦欧美伦电影理论片| 成人激情电影在线看| 成人免费视频97| 国产日韩欧美高清免费| 一级肉体全黄裸片| 欧美一区二区免费| 在线毛片观看| 水蜜桃在线免费观看| av毛片久久久久**hd| 在线播放成人av| 欧美国产日韩xxxxx| 丝袜久久网站| 国产又粗又猛大又黄又爽| 欧美日韩国内自拍| 天堂地址在线www| 国产精品日韩一区二区三区| 葵司免费一区二区三区四区五区| 日韩精品一区二区亚洲av性色 | 岛国在线大片| 成人黄色在线免费观看| 日本 国产 欧美色综合| 久久久精品国产sm调教网站| 亚洲亚裔videos黑人hd| 日本一区二区三区电影免费观看| 国产网站免费在线观看| 亚洲色图制服诱惑| 国产资源在线播放| 成人做爰66片免费看网站| 毛片一区二区三区| 国产精品久久久免费视频|