久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

基于vue實現探探滑動組件功能

瀏覽:160日期:2023-01-17 17:22:29

前言

嗨,說起探探想必各位程序汪都不陌生(畢竟妹子很多),能在上面絲滑的翻牌子,探探的的堆疊滑動組件起到了關鍵的作用,下面就來看看如何用vue寫一個探探的堆疊組件 ?

一. 功能分析

簡單使用下探探會發(fā)現,堆疊滑動的功能很簡單,用一張圖概括就是:

基于vue實現探探滑動組件功能

簡單歸納下里面包含的基本功能點:

圖片的堆疊 圖片第一張的滑動 條件成功后的滑出,條件失敗后的回彈 滑出后下一張圖片堆疊到頂部

體驗優(yōu)化

根據觸摸點的不同,滑動時首圖有不同角度偏移

偏移面積判定是否成功滑出

二. 具體實現

有了歸納好的功能點,我們實現組件的思路會更清晰

1. 堆疊效果

堆疊圖片效果在網上有大量的實例,實現的方法大同小異,主要通過在父層設定perspective及perspective-origin,來實現子層的透視,子層設定好translate3d Z軸數值即可模擬出堆疊效果,具體代碼如下

// 圖片堆疊dom <!--opacity: 0 隱藏我們不想看到的stack-item層級--> <!--z-index: -1 調整stack-item層級'--><ul class='stack'> <li style='transform: translate3d(0px, 0px, 0px);opacity: 1;z-index: 10;'><img src='http://www.gepszalag.com/bcjs/1.png' alt='01'></li> <li style='transform: translate3d(0px, 0px, -60px);opacity: 1;z-index: 1'><img src='http://www.gepszalag.com/bcjs/2.png' alt='02'></li> <li style='transform: translate3d(0px, 0px, -120px);opacity: 1;z-index: 1'><img src='http://www.gepszalag.com/bcjs/3.png' alt='03'></li> <li style='transform: translate3d(0px, 0px, -180px);opacity: 0;z-index: -1'><img src='http://www.gepszalag.com/bcjs/4.png' alt='04'></li> <li style='transform: translate3d(0px, 0px, -180px);opacity: 0;z-index: -1'><img src='http://www.gepszalag.com/bcjs/5.png' alt='05'></li></ul><style>.stack { width: 100%; height: 100%; position: relative; perspective: 1000px; //子元素視距 perspective-origin: 50% 150%; //子元素透視位置 -webkit-perspective: 1000px; -webkit-perspective-origin: 50% 150%; margin: 0; padding: 0; } .stack-item{ background: #fff; height: 100%; width: 100%; border-radius: 4px; text-align: center; overflow: hidden; } .stack-item img { width: 100%; display: block; pointer-events: none; }</style>

上面只是一組靜態(tài)代碼,我們希望得到的是vue組件,所以需要先建立一個組件模板stack.vue,在模板中我們可以使用v-for,遍歷出stack節(jié)點,使用:style 來修改各個item的style,代碼如下

<template> <ul class='stack'> <li v-for='(item, index) in pages' :style='[transform(index)]'> <img :src='http://www.gepszalag.com/bcjs/item.src'> </li> </ul></template><script>export default { props: { // pages數據包含基礎的圖片數據 pages: { type: Array, default: [] } }, data () { return { // basicdata數據包含組件基本數據 basicdata: { currentPage: 0 // 默認首圖的序列 }, // temporaryData數據包含組件臨時數據 temporaryData: { opacity: 1, // 記錄opacity zIndex: 10, // 記錄zIndex visible: 3 // 記錄默認顯示堆疊數visible } } }, methods: { // 遍歷樣式 transform (index) { if (index >= this.basicdata.currentPage) { let style = {} let visible = this.temporaryData.visible let perIndex = index - this.basicdata.currentPage // visible可見數量前滑塊的樣式 if (index <= this.basicdata.currentPage + visible - 1) { style[’opacity’] = ’1’ style[’transform’] = ’translate3D(0,0,’ + -1 * perIndex * 60 + ’px’ + ’)’ style[’zIndex’] = visible - index + this.basicdata.currentPage style[’transitionTimingFunction’] = ’ease’ style[’transitionDuration’] = 300 + ’ms’ } else { style[’zIndex’] = ’-1’ style[’transform’] = ’translate3D(0,0,’ + -1 * visible * 60 + ’px’ + ’)’ } return style } } }}</script>

關鍵點

style可以綁定對象的同時,也可以綁定數組和函數,這在遍歷的時候很有用

最基本的dom結構已經構建完畢,下一步是讓首張圖片“動”起來

2. 圖片滑動

圖片滑動效果,在很多場景中都有出現,其原理無非是監(jiān)聽touchs事件,得到位移,再通過translate3D改變目標位移,因此我們要實現的步驟如下

對stack進行touchs事件的綁定 監(jiān)聽并儲存手勢位置變化的數值 改變首圖css屬性中translate3D的x,y值

具體實現

在vue框架中,不建議直接操作節(jié)點,而是通過指令v-on對元素進行綁定,因此我們將綁定都寫在v-for遍歷里,通過index進行判斷其是否是首圖,再使用:style修改首頁的樣式,具體代碼如下:

<template> <ul class='stack'> <li v-for='(item, index) in pages' : @touchstart.stop.capture='touchstart' @touchmove.stop.capture='touchmove' @touchend.stop.capture='touchend' @mousedown.stop.capture='touchstart' @mouseup.stop.capture='touchend' @mousemove.stop.capture='touchmove'> <img :src='http://www.gepszalag.com/bcjs/item.src'> </li> </ul></template><script>export default { props: { // pages數據包含基礎的圖片數據 pages: { type: Array, default: [] } }, data () { return { // basicdata數據包含組件基本數據 basicdata: { start: {}, // 記錄起始位置 end: {}, // 記錄終點位置 currentPage: 0 // 默認首圖的序列 }, // temporaryData數據包含組件臨時數據 temporaryData: { poswidth: ’’, // 記錄位移 posheight: ’’, // 記錄位移 tracking: false // 是否在滑動,防止多次操作,影響體驗 } } }, methods: { touchstart (e) { if (this.temporaryData.tracking) { return } // 是否為touch if (e.type === ’touchstart’) { if (e.touches.length > 1) { this.temporaryData.tracking = false return } else { // 記錄起始位置 this.basicdata.start.t = new Date().getTime() this.basicdata.start.x = e.targetTouches[0].clientX this.basicdata.start.y = e.targetTouches[0].clientY this.basicdata.end.x = e.targetTouches[0].clientX this.basicdata.end.y = e.targetTouches[0].clientY } // pc操作 } else { this.basicdata.start.t = new Date().getTime() this.basicdata.start.x = e.clientX this.basicdata.start.y = e.clientY this.basicdata.end.x = e.clientX this.basicdata.end.y = e.clientY } this.temporaryData.tracking = true }, touchmove (e) { // 記錄滑動位置 if (this.temporaryData.tracking && !this.temporaryData.animation) { if (e.type === ’touchmove’) { this.basicdata.end.x = e.targetTouches[0].clientX this.basicdata.end.y = e.targetTouches[0].clientY } else { this.basicdata.end.x = e.clientX this.basicdata.end.y = e.clientY } // 計算滑動值 this.temporaryData.poswidth = this.basicdata.end.x - this.basicdata.start.x this.temporaryData.posheight = this.basicdata.end.y - this.basicdata.start.y } }, touchend (e) { this.temporaryData.tracking = false // 滑動結束,觸發(fā)判斷 }, // 非首頁樣式切換 transform (index) { if (index > this.basicdata.currentPage) { let style = {} let visible = 3 let perIndex = index - this.basicdata.currentPage // visible可見數量前滑塊的樣式 if (index <= this.basicdata.currentPage + visible - 1) { style[’opacity’] = ’1’ style[’transform’] = ’translate3D(0,0,’ + -1 * perIndex * 60 + ’px’ + ’)’ style[’zIndex’] = visible - index + this.basicdata.currentPage style[’transitionTimingFunction’] = ’ease’ style[’transitionDuration’] = 300 + ’ms’ } else { style[’zIndex’] = ’-1’ style[’transform’] = ’translate3D(0,0,’ + -1 * visible * 60 + ’px’ + ’)’ } return style } }, // 首頁樣式切換 transformIndex (index) { // 處理3D效果 if (index === this.basicdata.currentPage) { let style = {} style[’transform’] = ’translate3D(’ + this.temporaryData.poswidth + ’px’ + ’,’ + this.temporaryData.posheight + ’px’ + ’,0px)’ style[’opacity’] = 1 style[’zIndex’] = 10 return style } } }}</script>

3. 條件成功后的滑出,條件失敗后的回彈

條件的觸發(fā)判斷是在touchend/mouseup后進行,在這里我們先用簡單的條件進行判定,同時給予首圖彈出及回彈的效果,代碼如下

<template> <ul class='stack'> <li v-for='(item, index) in pages' : @touchmove.stop.capture='touchmove' @touchstart.stop.capture='touchstart' @touchend.stop.capture='touchend' @mousedown.stop.capture='touchstart' @mouseup.stop.capture='touchend' @mousemove.stop.capture='touchmove'> <img :src='http://www.gepszalag.com/bcjs/item.src'> </li> </ul></template><script>export default { props: { // pages數據包含基礎的圖片數據 pages: { type: Array, default: [] } }, data () { return { // basicdata數據包含組件基本數據 basicdata: { start: {}, // 記錄起始位置 end: {}, // 記錄終點位置 currentPage: 0 // 默認首圖的序列 }, // temporaryData數據包含組件臨時數據 temporaryData: { poswidth: ’’, // 記錄位移 posheight: ’’, // 記錄位移 tracking: false, // 是否在滑動,防止多次操作,影響體驗 animation: false, // 首圖是否啟用動畫效果,默認為否 opacity: 1 // 記錄首圖透明度 } } }, methods: { touchstart (e) { if (this.temporaryData.tracking) { return } // 是否為touch if (e.type === ’touchstart’) { if (e.touches.length > 1) { this.temporaryData.tracking = false return } else { // 記錄起始位置 this.basicdata.start.t = new Date().getTime() this.basicdata.start.x = e.targetTouches[0].clientX this.basicdata.start.y = e.targetTouches[0].clientY this.basicdata.end.x = e.targetTouches[0].clientX this.basicdata.end.y = e.targetTouches[0].clientY } // pc操作 } else { this.basicdata.start.t = new Date().getTime() this.basicdata.start.x = e.clientX this.basicdata.start.y = e.clientY this.basicdata.end.x = e.clientX this.basicdata.end.y = e.clientY } this.temporaryData.tracking = true this.temporaryData.animation = false }, touchmove (e) { // 記錄滑動位置 if (this.temporaryData.tracking && !this.temporaryData.animation) { if (e.type === ’touchmove’) { this.basicdata.end.x = e.targetTouches[0].clientX this.basicdata.end.y = e.targetTouches[0].clientY } else { this.basicdata.end.x = e.clientX this.basicdata.end.y = e.clientY } // 計算滑動值 this.temporaryData.poswidth = this.basicdata.end.x - this.basicdata.start.x this.temporaryData.posheight = this.basicdata.end.y - this.basicdata.start.y } }, touchend (e) { this.temporaryData.tracking = false this.temporaryData.animation = true // 滑動結束,觸發(fā)判斷 // 簡單判斷滑動寬度超出100像素時觸發(fā)滑出 if (Math.abs(this.temporaryData.poswidth) >= 100) { // 最終位移簡單設定為x軸200像素的偏移 let ratio = Math.abs(this.temporaryData.posheight / this.temporaryData.poswidth) this.temporaryData.poswidth = this.temporaryData.poswidth >= 0 ? this.temporaryData.poswidth + 200 : this.temporaryData.poswidth - 200 this.temporaryData.posheight = this.temporaryData.posheight >= 0 ? Math.abs(this.temporaryData.poswidth * ratio) : -Math.abs(this.temporaryData.poswidth * ratio) this.temporaryData.opacity = 0 // 不滿足條件則滑入 } else { this.temporaryData.poswidth = 0 this.temporaryData.posheight = 0 } }, // 非首頁樣式切換 transform (index) { if (index > this.basicdata.currentPage) { let style = {} let visible = 3 let perIndex = index - this.basicdata.currentPage // visible可見數量前滑塊的樣式 if (index <= this.basicdata.currentPage + visible - 1) { style[’opacity’] = ’1’ style[’transform’] = ’translate3D(0,0,’ + -1 * perIndex * 60 + ’px’ + ’)’ style[’zIndex’] = visible - index + this.basicdata.currentPage style[’transitionTimingFunction’] = ’ease’ style[’transitionDuration’] = 300 + ’ms’ } else { style[’zIndex’] = ’-1’ style[’transform’] = ’translate3D(0,0,’ + -1 * visible * 60 + ’px’ + ’)’ } return style } }, // 首頁樣式切換 transformIndex (index) { // 處理3D效果 if (index === this.basicdata.currentPage) { let style = {} style[’transform’] = ’translate3D(’ + this.temporaryData.poswidth + ’px’ + ’,’ + this.temporaryData.posheight + ’px’ + ’,0px)’ style[’opacity’] = this.temporaryData.opacity style[’zIndex’] = 10 if (this.temporaryData.animation) { style[’transitionTimingFunction’] = ’ease’ style[’transitionDuration’] = 300 + ’ms’ } return style } } }}</script>

4. 滑出后下一張圖片堆疊到頂部

重新堆疊是組件最后一個功能,同時也是最重要和復雜的功能。在我們的代碼里,stack-item的排序依賴綁定:style的transformIndex和transform函數,函數里判定的條件是currentPage,那是不是改變currentPage,讓其+1,即可完成重新堆疊呢?

答案沒有那么簡單,因為我們滑出是動畫效果,會進行300ms的時間,而currentPage變化引起的重排,會立即變化,打斷動畫的進行。因此我們需要先修改transform函數的排序條件,后改變currentPage。

具體實現

修改transform函數排序條件 讓currentPage+1 添加onTransitionEnd事件,在滑出結束后,重新放置stack列表中

代碼如下:

<template> <ul class='stack'> <li v-for='(item, index) in pages' : @touchmove.stop.capture='touchmove' @touchstart.stop.capture='touchstart' @touchend.stop.capture='touchend' @mousedown.stop.capture='touchstart' @mouseup.stop.capture='touchend' @mousemove.stop.capture='touchmove' @webkit-transition-end='onTransitionEnd' @transitionend='onTransitionEnd' > <img :src='http://www.gepszalag.com/bcjs/item.src'> </li> </ul></template><script>export default { props: { // pages數據包含基礎的圖片數據 pages: { type: Array, default: [] } }, data () { return { // basicdata數據包含組件基本數據 basicdata: { start: {}, // 記錄起始位置 end: {}, // 記錄終點位置 currentPage: 0 // 默認首圖的序列 }, // temporaryData數據包含組件臨時數據 temporaryData: { poswidth: ’’, // 記錄位移 posheight: ’’, // 記錄位移 lastPosWidth: ’’, // 記錄上次最終位移 lastPosHeight: ’’, // 記錄上次最終位移 tracking: false, // 是否在滑動,防止多次操作,影響體驗 animation: false, // 首圖是否啟用動畫效果,默認為否 opacity: 1, // 記錄首圖透明度 swipe: false // onTransition判定條件 } } }, methods: { touchstart (e) { if (this.temporaryData.tracking) { return } // 是否為touch if (e.type === ’touchstart’) { if (e.touches.length > 1) { this.temporaryData.tracking = false return } else { // 記錄起始位置 this.basicdata.start.t = new Date().getTime() this.basicdata.start.x = e.targetTouches[0].clientX this.basicdata.start.y = e.targetTouches[0].clientY this.basicdata.end.x = e.targetTouches[0].clientX this.basicdata.end.y = e.targetTouches[0].clientY } // pc操作 } else { this.basicdata.start.t = new Date().getTime() this.basicdata.start.x = e.clientX this.basicdata.start.y = e.clientY this.basicdata.end.x = e.clientX this.basicdata.end.y = e.clientY } this.temporaryData.tracking = true this.temporaryData.animation = false }, touchmove (e) { // 記錄滑動位置 if (this.temporaryData.tracking && !this.temporaryData.animation) { if (e.type === ’touchmove’) { this.basicdata.end.x = e.targetTouches[0].clientX this.basicdata.end.y = e.targetTouches[0].clientY } else { this.basicdata.end.x = e.clientX this.basicdata.end.y = e.clientY } // 計算滑動值 this.temporaryData.poswidth = this.basicdata.end.x - this.basicdata.start.x this.temporaryData.posheight = this.basicdata.end.y - this.basicdata.start.y } }, touchend (e) { this.temporaryData.tracking = false this.temporaryData.animation = true // 滑動結束,觸發(fā)判斷 // 簡單判斷滑動寬度超出100像素時觸發(fā)滑出 if (Math.abs(this.temporaryData.poswidth) >= 100) { // 最終位移簡單設定為x軸200像素的偏移 let ratio = Math.abs(this.temporaryData.posheight / this.temporaryData.poswidth) this.temporaryData.poswidth = this.temporaryData.poswidth >= 0 ? this.temporaryData.poswidth + 200 : this.temporaryData.poswidth - 200 this.temporaryData.posheight = this.temporaryData.posheight >= 0 ? Math.abs(this.temporaryData.poswidth * ratio) : -Math.abs(this.temporaryData.poswidth * ratio) this.temporaryData.opacity = 0 this.temporaryData.swipe = true // 記錄最終滑動距離 this.temporaryData.lastPosWidth = this.temporaryData.poswidth this.temporaryData.lastPosHeight = this.temporaryData.posheight // currentPage+1 引發(fā)排序變化 this.basicdata.currentPage += 1 // currentPage切換,整體dom進行變化,把第一層滑動置零 this.$nextTick(() => { this.temporaryData.poswidth = 0 this.temporaryData.posheight = 0 this.temporaryData.opacity = 1 }) // 不滿足條件則滑入 } else { this.temporaryData.poswidth = 0 this.temporaryData.posheight = 0 this.temporaryData.swipe = false } }, onTransitionEnd (index) { // dom發(fā)生變化后,正在執(zhí)行的動畫滑動序列已經變?yōu)樯弦粚? if (this.temporaryData.swipe && index === this.basicdata.currentPage - 1) { this.temporaryData.animation = true this.temporaryData.lastPosWidth = 0 this.temporaryData.lastPosHeight = 0 this.temporaryData.swipe = false } }, // 非首頁樣式切換 transform (index) { if (index > this.basicdata.currentPage) { let style = {} let visible = 3 let perIndex = index - this.basicdata.currentPage // visible可見數量前滑塊的樣式 if (index <= this.basicdata.currentPage + visible - 1) { style[’opacity’] = ’1’ style[’transform’] = ’translate3D(0,0,’ + -1 * perIndex * 60 + ’px’ + ’)’ style[’zIndex’] = visible - index + this.basicdata.currentPage style[’transitionTimingFunction’] = ’ease’ style[’transitionDuration’] = 300 + ’ms’ } else { style[’zIndex’] = ’-1’ style[’transform’] = ’translate3D(0,0,’ + -1 * visible * 60 + ’px’ + ’)’ } return style // 已滑動模塊釋放后 } else if (index === this.basicdata.currentPage - 1) { let style = {} // 繼續(xù)執(zhí)行動畫 style[’transform’] = ’translate3D(’ + this.temporaryData.lastPosWidth + ’px’ + ’,’ + this.temporaryData.lastPosHeight + ’px’ + ’,0px)’ style[’opacity’] = ’0’ style[’zIndex’] = ’-1’ style[’transitionTimingFunction’] = ’ease’ style[’transitionDuration’] = 300 + ’ms’ return style } }, // 首頁樣式切換 transformIndex (index) { // 處理3D效果 if (index === this.basicdata.currentPage) { let style = {} style[’transform’] = ’translate3D(’ + this.temporaryData.poswidth + ’px’ + ’,’ + this.temporaryData.posheight + ’px’ + ’,0px)’ style[’opacity’] = this.temporaryData.opacity style[’zIndex’] = 10 if (this.temporaryData.animation) { style[’transitionTimingFunction’] = ’ease’ style[’transitionDuration’] = 300 + ’ms’ } return style } } }}</script>

ok~ 完成了上面的四步,堆疊組件的基本功能就已經實現,快來看看效果吧

基于vue實現探探滑動組件功能

堆疊滑動效果已經出來了,但是探探在體驗上,還增加了觸碰角度偏移,以及判定滑出面積比例

角度偏移的原理,是在用戶每次進行touch時,記錄用戶觸碰位置,計算出最大的偏移角度,在滑動出現位移時,線性增加角度以至最大的偏移角度。

使用在stack中具體要做的是:

touchmove中計算出所需角度和方向

touchend及onTransitionEnd中將角度至零

判定滑出面積比例,主要通過偏移量計算出偏移面積,從而得到面積比例,完成判斷

完整的代碼和demo可以在github上查看源碼,這里就不貼出來了

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 亚洲高清在线 | 91精品久久久久久久久久 | 精品一区二区三区免费 | 亚洲伦理| 91短视频版在线观看www免费 | 精品久久久久久久久久久久 | 福利精品在线观看 | 操片| 国产丝袜一区二区三区免费视频 | 亚洲国产视频精品 | 日韩在线欧美 | 色噜噜一区二区 | 亚洲综合精品久久 | 国产人成精品一区二区三 | 欧美午夜一区 | 日韩色综合 | 国产视频9999| 综合久久99| 国产电影一区二区在线观看 | 看全黄大色黄大片老人做 | 久久久91精品国产一区二区三区 | 福利精品视频 | 午夜欧美一区二区三区在线播放 | 一区二区中文字幕在线观看 | 国产传媒在线观看 | 国产精品免费一区二区三区四区 | 日韩中文视频 | 欧美日韩在线播放 | 国产精品久久一区 | 羞羞视频在线免费 | 亚洲精品日韩激情欧美 | 国产精品亚洲一区二区三区 | 一级黄色片欧美 | 91在线入口 | 亚洲欧美中文日韩在线v日本 | 国产精品极品美女在线观看免费 | 亚洲一区二区在线看 | 成人影音 | 亚洲精品中文视频 | 日本不卡一区 | av一区二区三区四区 | 国产精品美女久久久久久久久久久 | 毛片av在线播放 | 97国产在线| 99精品国产高清一区二区麻豆 | 欧美日韩一区二区三区 | 欧美精品1区 | 国产精品污www在线观看 | 亚洲精品电影网在线观看 | 91视视频在线观看入口直接观看 | 国产自产才c区 | 天天操天天舔天天爽 | 免费三级电影网站 | 亚洲精品视频在线看 | 久久久久久91香蕉国产 | 欧美日韩精品 | xx视频在线观看 | 久久伊人青青草 | 亚洲精品国产a久久久久久 国产毛片毛片 | 久久中文字幕一区 | 国产毛片精品 | 午夜精品久久久久久久星辰影院 | 日韩精品免费 | 日本成人一二三区 | 亚洲免费在线视频 | 国产一区二区久久久 | 欧美中文在线 | 国产精品91久久久久 | 色综合一区 | 国产男女免费视频 | 精品国产乱码久久久久久久软件 | 99爱免费观看 | 国产三级一区二区 | 亚洲国产精品久久久久久女王 | 国产精品国产三级国产aⅴ无密码 | 在线免费观看黄色 | 欧美另类一二三四 | 欧美日韩免费在线 | 另类一区| 日本三级电影免费 | 亚洲欧美日韩在线一区 | 伊人最新网址 | 视频一区在线播放 | 久久精品成人免费视频 | 亚洲国产aⅴ成人精品无吗 国产精品永久在线观看 | 五月网婷婷 | 国产精品视频一区二区三区 | 亚洲欧美综合一区 | 久久久精品一区 | 亚洲精品成人av | 欧美精品在线观看免费 | 亚洲一区中文 | 中文字幕一区二区三区日韩精品 | 久久不射电影网 | 精品国产一区二区三区久久影院 | 亚洲天堂久久 | 伦理午夜电影免费观看 | 精品一区二区三区在线观看 | 伊人短视频 | avhd101在线成人播放 | 欧美性网| 欧美日韩亚洲视频 | 国产精品国产三级国产aⅴ原创 | 精品免费国产一区二区三区 | 在线亚洲不卡 | 亚洲一区中文字幕在线观看 | 亚洲国产高清在线 | www.国产精品 | 天堂av一区二区 | 亚洲h| 精品久久国产 | 精品国产一区二区三区性色 | 久久久国产精品 | 国产精品成人3p一区二区三区 | 黄色网在线看 | 成人乱人乱一区二区三区 | 久久精品一 | 精品国产91乱码一区二区三区 | 午夜在线观看 | 久久精品一区 | 91精品综合久久久久久五月天 | 91视频免费观看网址 | 亚洲欧洲一区二区三区 | 亚洲高清视频一区 | 亚洲视频在线观看网址 | 亚洲色域网 | 日韩高清中文字幕 | 91精品国产一区二区 | 成人精品电影 | 嫩草成人影院 | 日韩在线视频精品 | 99视频免费在线观看 | 国产精品毛片在线 | 欧美一级免费观看 | 中文字幕一区在线观看视频 | 青草福利 | 一区二区三区精品视频 | 国产精品亚洲成在人线 | 国产精品久久久久久久久久久久久久 | 精品黄网 | 高清av网站 | 韩国久久精品 | 日日干夜夜操 | 午夜精品视频在线观看 | 影音先锋在线看片资源 | 婷婷亚洲五月 | 国产成人一区二区三区 | 国产在线精品一区 | 成人国产精品视频 | av在线网址观看 | 日韩欧美一区二区三区久久婷婷 | 久久久高清 | 99久久综合精品五月天 | 91在线电影 | 日韩av电影观看 | 国产噜噜噜噜噜久久久久久久久 | 久久99精品久久久久子伦 | 欧美九九九 | 日本一区二区成人 | 一级a性色生活片毛片 | 国产一级片| 免费观看黄色大片 | 最新日韩av | 在线免费91| 成人精品一区二区三区中文字幕 | 精品久久久久久久久久久久久久 | 日本免费一区二区视频 | 91福利网站在线观看 | 日韩免费av一区二区 | 一区欧美 | 久久国产视屏 | 欧美午夜一区二区三区免费大片 | 中文字幕在线免费视频 | 中文字幕亚洲精品 | 亚洲精品久久久久久久久久久久久 | 超级乱淫片国语对白免费视频 | 精品国产乱码久久久久久久软件 | 天天射天天干 | 免费xxxx大片国产在线 | 日韩极品在线 | 中文字幕综合 | 国产一在线 | 成人精品在线 | 97在线免费视频 | 国产色黄视频 | 成年人看的羞羞网站 | 天天操天天添 | 国产精品极品美女在线观看免费 | 成人毛片在线视频 | 国产成人涩涩涩视频在线观看 | 国产精品久久久爽爽爽麻豆色哟哟 | 少妇av片 | 亚洲第一福利视频 | 91色在线观看 | 狠狠色综合欧美激情 | 男女视频在线看 | 日韩一日 | 99热精品国产 | 99在线精品视频 | 亚色在线 | 青青草久久 | 在线观看毛片视频 | 天天操夜夜干 | 国产偷自视频区视频 | 欧洲亚洲精品久久久久 | 99视频精品 | 二区三区 | 亚洲 中文 欧美 日韩 在线观看 | 99国产视频 | 国产精品视频一区二区三区四 | 午夜午夜精品一区二区三区文 | 久在线视频 | 日韩高清成人 | 青青久久| 久久国产欧美日韩精品 | 天天看天天爽 | 精品二区 | 伊人亚洲 | 性色视频免费观看 | 久久精品国产一区二区三区不卡 | 成人综合在线观看 | 欧美综合色 | 草久在线视频 | 久久精品欧美一区二区三区不卡 | 超碰av人人 | 欧美在线视频网 | 日本五月婷婷 | 亚洲色欲色欲www | www.久久精品 | 日韩av免费在线观看 | 久久久久久亚洲 | 成人看片在线观看 | 午夜影院在线观看视频 | 蜜桃久久av | 欧美精品在线一区 | 99免费视频 | 久久免费视频国产 | 欧美日韩成人在线播放 | 成人xxx | 日日操夜 | 国产精品一区二区视频 | 欧美成人a∨高清免费观看 在线视频成人 | 羞羞视频在线免费观看 | 色吊丝在线永久观看最新版本 | 91视频免费观看 | 亚洲精品日本 | www.天天草 | 久久国内精品 | 亚洲精品一区二三区 | 久久青青 | 一区二区福利 | 亚洲欧美日韩另类一区二区 | 亚洲精品久久久久久久久久久 | 久久久久国 | 国产在线拍揄自揄拍视频 | 日韩成人在线一区 | 黄色a三级 | 亚洲国产精品福利 | 操久久| 久久久二| 欧美精品日韩 | 欧美成人精品一区二区三区 | 97久久精品人人做人人爽50路 | 免费观看日韩一级片 | 成人欧美一区二区三区在线播放 | 日本视频中文字幕 | 午夜精品久久久久久久男人的天堂 | 黄色片网站在线免费观看 | 青青久草在线 | 99亚洲精品| 欧美日日| 国产综合视频 | 亚洲高清在线视频 | 亚洲成人精品网 | 免费亚洲网站 | www久久九| 国产精品一区二区在线 | 在线观看国产视频 | 久久精品国产一区 | 久久国产一区二区三区 | 久久中文字幕一区二区 | 黄色免费成人 | 男女黄网站 | 日韩精品一区二区三区四区视频 | 亚洲欧美一区二区在线观看 | 久久91久久久久麻豆精品 | 欧美亚洲另类丝袜综合网动图 | 麻豆专区一区二区三区四区五区 | 九九色综合 | 色婷婷亚洲| 狠狠躁夜夜躁人人爽天天高潮 | 国产欧美综合一区二区三区 | 91久久国产综合久久蜜月精品 | 黄色欧美一级片 | 老黄网站在线观看 | 在线二区| 国产成年免费视频 | www.久草.com | 久久国产成人午夜av影院宅 | 日韩成人在线免费视频 | 国产成人精品一区二区三区四区 | 国产精品污www在线观看 | 欧美日韩视频在线 | 欧美一区精品 | 亚洲综合精品在线 | 精品国产乱码久久久久久蜜臀 | 国产欧美一区二区精品婷 | av片免费看 | 中文字幕av一区二区三区免费看 | 国产女人免费看a级丨片 | 国产精品一区av | 三级网站视频 | 国产激情网址 | 免费国产一区 | 成人亚洲视频在线观看 | 在线观看三区 | 欧美女优在线视频 | 欧美激情一区二区三级高清视频 | 国产精品丝袜一区二区 | 精品国产91久久久久久久 | 成人精品视频在线观看 | 国产精品久久嫩一区二区免费 | 91色乱码一区二区三区 | 成人欧美一区二区三区黑人孕妇 | 亚洲欧美在线免费观看 | 91欧美| 欧美日韩国产高清 | 国产激情性色视频在线观看 | 成人欧美日韩一区二区三区 | 欧美色综合天天久久综合精品 | 精品久久久精品 | 日韩二区精品 | 一本岛在线视频 | 黄a免费看 | 欧美精品欧美精品系列 | 免费观看欧美一级 | 欧美一卡二卡在线观看 | 9se成人免费网站 | 嫩草视频网 | 成人在线免费电影 | 九九在线视频 | 日韩国产在线观看 | 99re国产| 精品视频在线观看 | 精品成人一区二区 | www视频在线观看 | 久草视 | 精品一区视频 | 国产精品三级久久久久久电影 | 欧美午夜在线观看 | 中文字幕久久精品 | www国产亚洲 | 午夜午夜精品一区二区三区文 | 色毛片 | 国产精品九九久久99视频 | 日韩欧美一级片 | 天天干夜夜弄 | 久久中文字幕一区二区 | 亚洲视频免费网站 | 人人射人人 | 一级黄色爱爱视频 | 中文av一区 | 中文字幕一区二区不卡 | 操夜夜| 99精品欧美一区二区三区综合在线 | 四虎成人免费电影 | 精品欧美日韩 | 国产色 | 在线观看国产www | 国产一区| 日韩免费精品视频 | 欧美视频精品在线观看 | 亚洲成a人v欧美综合天堂麻豆 | 999久久久久久久久 国产欧美在线观看 | 99精品欧美一区二区三区综合在线 | 国产精品久久久久久久久免费丝袜 | 91精品国产乱码久久久久久 | 日韩在线视频免费 | 日夜夜精品| 97国产一区二区精品久久呦 | 日韩成人黄色 | 亚洲免费网| 国产日韩欧美视频 | 91精品久久 | 国产精品自产拍在线观看 | 黄色影视在线免费观看 | 久热精品在线 | 国产成人精品一区一区一区 | 久久精品一区 | 久久久久久久国产 | 国产精品毛片久久久久久 | 亚洲91精品 | 每日更新av | 久久精品麻豆 | 国产成人av在线 | 海外中文字幕在线观看 | 欧美日韩在线观看一区二区三区 | 天天躁日日躁性色aⅴ电影 免费在线观看成年人视频 国产欧美精品 | 亚洲欧美激情精品一区二区 | 久久国产一区二区三区 | 婷婷久久综合 | 亚洲一区二区在线 | 日韩在线播放一区二区 | 亚洲精品视频一区 | www.国产| 精品一区二区三区免费看 | 亚洲一区在线日韩在线深爱 | 91免费在线看 | 国产精品综合一区二区 | 色婷婷国产精品 | 国产情侣小视频 | 国产精品久久久久久久久 | 欧美啪 | 日韩欧美精品一区二区三区 | 亚洲精品久久久久久一区二区 | 久久久久久久久久久网站 | 日韩在线观看一区 | 精品一区免费 | 成人精品一区二区三区中文字幕 | 亚洲热在线视频 | 国产一区二区三区久久久久久久久 | 密室大逃脱第六季大神版在线观看 | 国产午夜久久 | 男女深夜网站 | 国产黄色一级大片 | 亚洲天堂成人 | 欧美精品色网 | 欧美一区二区三区在线 | 亚洲欧美日韩精品久久奇米色影视 | 日韩成人国产 | 夜本色| 久久2018 | 国产日韩欧美精品一区二区三区 | 久久久久久国产精品 | av 一区二区三区 | 国产在线观看一区二区三区 | 91色在线观看 | 日韩久久久久 | 亚洲xx视频 | 日本久久精品 | 国产精品无码永久免费888 | 成人在线小视频 | 国产中文视频 | 成人免费视频网站在线观看 | 中文字幕精品一区久久久久 | 色网站免费视频 | 日日骚 | 在线免费观看日韩视频 | 亚洲乱码国产乱码精品精98午夜 | 97久久精品人人做人人爽50路 | 99免费在线播放99久久免费 | 一区二区三区影院 | av影片在线| 一区二区av | 太子妃好紧皇上好爽h | 成人免费网站 | 国产九九九 | 国产v日产∨综合v精品视频 | av免费网站在线观看 | 久久久国产精品入口麻豆 | 欧美中文字幕一区二区 | 欧美久久久精品 | 日日夜夜一区二区 | 国产精品久久久久久久久久久久冷 | 国产一级视频 | 日韩av成人| 免费一区二区 | 亚洲精品乱码久久久久久花季 | 国产激情网 | 亚洲欧美一区二区三区在线 | 狠狠综合 | 视频一区二区三区中文字幕 | 人人干人人干 | 久久免费小视频 | 国产精品视频久久久 | 中文字幕乱码亚洲精品一区 | 国产又粗又长又硬又猛电影 | 欧美一区二区三区在线观看 | 国产一在线 | www.啪啪| 亚洲综合视频 | 日日操夜夜操免费视频 | 先锋av资源在线 | 91啪影院 | 嫩草影院黄色 | chengrenzaixian| 色吧av | 国产高清精 | 久久夜视频 | 久久成人一区 | 免费观看欧美一级 | 伦理午夜电影免费观看 | 午夜大片网 | 99re在线观看视频 | 中文在线一区 | 伊人一区| 国产噜噜噜噜噜久久久久久久久 | 精品国产一区三区 | 中文字幕在线视频观看 | www.色综合| 在线观看av网站永久 | 亚洲福利一区 | 国产精品久久久久久久久久久久 | 欧美综合激情 | 禁果av一区二区三区 | www久久久 | 日韩一区二区中文字幕 | 欧美日韩高清在线一区 | 日日摸夜夜添夜夜添高潮视频 | 午夜影视在线观看 | av在线入口 | 中文字幕在线观看一区二区三区 | 龙珠z国语291集普通话 | 亚洲第一av | 国产精品乱码一区二区三区 | 激情小视频在线观看 | 精品久久久久久久久久久久 | 色在线免费视频 | 欧美在线观看网站 | 日韩视频中文字幕在线观看 | 亚洲一区二区精品视频 | 91精品一区二区 | 我爱操| 91偷拍精品一区二区三区 | 自拍第一页 | 久久久av亚洲男天堂 | 国产成人在线免费观看 | 免费一看一级毛片 | 午夜视频一区 | 老司机深夜福利在线观看 | 午夜家庭影院 | 国产综合亚洲精品一区二 | 在线涩涩| 91视频免费在线 | 欧美中文字幕在线 | 欧美日韩精品在线观看 | 天堂精品| 成人1区2区 | 久久久999成人 | 禁果av一区二区三区 | 成人精品久久久 | 二区欧美 | 久久精品福利 | 午夜电影福利 | 免费亚洲精品 | 久久一区二区三区四区五区 | 国产精品久久久久无码av | 国产一区二区成人 | 欧美黑人做爰xxxⅹ 国产精品一区二区视频 | 久久精品高清视频 | 91精品视频在线播放 | 亚洲日韩中文字幕一区 | 在线只有精品 | 可以免费观看的av | 情趣视频在线免费观看 | 五月天婷婷精品 | 久在线视频 | 国产精品久久久久久久久久三级 | 五月婷亚洲 | 一区二区日韩精品 | 成人伊人网 | 亚洲精品天堂 | 97伦理网| 日日操视频| 老司机深夜福利视频 | 亚洲精品粉嫩美女一区 | 91精品国产一区二区 | 亚洲欧美日韩一区二区 | 久久久久黄| 亚洲精品成人无限看 | 69性欧美高清影院 | 精品久 | 国产一区二区精品久久 | 日韩三级电影免费观看 | 黄色毛片在线观看 | 日本免费三片免费观看 | 精品欧美一区二区精品久久久 | 国产91av视频在线观看 | 天天色天天看 | 色香蕉在线 | 国产精品久久久久久久久久99 | 国产h片在线观看 | 国产成人精品网站 | 能免费看的av | 亚洲va欧美va天堂v国产综合 | 亚洲免费看片 | 国产黄色大片 | 黄色毛片在线看 | 中文字幕一区在线观看视频 | 亚洲毛片在线观看 | 中文字幕精品一区久久久久 | 精品国产伦一区二区三区观看说明 | 玖草资源 | 欧美日韩一区二区视频在线观看 | 欧美精品久久久 | 亚洲成人av在线播放 | 久久噜噜噜精品国产亚洲综合 | 日韩成人在线播放 | 国产在线h | 中文字幕在线第一页 | 成人一级片视频 | 一区二区三区四区视频 | 亚洲成人精品一区二区三区 | 国产欧美精品区一区二区三区 | 国产免费一级特黄录像 | 久久久久久久成人 | 午夜久久av | 国产精品99久久免费观看 | 国产精品精品视频一区二区三区 | 国产成人一区 | 中文字幕日韩一区 | 日韩免费观看视频 | 国产3区| 日韩视频在线观看中文字幕 | 越南性xxxx精品hd |