国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

深入了解Vue3中偵聽器watcher的實(shí)現(xiàn)原理

 更新時(shí)間:2022年04月14日 10:44:33   作者:風(fēng)度前端  
在平時(shí)的開發(fā)工作中,我們經(jīng)常使用偵聽器幫助我們?nèi)ビ^察某個(gè)數(shù)據(jù)的變化然后去執(zhí)行一段邏輯。在?Vue.js?2.x?中,你可以通過?watch?選項(xiàng)去初始化一個(gè)偵聽器,稱作?watcher。本文將詳細(xì)為大家介紹一下偵聽器的實(shí)現(xiàn)原理,需要的可以參考一下

在平時(shí)的開發(fā)工作中,我們經(jīng)常使用偵聽器幫助我們?nèi)ビ^察某個(gè)數(shù)據(jù)的變化然后去執(zhí)行一段邏輯。

在 Vue.js 2.x 中,你可以通過 watch 選項(xiàng)去初始化一個(gè)偵聽器,稱作 watcher:

export default { 
  watch: { 
    a(newVal, oldVal) { 
      console.log('new: %s,00 old: %s', newVal, oldVal) 
    } 
  } 
} 

當(dāng)然你也可以通過 $watch API 去創(chuàng)建一個(gè)偵聽器:

const unwatch = vm.$watch('a', function(newVal, oldVal) { 
  console.log('new: %s, old: %s', newVal, oldVal) 
}) 

與 watch 選項(xiàng)不同,通過 $watch API 創(chuàng)建的偵聽器 watcher 會(huì)返回一個(gè) unwatch 函數(shù),你可以隨時(shí)執(zhí)行它來停止這個(gè) watcher 對(duì)數(shù)據(jù)的偵聽,而對(duì)于 watch 選項(xiàng)創(chuàng)建的偵聽器,它會(huì)隨著組件的銷毀而停止對(duì)數(shù)據(jù)的偵聽。

在 Vue.js 3.0 中,雖然你仍可以使用 watch 選項(xiàng),但針對(duì) Composition API,Vue.js 3.0 提供了 watch API 來實(shí)現(xiàn)偵聽器的效果。本文就來分析下 watch API 的實(shí)現(xiàn)原理

watch API 的用法

我們先來看 Vue.js 3.0 中 watch API 有哪些用法。

1.watch API 可以偵聽一個(gè) getter 函數(shù),但是它必須返回一個(gè)響應(yīng)式對(duì)象,當(dāng)該響應(yīng)式對(duì)象更新后,會(huì)執(zhí)行對(duì)應(yīng)的回調(diào)函數(shù)。

import { reactive, watch } from 'vue' 
const state = reactive({ count: 0 }) 
watch(() => state.count, (count, prevCount) => { 
  // 當(dāng) state.count 更新,會(huì)觸發(fā)此回調(diào)函數(shù) 
}) 

2.watch API 也可以直接偵聽一個(gè)響應(yīng)式對(duì)象,當(dāng)響應(yīng)式對(duì)象更新后,會(huì)執(zhí)行對(duì)應(yīng)的回調(diào)函數(shù)。

import { ref, watch } from 'vue' 
const count = ref(0) 
watch(count, (count, prevCount) => { 
  // 當(dāng) count.value 更新,會(huì)觸發(fā)此回調(diào)函數(shù) 
}) 

3.watch API 還可以直接偵聽多個(gè)響應(yīng)式對(duì)象,任意一個(gè)響應(yīng)式對(duì)象更新后,就會(huì)執(zhí)行對(duì)應(yīng)的回調(diào)函數(shù)。

import { ref, watch } from 'vue' 
const count = ref(0) 
const count2 = ref(1) 
watch([count, count2], ([count, count2], [prevCount, prevCount2]) => { 
  // 當(dāng) count.value 或者 count2.value 更新,會(huì)觸發(fā)此回調(diào)函數(shù) 
}) 

watch API實(shí)現(xiàn)原理

偵聽器的言下之意就是,當(dāng)偵聽的對(duì)象或者函數(shù)發(fā)生了變化則自動(dòng)執(zhí)行某個(gè)回調(diào)函數(shù),這和副作用函數(shù) effect 很像, 那它的內(nèi)部實(shí)現(xiàn)是不是依賴了 effect 呢?帶著這個(gè)疑問,我們來探究 watch API 的具體實(shí)現(xiàn):

function watch(source, cb, options) { 
  if ((process.env.NODE_ENV !== 'production') && !isFunction(cb)) { 
    warn(``watch(fn, options?)` signature has been moved to a separate API. ` + 
      `Use `watchEffect(fn, options?)` instead. `watch` now only ` + 
      `supports `watch(source, cb, options?) signature.`) 
  } 
  return doWatch(source, cb, options) 
} 
function doWatch(source, cb, { immediate, deep, flush, onTrack, onTrigger } = EMPTY_OBJ) { 
  // 標(biāo)準(zhǔn)化 source 
  // 構(gòu)造 applyCb 回調(diào)函數(shù) 
  // 創(chuàng)建 scheduler 時(shí)序執(zhí)行函數(shù) 
  // 創(chuàng)建 effect 副作用函數(shù) 
  // 返回偵聽器銷毀函數(shù) 
}    

從代碼中可以看到,watch 函數(shù)內(nèi)部調(diào)用了 doWatch 函數(shù),調(diào)用前會(huì)在非生產(chǎn)環(huán)境下判斷第二個(gè)參數(shù) cb 是不是一個(gè)函數(shù),如果不是則會(huì)報(bào)警告以告訴用戶應(yīng)該使用 watchEffect(fn, options) API,watchEffect API 也是偵聽器相關(guān)的 API,稍后我們會(huì)詳細(xì)介紹。

下面我們就看看doWatch函數(shù)做了哪些事情

標(biāo)準(zhǔn)化source

我們先來看watch 函數(shù)的第一個(gè)參數(shù) source。

通過前文知道 source 可以是 getter 函數(shù),也可以是響應(yīng)式對(duì)象甚至是響應(yīng)式對(duì)象數(shù)組,所以我們需要標(biāo)準(zhǔn)化 source,這是標(biāo)準(zhǔn)化 source 的流程:

// source 不合法的時(shí)候會(huì)報(bào)警告 
const warnInvalidSource = (s) => { 
  warn(`Invalid watch source: `, s, `A watch source can only be a getter/effect function, a ref, ` + 
    `a reactive object, or an array of these types.`) 
} 
// 當(dāng)前組件實(shí)例 
const instance = currentInstance 
let getter 
if (isArray(source)) { 
  getter = () => source.map(s => { 
    if (isRef(s)) { 
      return s.value 
    } 
    else if (isReactive(s)) { 
      return traverse(s) 
    } 
    else if (isFunction(s)) { 
      return callWithErrorHandling(s, instance, 2 /* WATCH_GETTER */) 
    } 
    else { 
      (process.env.NODE_ENV !== 'production') && warnInvalidSource(s) 
    } 
  }) 
} 
else if (isRef(source)) { 
  getter = () => source.value 
} 
else if (isReactive(source)) { 
  getter = () => source 
  deep = true 
} 
else if (isFunction(source)) { 
  if (cb) { 
    // getter with cb 
    getter = () => callWithErrorHandling(source, instance, 2 /* WATCH_GETTER */) 
  } 
  else { 
    // watchEffect 的邏輯 
  } 
} 
else { 
  getter = NOOP 
  (process.env.NODE_ENV !== 'production') && warnInvalidSource(source) 
} 
if (cb && deep) { 
  const baseGetter = getter 
  getter = () => traverse(baseGetter()) 
} 

其實(shí),source 標(biāo)準(zhǔn)化主要是根據(jù) source 的類型,將其變成 getter 函數(shù)。具體來說:

  • 如果 source 是 ref 對(duì)象,則創(chuàng)建一個(gè)訪問 source.value 的 getter 函數(shù);
  • 如果 source 是 reactive 對(duì)象,則創(chuàng)建一個(gè)訪問 source 的 getter 函數(shù),并設(shè)置 deep 為 true(deep 的作用我稍后會(huì)說)
  • 如果 source 是一個(gè)函數(shù),則會(huì)進(jìn)一步判斷第二個(gè)參數(shù) cb 是否存在,對(duì)于 watch API 來說,cb 是一定存在且是一個(gè)回調(diào)函數(shù),這種情況下,getter 就是一個(gè)簡單的對(duì) source 函數(shù)封裝的函數(shù)。

如果 source 不滿足上述條件,則在非生產(chǎn)環(huán)境下報(bào)警告,提示 source 類型不合法。

我們來看一下最終標(biāo)準(zhǔn)化生成的 getter 函數(shù),它會(huì)返回一個(gè)響應(yīng)式對(duì)象,在后續(xù)創(chuàng)建 effect runner 副作用函數(shù)需要用到,每次執(zhí)行 runner 就會(huì)把 getter 函數(shù)返回的響應(yīng)式對(duì)象作為 watcher 求值的結(jié)果,effect runner 的創(chuàng)建流程我們后續(xù)會(huì)詳細(xì)分析,這里不需要深入了解。

最后我們來關(guān)注一下 deep 為 true 的情況。此時(shí),我們會(huì)發(fā)現(xiàn)生成的 getter 函數(shù)會(huì)被 traverse 函數(shù)包裝一層。traverse 函數(shù)的實(shí)現(xiàn)很簡單,即通過遞歸的方式訪問 value 的每一個(gè)子屬性。那么,為什么要遞歸訪問每一個(gè)子屬性呢?

其實(shí) deep 屬于 watcher 的一個(gè)配置選項(xiàng),Vue.js 2.x 也支持,表面含義是深度偵聽,實(shí)際上是通過遍歷對(duì)象的每一個(gè)子屬性來實(shí)現(xiàn)。舉個(gè)例子你就明白了:

import { reactive, watch } from 'vue' 
const state = reactive({ 
  count: { 
    a: { 
      b: 1 
    } 
  } 
}) 
watch(state.count, (count, prevCount) => { 
  console.log(count) 
}) 
state.count.a.b = 2  

這里,我們利用 reactive API 創(chuàng)建了一個(gè)嵌套層級(jí)較深的響應(yīng)式對(duì)象 state,然后再調(diào)用 watch API 偵聽 state.count 的變化。接下來我們修改內(nèi)部屬性 state.count.a.b 的值,你會(huì)發(fā)現(xiàn) watcher 的回調(diào)函數(shù)執(zhí)行了,為什么會(huì)執(zhí)行呢?

原則上Proxy實(shí)現(xiàn)的響應(yīng)式對(duì)象,只有對(duì)象屬性先被訪問觸發(fā)了依賴收集,再去修改這個(gè)屬性,才可以通知對(duì)應(yīng)的依賴更新。而從上述業(yè)務(wù)代碼來看,我們修改 state.count.a.b 的值時(shí)并沒有訪問它 ,但還是觸發(fā)了 watcher 的回調(diào)函數(shù)。

根本原因是,當(dāng)我們執(zhí)行 watch 函數(shù)的時(shí)候,我們知道如果偵聽的是一個(gè) reactive 對(duì)象,那么內(nèi)部會(huì)設(shè)置 deep 為 true, 然后執(zhí)行 traverse 去遞歸訪問對(duì)象深層子屬性,這個(gè)時(shí)候就會(huì)訪問 state.count.a.b 觸發(fā)依賴收集,這里收集的依賴是 watcher 內(nèi)部創(chuàng)建的 effect runner。因此,當(dāng)我們?cè)偃バ薷?state.count.a.b 的時(shí)候,就會(huì)通知這個(gè) effect ,所以最終會(huì)執(zhí)行 watcher 的回調(diào)函數(shù)。

當(dāng)我們偵聽一個(gè)通過 reactive API 創(chuàng)建的響應(yīng)式對(duì)象時(shí),內(nèi)部會(huì)執(zhí)行 traverse 函數(shù),如果這個(gè)對(duì)象非常復(fù)雜,比如嵌套層級(jí)很深,那么遞歸 traverse 就會(huì)有一定的性能耗時(shí)。因此如果我們需要偵聽這個(gè)復(fù)雜響應(yīng)式對(duì)象內(nèi)部的某個(gè)具體屬性,就可以想辦法減少 traverse 帶來的性能損耗。

比如剛才的例子,我們就可以直接偵聽 state.count.a.b 的變化:

watch(state.count.a, (newVal, oldVal) => { 
  console.log(newVal) 
}) 
state.count.a.b = 2 

這樣就可以減少內(nèi)部執(zhí)行 traverse 的次數(shù)。你可能會(huì)問,直接偵聽 state.count.a.b 可以嗎?答案是不行,因?yàn)?state.count.a.b 已經(jīng)是一個(gè)基礎(chǔ)數(shù)字類型了,不符合 source 要求的參數(shù)類型,所以會(huì)在非生產(chǎn)環(huán)境下報(bào)警告。

那么有沒有辦法優(yōu)化使得 traverse 不執(zhí)行呢?答案是可以的。我們可以偵聽一個(gè) getter 函數(shù):

watch(() => state.count.a.b, (newVal, oldVal) => { 
  console.log(newVal) 
}) 
state.count.a.b = 2 

這樣函數(shù)內(nèi)部會(huì)訪問并返回 state.count.a.b,一次 traverse 都不會(huì)執(zhí)行并且依然可以偵聽到它的變化從而執(zhí)行 watcher 的回調(diào)函數(shù)。

構(gòu)造回調(diào)函數(shù)

處理完 watch API 第一個(gè)參數(shù) source 后,接下來處理第二個(gè)參數(shù) cb。

cb 是一個(gè)回調(diào)函數(shù),它有三個(gè)參數(shù):第一個(gè) newValue 代表新值;第二個(gè) oldValue 代表舊值。第三個(gè)參數(shù) onInvalidate,這個(gè)放在后面介紹。

其實(shí)這樣的 API 設(shè)計(jì)非常好理解,即偵聽一個(gè)值的變化,如果值變了就執(zhí)行回調(diào)函數(shù),回調(diào)函數(shù)里可以訪問到新值和舊值。

接下來我們來看一下構(gòu)造回調(diào)函數(shù)的處理邏輯:

let cleanup 
// 注冊(cè)無效回調(diào)函數(shù) 
const onInvalidate = (fn) => { 
  cleanup = runner.options.onStop = () => { 
    callWithErrorHandling(fn, instance, 4 /* WATCH_CLEANUP */) 
  } 
} 
// 舊值初始值 
let oldValue = isArray(source) ? [] : INITIAL_WATCHER_VALUE /*{}*/ 
// 回調(diào)函數(shù) 
const applyCb = cb 
  ? () => { 
    // 組件銷毀,則直接返回 
    if (instance && instance.isUnmounted) { 
      return 
    } 
    // 求得新值 
    const newValue = runner() 
    if (deep || hasChanged(newValue, oldValue)) { 
      // 執(zhí)行清理函數(shù) 
      if (cleanup) { 
        cleanup() 
      } 
      callWithAsyncErrorHandling(cb, instance, 3 /* WATCH_CALLBACK */, [ 
        newValue, 
        // 第一次更改時(shí)傳遞舊值為 undefined 
        oldValue === INITIAL_WATCHER_VALUE ? undefined : oldValue, 
        onInvalidate 
      ]) 
      // 更新舊值 
      oldValue = newValue 
    } 
  } 
  : void 0 

onInvalidate 函數(shù)用來注冊(cè)無效回調(diào)函數(shù) ,我們暫時(shí)不需要關(guān)注它,我們需要重點(diǎn)來看 applyCb。 這個(gè)函數(shù)實(shí)際上就是對(duì) cb 做一層封裝,當(dāng)偵聽的值發(fā)生變化時(shí)就會(huì)執(zhí)行 applyCb 方法,我們來分析一下它的實(shí)現(xiàn)。

首先,watch API 和組件實(shí)例相關(guān),因?yàn)橥ǔN覀儠?huì)在組件的 setup 函數(shù)中使用它,當(dāng)組件銷毀后,回調(diào)函數(shù) cb 不應(yīng)該被執(zhí)行而是直接返回。

接著,執(zhí)行 runner 求得新值,這里實(shí)際上就是執(zhí)行前面創(chuàng)建的 getter 函數(shù)求新值。

最后進(jìn)行判斷,如果是 deep 的情況或者新舊值發(fā)生了變化,則執(zhí)行回調(diào)函數(shù) cb,傳入?yún)?shù) newValue 和 oldValue。注意,第一次執(zhí)行的時(shí)候舊值的初始值是空數(shù)組或者 undefined。執(zhí)行完回調(diào)函數(shù) cb 后,把舊值 oldValue 再更新為 newValue,這是為了下一次的比對(duì)。

創(chuàng)建scheduler

接下來我們要分析創(chuàng)建 scheduler 過程。

scheduler 的作用是根據(jù)某種調(diào)度的方式去執(zhí)行某種函數(shù),在 watch API 中,主要影響到的是回調(diào)函數(shù)的執(zhí)行方式。我們來看一下它的實(shí)現(xiàn)邏輯:

const invoke = (fn) => fn() 
let scheduler 
if (flush === 'sync') { 
  // 同步 
  scheduler = invoke 
} 
else if (flush === 'pre') { 
  scheduler = job => { 
    if (!instance || instance.isMounted) { 
      // 進(jìn)入異步隊(duì)列,組件更新前執(zhí)行 
      queueJob(job) 
    } 
    else { 
      // 如果組件還沒掛載,則同步執(zhí)行確保在組件掛載前 
      job() 
    } 
  } 
} 
else { 
  // 進(jìn)入異步隊(duì)列,組件更新后執(zhí)行 
  scheduler = job => queuePostRenderEffect(job, instance && instance.suspense) 
} 

Watch API 的參數(shù)除了 source 和 cb,還支持第三個(gè)參數(shù) options,不同的配置決定了 watcher 的不同行為。前面我們也分析了 deep 為 true 的情況,除了 source 為 reactive 對(duì)象時(shí)會(huì)默認(rèn)把 deep 設(shè)置為 true,你也可以主動(dòng)傳入第三個(gè)參數(shù),把 deep 設(shè)置為 true。

這里,scheduler 的創(chuàng)建邏輯受到了第三個(gè)參數(shù) Options 中的 flush 屬性值的影響,不同的 flush 決定了 watcher 的執(zhí)行時(shí)機(jī)。

  • 當(dāng) flush 為 sync 的時(shí)候,表示它是一個(gè)同步 watcher,即當(dāng)數(shù)據(jù)變化時(shí)同步執(zhí)行回調(diào)函數(shù)。
  • 當(dāng) flush 為 pre 的時(shí)候,回調(diào)函數(shù)通過 queueJob 的方式在組件更新之前執(zhí)行,如果組件還沒掛載,則同步執(zhí)行確?;卣{(diào)函數(shù)在組件掛載之前執(zhí)行。
  • 如果沒設(shè)置 flush,那么回調(diào)函數(shù)通過 queuePostRenderEffect 的方式在組件更新之后執(zhí)行。

queueJob 和 queuePostRenderEffect 在這里不是重點(diǎn),所以我們放到后面介紹??傊悻F(xiàn)在要記住,watcher 的回調(diào)函數(shù)是通過一定的調(diào)度方式執(zhí)行的。

創(chuàng)建effect

前面的分析我們提到了 runner,它其實(shí)就是 watcher 內(nèi)部創(chuàng)建的 effect 函數(shù),接下來,我們來分析它邏輯:

const runner = effect(getter, { 
  // 延時(shí)執(zhí)行 
  lazy: true, 
  // computed effect 可以優(yōu)先于普通的 effect 先運(yùn)行,比如組件渲染的 effect 
  computed: true, 
  onTrack, 
  onTrigger, 
  scheduler: applyCb ? () => scheduler(applyCb) : scheduler 
}) 
// 在組件實(shí)例中記錄這個(gè) effect 
recordInstanceBoundEffect(runner) 
// 初次執(zhí)行 
if (applyCb) { 
  if (immediate) { 
    applyCb() 
  } 
  else { 
    // 求舊值 
    oldValue = runner() 
  } 
} 
else { 
  // 沒有 cb 的情況 
  runner() 
} 

這塊代碼邏輯是整個(gè) watcher 實(shí)現(xiàn)的核心部分,即通過 effect API 創(chuàng)建一個(gè)副作用函數(shù) runner,我們需要關(guān)注以下幾點(diǎn)。

runner 是一個(gè) computed effect。 因?yàn)?computed effect 可以優(yōu)先于普通的 effect(比如組件渲染的 effect)先運(yùn)行,這樣就可以實(shí)現(xiàn)當(dāng)配置 flush 為 pre 的時(shí)候,watcher 的執(zhí)行可以優(yōu)先于組件更新。

runner 執(zhí)行的方式。 runner 是 lazy 的,它不會(huì)在創(chuàng)建后立刻執(zhí)行。第一次手動(dòng)執(zhí)行 runner 會(huì)執(zhí)行前面的 getter 函數(shù),訪問響應(yīng)式數(shù)據(jù)并做依賴收集。注意,此時(shí)activeEffect 就是 runner,這樣在后面更新響應(yīng)式數(shù)據(jù)時(shí),就可以觸發(fā) runner 執(zhí)行 scheduler 函數(shù),以一種調(diào)度方式來執(zhí)行回調(diào)函數(shù)。

runner 的返回結(jié)果。 手動(dòng)執(zhí)行 runner 就相當(dāng)于執(zhí)行了前面標(biāo)準(zhǔn)化的 getter 函數(shù),getter 函數(shù)的返回值就是 watcher 計(jì)算出的值,所以我們第一次執(zhí)行 runner 求得的值可以作為 oldValue。

配置了 immediate 的情況。 當(dāng)我們配置了 immediate ,創(chuàng)建完 watcher 會(huì)立刻執(zhí)行 applyCb 函數(shù),此時(shí) oldValue 還是初始值,在 applyCb 執(zhí)行時(shí)也會(huì)執(zhí)行 runner 進(jìn)而執(zhí)行前面的 getter 函數(shù)做依賴收集,求得新值。

返回銷毀函數(shù)

最后,會(huì)返回偵聽器銷毀函數(shù),也就是 watch API 執(zhí)行后返回的函數(shù)。我們可以通過調(diào)用它來停止 watcher 對(duì)數(shù)據(jù)的偵聽。

return () => { 
  stop(runner) 
  if (instance) { 
    // 移除組件 effects 對(duì)這個(gè) runner 的引用 
    remove(instance.effects, runner) 
  } 
} 
function stop(effect) { 
  if (effect.active) { 
    cleanup(effect) 
    if (effect.options.onStop) { 
      effect.options.onStop() 
    } 
    effect.active = false 
  } 
} 

銷毀函數(shù)內(nèi)部會(huì)執(zhí)行 stop 方法讓 runner 失活,并清理 runner 的相關(guān)依賴,這樣就可以停止對(duì)數(shù)據(jù)的偵聽。并且,如果是在組件中注冊(cè)的 watcher,也會(huì)移除組件 effects 對(duì)這個(gè) runner 的引用。

異步任務(wù)隊(duì)列的設(shè)計(jì)

偵聽器的回調(diào)函數(shù)是以一種調(diào)度的方式執(zhí)行的,特別是當(dāng) flush 不是 sync 時(shí),它會(huì)把回調(diào)函數(shù)執(zhí)行的任務(wù)推到一個(gè)異步隊(duì)列中執(zhí)行。接下來,我們就來分析異步執(zhí)行隊(duì)列的設(shè)計(jì)。分析之前,我們先來思考一下,為什么會(huì)需要異步隊(duì)列?

我們把之前的例子簡單修改一下:

import { reactive, watch } from 'vue' 
const state = reactive({ count: 0 }) 
watch(() => state.count, (count, prevCount) => { 
  console.log(count) 
}) 
state.count++ 
state.count++ 
state.count++ 

這里,我們修改了三次 state.count,那么 watcher 的回調(diào)函數(shù)會(huì)執(zhí)行三次嗎?

答案是不會(huì),實(shí)際上只輸出了一次 count 的值,也就是最終計(jì)算的值 3。這在大多數(shù)場(chǎng)景下都是符合預(yù)期的,因?yàn)樵谝粋€(gè) Tick(宏任務(wù)執(zhí)行的生命周期)內(nèi),即使多次修改偵聽的值,它的回調(diào)函數(shù)也只執(zhí)行一次。

組件的更新過程是異步的,我們知道修改模板中引用的響應(yīng)式對(duì)象的值時(shí),會(huì)觸發(fā)組件的重新渲染,但是在一個(gè) Tick 內(nèi),即使你多次修改多個(gè)響應(yīng)式對(duì)象的值,組件的重新渲染也只執(zhí)行一次。這是因?yàn)槿绻看胃聰?shù)據(jù)都觸發(fā)組件重新渲染,那么重新渲染的次數(shù)和代價(jià)都太高了。

那么,這是怎么做到的呢?我們先從異步任務(wù)隊(duì)列的創(chuàng)建說起。

異步任務(wù)隊(duì)列的創(chuàng)建

通過前面的分析我們知道,在創(chuàng)建一個(gè) watcher 時(shí),如果配置 flush 為 pre 或不配置 flush ,那么 watcher 的回調(diào)函數(shù)就會(huì)異步執(zhí)行。此時(shí)分別是通過 queueJob 和 queuePostRenderEffect 把回調(diào)函數(shù)推入異步隊(duì)列中的。

在不涉及 suspense 的情況下,queuePostRenderEffect 相當(dāng)于 queuePostFlushCb,我們來看它們的實(shí)現(xiàn):

// 異步任務(wù)隊(duì)列 
const queue = [] 
// 隊(duì)列任務(wù)執(zhí)行完后執(zhí)行的回調(diào)函數(shù)隊(duì)列 
const postFlushCbs = [] 
function queueJob(job) { 
  if (!queue.includes(job)) { 
    queue.push(job) 
    queueFlush() 
  } 
} 
function queuePostFlushCb(cb) { 
  if (!isArray(cb)) { 
    postFlushCbs.push(cb) 
  } 
  else { 
    // 如果是數(shù)組,把它拍平成一維 
    postFlushCbs.push(...cb) 
  } 
  queueFlush() 
} 

Vue.js 內(nèi)部維護(hù)了一個(gè) queue 數(shù)組和一個(gè) postFlushCbs 數(shù)組,其中 queue 數(shù)組用作異步任務(wù)隊(duì)列, postFlushCbs 數(shù)組用作異步任務(wù)隊(duì)列執(zhí)行完畢后的回調(diào)函數(shù)隊(duì)列。

執(zhí)行 queueJob 時(shí)會(huì)把這個(gè)任務(wù) job 添加到 queue 的隊(duì)尾,而執(zhí)行 queuePostFlushCb 時(shí),會(huì)把這個(gè) cb 回調(diào)函數(shù)添加到 postFlushCbs 的隊(duì)尾。它們?cè)谔砑油戤吅蠖紙?zhí)行了 queueFlush 函數(shù),我們接著看它的實(shí)現(xiàn):

const p = Promise.resolve() 
// 異步任務(wù)隊(duì)列是否正在執(zhí)行 
let isFlushing = false 
// 異步任務(wù)隊(duì)列是否等待執(zhí)行 
let isFlushPending = false 
function nextTick(fn) { 
  return fn ? p.then(fn) : p 
} 
function queueFlush() { 
  if (!isFlushing && !isFlushPending) { 
    isFlushPending = true 
    nextTick(flushJobs) 
  } 
} 

可以看到,Vue.js 內(nèi)部還維護(hù)了 isFlushing 和 isFlushPending 變量,用來控制異步任務(wù)的刷新邏輯。

在 queueFlush 首次執(zhí)行時(shí),isFlushing 和 isFlushPending 都是 false,此時(shí)會(huì)把 isFlushPending 設(shè)置為 true,并且調(diào)用 nextTick(flushJobs) 去執(zhí)行隊(duì)列里的任務(wù)。

因?yàn)?isFlushPending 的控制,這使得即使多次執(zhí)行 queueFlush,也不會(huì)多次去執(zhí)行 flushJobs。另外 nextTick 在 Vue.js 3.0 中的實(shí)現(xiàn)也是非常簡單,通過 Promise.resolve().then 去異步執(zhí)行 flushJobs。

因?yàn)?JavaScript 是單線程執(zhí)行的,這樣的異步設(shè)計(jì)使你在一個(gè) Tick 內(nèi),可以多次執(zhí)行 queueJob 或者 queuePostFlushCb 去添加任務(wù),也可以保證在宏任務(wù)執(zhí)行完畢后的微任務(wù)階段執(zhí)行一次 flushJobs。

異步任務(wù)隊(duì)列的執(zhí)行

創(chuàng)建完任務(wù)隊(duì)列后,接下來要異步執(zhí)行這個(gè)隊(duì)列,我們來看一下 flushJobs 的實(shí)現(xiàn):

const getId = (job) => (job.id == null ? Infinity : job.id) 
function flushJobs(seen) { 
  isFlushPending = false 
  isFlushing = true 
  let job 
  if ((process.env.NODE_ENV !== 'production')) { 
    seen = seen || new Map() 
  } 
  // 組件的更新是先父后子 
  // 如果一個(gè)組件在父組件更新過程中卸載,它自身的更新應(yīng)該被跳過 
  queue.sort((a, b) => getId(a) - getId(b)) 
  while ((job = queue.shift()) !== undefined) { 
    if (job === null) { 
      continue 
    } 
    if ((process.env.NODE_ENV !== 'production')) { 
      checkRecursiveUpdates(seen, job) 
    } 
    callWithErrorHandling(job, null, 14 /* SCHEDULER */) 
  } 
  flushPostFlushCbs(seen) 
  isFlushing = false 
  // 一些 postFlushCb 執(zhí)行過程中會(huì)再次添加異步任務(wù),遞歸 flushJobs 會(huì)把它們都執(zhí)行完畢 
  if (queue.length || postFlushCbs.length) { 
    flushJobs(seen) 
  } 
} 

可以看到,flushJobs 函數(shù)開始執(zhí)行的時(shí)候,會(huì)把 isFlushPending 重置為 false,把 isFlushing 設(shè)置為 true 來表示正在執(zhí)行異步任務(wù)隊(duì)列。

對(duì)于異步任務(wù)隊(duì)列 queue,在遍歷執(zhí)行它們前會(huì)先對(duì)它們做一次從小到大的排序,這是因?yàn)閮蓚€(gè)主要原因:

  • 我們創(chuàng)建組件的過程是由父到子,所以創(chuàng)建組件副作用渲染函數(shù)也是先父后子,父組件的副作用渲染函數(shù)的 effect id 是小于子組件的,每次更新組件也是通過 queueJob 把 effect 推入異步任務(wù)隊(duì)列 queue 中的。所以為了保證先更新父組再更新子組件,要對(duì) queue 做從小到大的排序。
  • 如果一個(gè)組件在父組件更新過程中被卸載,它自身的更新應(yīng)該被跳過。所以也應(yīng)該要保證先更新父組件再更新子組件,要對(duì) queue 做從小到大的排序。

接下來,就是遍歷這個(gè) queue,依次執(zhí)行隊(duì)列中的任務(wù)了,在遍歷過程中,注意有一個(gè) checkRecursiveUpdates 的邏輯,它是用來在非生產(chǎn)環(huán)境下檢測(cè)是否有循環(huán)更新的,它的作用我們稍后會(huì)提。

遍歷完 queue 后,又會(huì)進(jìn)一步執(zhí)行 flushPostFlushCbs 方法去遍歷執(zhí)行所有推入到 postFlushCbs 的回調(diào)函數(shù):

function flushPostFlushCbs(seen) { 
  if (postFlushCbs.length) { 
    // 拷貝副本 
    const cbs = [...new Set(postFlushCbs)] 
    postFlushCbs.length = 0 
    if ((process.env.NODE_ENV !== 'production')) { 
      seen = seen || new Map() 
    } 
    for (let i = 0; i < cbs.length; i++) { 
      if ((process.env.NODE_ENV !== 'production')) {                                                       
        checkRecursiveUpdates(seen, cbs[i]) 
      } 
      cbs[i]() 
    } 
  } 
} 

注意這里遍歷前會(huì)通過 const cbs = [...new Set(postFlushCbs)] 拷貝一個(gè) postFlushCbs 的副本,這是因?yàn)樵诒闅v的過程中,可能某些回調(diào)函數(shù)的執(zhí)行會(huì)再次修改 postFlushCbs,所以拷貝一個(gè)副本循環(huán)遍歷則不會(huì)受到 postFlushCbs 修改的影響。

遍歷完 postFlushCbs 后,會(huì)重置 isFlushing 為 false,因?yàn)橐恍?postFlushCb 執(zhí)行過程中可能會(huì)再次添加異步任務(wù),所以需要繼續(xù)判斷如果 queue 或者 postFlushCbs 隊(duì)列中還存在任務(wù),則遞歸執(zhí)行 flushJobs 把它們都執(zhí)行完畢。

檢測(cè)循環(huán)更新

前面我們提到了,在遍歷執(zhí)行異步任務(wù)和回調(diào)函數(shù)的過程中,都會(huì)在非生產(chǎn)環(huán)境下執(zhí)行 checkRecursiveUpdates 檢測(cè)是否有循環(huán)更新,它是用來解決什么問題的呢?

我們把之前的例子改寫一下:

import { reactive, watch } from 'vue' 
const state = reactive({ count: 0 }) 
watch(() => state.count, (count, prevCount) => { 
  state.count++ 
  console.log(count) 
}) 
state.count++ 

如果你去跑這個(gè)示例,你會(huì)在控制臺(tái)看到輸出了 101 次值,然后報(bào)了錯(cuò)誤: Maximum recursive updates exceeded 。這是因?yàn)槲覀冊(cè)?watcher 的回調(diào)函數(shù)里更新了數(shù)據(jù),這樣會(huì)再一次進(jìn)入回調(diào)函數(shù),如果我們不加任何控制,那么回調(diào)函數(shù)會(huì)一直執(zhí)行,直到把內(nèi)存耗盡造成瀏覽器假死。

為了避免這種情況,Vue.js 實(shí)現(xiàn)了 checkRecursiveUpdates 方法:

const RECURSION_LIMIT = 100 
function checkRecursiveUpdates(seen, fn) { 
  if (!seen.has(fn)) { 
    seen.set(fn, 1) 
  } 
  else { 
    const count = seen.get(fn) 
    if (count > RECURSION_LIMIT) { 
      throw new Error('Maximum recursive updates exceeded. ' + 
        "You may have code that is mutating state in your component's " + 
        'render function or updated hook or watcher source function.') 
    } 
    else { 
      seen.set(fn, count + 1) 
    } 
  } 
} 

通過前面的代碼,我們知道 flushJobs 一開始便創(chuàng)建了 seen,它是一個(gè) Map 對(duì)象,然后在 checkRecursiveUpdates 的時(shí)候會(huì)把任務(wù)添加到 seen 中,記錄引用計(jì)數(shù) count,初始值為 1,如果 postFlushCbs 再次添加了相同的任務(wù),則引用計(jì)數(shù) count 加 1,如果 count 大于我們定義的限制 100 ,則說明一直在添加這個(gè)相同的任務(wù)并超過了 100 次。那么,Vue.js 會(huì)拋出這個(gè)錯(cuò)誤,因?yàn)樵谡5氖褂弥校粦?yīng)該出現(xiàn)這種情況,而我們上述的錯(cuò)誤示例就會(huì)觸發(fā)這種報(bào)錯(cuò)邏輯。

優(yōu)化:只用一個(gè)變量

到這里,異步隊(duì)列的設(shè)計(jì)就介紹完畢了,你可能會(huì)對(duì) isFlushPending 和 isFlushing 有些疑問,為什么需要兩個(gè)變量來控制呢?

從語義上來看,isFlushPending 用于判斷是否在等待 nextTick 執(zhí)行 flushJobs,而 isFlushing 是判斷是否正在執(zhí)行任務(wù)隊(duì)列。

從功能上來看,它們的作用是為了確保以下兩點(diǎn):

  • 在一個(gè) Tick 內(nèi)可以多次添加任務(wù)到隊(duì)列中,但是任務(wù)隊(duì)列會(huì)在 nextTick 后執(zhí)行;
  • 在執(zhí)行任務(wù)隊(duì)列的過程中,也可以添加新的任務(wù)到隊(duì)列中,并且在當(dāng)前 Tick 去執(zhí)行剩余的任務(wù)隊(duì)列。

但實(shí)際上,這里我們可以進(jìn)行優(yōu)化。在我看來,這里用一個(gè)變量就足夠了,我們來稍微修改一下源碼:

function queueFlush() { 
  if (!isFlushing) { 
    isFlushing = true 
    nextTick(flushJobs) 
  } 
} 
function flushJobs(seen) { 
  let job 
  if ((process.env.NODE_ENV !== 'production')) { 
    seen = seen || new Map() 
  } 
  queue.sort((a, b) => getId(a) - getId(b)) 
  while ((job = queue.shift()) !== undefined) { 
    if (job === null) { 
      continue 
    } 
    if ((process.env.NODE_ENV !== 'production')) { 
      checkRecursiveUpdates(seen, job) 
    } 
    callWithErrorHandling(job, null, 14 /* SCHEDULER */) 
  } 
  flushPostFlushCbs(seen) 
  if (queue.length || postFlushCbs.length) { 
    flushJobs(seen) 
  } 
  isFlushing = false 
} 

可以看到,我們只需要一個(gè) isFlushing 來控制就可以實(shí)現(xiàn)相同的功能了。在執(zhí)行 queueFlush 的時(shí)候,判斷 isFlushing 為 false,則把它設(shè)置為 true,然后 nextTick 會(huì)執(zhí)行 flushJobs。在 flushJobs 函數(shù)執(zhí)行完成的最后,也就是所有的任務(wù)(包括后添加的)都執(zhí)行完畢,再設(shè)置 isFlushing 為 false。

了解完 watch API 和異步任務(wù)隊(duì)列的設(shè)計(jì)后,我們?cè)賮韺W(xué)習(xí)偵聽器提供的另一個(gè) API—— watchEffect API。

watchEffect

watchEffect API 的作用是注冊(cè)一個(gè)副作用函數(shù),副作用函數(shù)內(nèi)部可以訪問到響應(yīng)式對(duì)象,當(dāng)內(nèi)部響應(yīng)式對(duì)象變化后再立即執(zhí)行這個(gè)函數(shù)。

可以先來看一個(gè)示例:

import { ref, watchEffect } from 'vue' 
const count = ref(0) 
watchEffect(() => console.log(count.value)) 
count.value++ 

它的結(jié)果是依次輸出 0 和 1。

watchEffect 和前面的 watch API 有哪些不同呢?主要有三點(diǎn):

  • 偵聽的源不同 。 watch API 可以偵聽一個(gè)或多個(gè)響應(yīng)式對(duì)象,也可以偵聽一個(gè) getter 函數(shù),而 watchEffect API 偵聽的是一個(gè)普通函數(shù),只要內(nèi)部訪問了響應(yīng)式對(duì)象即可,這個(gè)函數(shù)并不需要返回響應(yīng)式對(duì)象。
  • 沒有回調(diào)函數(shù) 。 watchEffect API 沒有回調(diào)函數(shù),副作用函數(shù)的內(nèi)部響應(yīng)式對(duì)象發(fā)生變化后,會(huì)再次執(zhí)行這個(gè)副作用函數(shù)。
  • 立即執(zhí)行 。 watchEffect API 在創(chuàng)建好 watcher 后,會(huì)立刻執(zhí)行它的副作用函數(shù),而 watch API 需要配置 immediate 為 true,才會(huì)立即執(zhí)行回調(diào)函數(shù)。

對(duì) watchEffect API 有大體了解后,我們來看一下在我整理的 watchEffect 場(chǎng)景下, doWatch 函數(shù)的簡化版實(shí)現(xiàn):

function watchEffect(effect, options) { 
  return doWatch(effect, null, options); 
} 
function doWatch(source, cb, { immediate, deep, flush, onTrack, onTrigger } = EMPTY_OBJ) { 
  instance = currentInstance; 
  let getter; 
  if (isFunction(source)) { 
    getter = () => { 
      if (instance && instance.isUnmounted) { 
        return; 
      } 
       // 執(zhí)行清理函數(shù) 
      if (cleanup) { 
        cleanup(); 
      } 
      // 執(zhí)行 source 函數(shù),傳入 onInvalidate 作為參數(shù) 
      return callWithErrorHandling(source, instance, 3 /* WATCH_CALLBACK */, [onInvalidate]); 
    }; 
  } 
  let cleanup; 
  const onInvalidate = (fn) => { 
    cleanup = runner.options.onStop = () => { 
      callWithErrorHandling(fn, instance, 4 /* WATCH_CLEANUP */); 
    }; 
  }; 
  let scheduler; 
  // 創(chuàng)建 scheduler 
  if (flush === 'sync') { 
    scheduler = invoke; 
  } 
  else if (flush === 'pre') { 
    scheduler = job => { 
      if (!instance || instance.isMounted) { 
        queueJob(job); 
      } 
      else { 
        job(); 
      } 
    }; 
  } 
  else { 
    scheduler = job => queuePostRenderEffect(job, instance && instance.suspense); 
  } 
  // 創(chuàng)建 runner 
  const runner = effect(getter, { 
    lazy: true, 
    computed: true, 
    onTrack, 
    onTrigger, 
    scheduler 
  }); 
  recordInstanceBoundEffect(runner); 
   
  // 立即執(zhí)行 runner 
  runner(); 
   
  // 返回銷毀函數(shù) 
  return () => { 
    stop(runner); 
    if (instance) { 
      remove(instance.effects, runner); 
    } 
  }; 
} 

可以看到,getter 函數(shù)就是對(duì) source 函數(shù)的簡單封裝,它會(huì)先判斷組件實(shí)例是否已經(jīng)銷毀,然后每次執(zhí)行 source 函數(shù)前執(zhí)行 cleanup 清理函數(shù)。

watchEffect 內(nèi)部創(chuàng)建的 runner 對(duì)應(yīng)的 scheduler 對(duì)象就是 scheduler 函數(shù)本身,這樣它再次執(zhí)行時(shí),就會(huì)執(zhí)行這個(gè) scheduler 函數(shù),并且傳入 runner 函數(shù)作為參數(shù),其實(shí)就是按照一定的調(diào)度方式去執(zhí)行基于 source 封裝的 getter 函數(shù)。

創(chuàng)建完 runner 后就立刻執(zhí)行了 runner,其實(shí)就是內(nèi)部同步執(zhí)行了基于 source 封裝的 getter 函數(shù)。

在執(zhí)行 source 函數(shù)的時(shí)候,會(huì)傳入一個(gè) onInvalidate 函數(shù)作為參數(shù),接下來我們就來分析它的作用。

注冊(cè)無效回調(diào)函數(shù)

有些時(shí)候,watchEffect 會(huì)注冊(cè)一個(gè)副作用函數(shù),在函數(shù)內(nèi)部可以做一些異步操作,但是當(dāng)這個(gè) watcher 停止后,如果我們想去對(duì)這個(gè)異步操作做一些額外事情(比如取消這個(gè)異步操作),我們可以通過 onInvalidate 參數(shù)注冊(cè)一個(gè)無效函數(shù)。

import {ref, watchEffect } from 'vue' 
const id = ref(0) 
watchEffect(onInvalidate => { 
  // 執(zhí)行異步操作 
  const token = performAsyncOperation(id.value) 
  onInvalidate(() => { 
    // 如果 id 發(fā)生變化或者 watcher 停止了,則執(zhí)行邏輯取消前面的異步操作 
    token.cancel() 
  }) 
}) 

我們利用 watchEffect 注冊(cè)了一個(gè)副作用函數(shù),它有一個(gè) onInvalidate 參數(shù)。在這個(gè)函數(shù)內(nèi)部通過 performAsyncOperation 執(zhí)行某些異步操作,并且訪問了 id 這個(gè)響應(yīng)式對(duì)象,然后通過 onInvalidate 注冊(cè)了一個(gè)回調(diào)函數(shù)。

如果 id 發(fā)生變化或者 watcher 停止了,這個(gè)回調(diào)函數(shù)將會(huì)執(zhí)行,然后執(zhí)行 token.cancel 取消之前的異步操作。

我們來回顧 onInvalidate 在 doWatch 中的實(shí)現(xiàn):

const onInvalidate = (fn) => { 
  cleanup = runner.options.onStop = () => { 
    callWithErrorHandling(fn, instance, 4 /* WATCH_CLEANUP */); 
  }; 
}; 

實(shí)際上,當(dāng)你執(zhí)行 onInvalidate 的時(shí)候,就是注冊(cè)了一個(gè) cleanup 和 runner 的 onStop 方法,這個(gè)方法內(nèi)部會(huì)執(zhí)行 fn,也就是你注冊(cè)的無效回調(diào)函數(shù)。

也就是說當(dāng)響應(yīng)式數(shù)據(jù)發(fā)生變化,會(huì)執(zhí)行 cleanup 方法,當(dāng) watcher 被停止,會(huì)執(zhí)行 onStop 方法,這兩者都會(huì)執(zhí)行注冊(cè)的無效回調(diào)函數(shù) fn。

通過這種方式,Vue.js 就很好地實(shí)現(xiàn)了 watcher 注冊(cè)無效回調(diào)函數(shù)的需求。

總結(jié)

偵聽器的內(nèi)部設(shè)計(jì)很巧妙,我們可以偵聽響應(yīng)式數(shù)據(jù)的變化,內(nèi)部創(chuàng)建 effect runner,首次執(zhí)行 runner 做依賴收集,然后在數(shù)據(jù)發(fā)生變化后,以某種調(diào)度方式去執(zhí)行回調(diào)函數(shù)。

相比于計(jì)算屬性,偵聽器更適合用于在數(shù)據(jù)變化后執(zhí)行某段邏輯的場(chǎng)景,而計(jì)算屬性則用于一個(gè)數(shù)據(jù)依賴另外一些數(shù)據(jù)計(jì)算而來的場(chǎng)景。

以上就是深入了解Vue3中偵聽器watcher的實(shí)現(xiàn)原理的詳細(xì)內(nèi)容,更多關(guān)于Vue3 偵聽器watcher的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue實(shí)現(xiàn)導(dǎo)出Excel表格文件提示“文件已損壞無法打開”的解決方法

    Vue實(shí)現(xiàn)導(dǎo)出Excel表格文件提示“文件已損壞無法打開”的解決方法

    xlsx用于讀取解析和寫入Excel文件的JavaScript庫,它提供了一系列的API處理Excel文件,使用該庫,可以將數(shù)據(jù)轉(zhuǎn)換Excel文件并下載到本地,適用于在前端直接生成Excel文件,這篇文章主要介紹了Vue實(shí)現(xiàn)導(dǎo)出Excel表格,提示文件已損壞,無法打開的解決方法,需要的朋友可以參考下
    2024-01-01
  • Vue.js監(jiān)聽select2的值改變進(jìn)行查詢方式

    Vue.js監(jiān)聽select2的值改變進(jìn)行查詢方式

    這篇文章主要介紹了Vue.js監(jiān)聽select2的值改變進(jìn)行查詢方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue 注冊(cè)組件的使用詳解

    vue 注冊(cè)組件的使用詳解

    Vue.js的組件的使用有3個(gè)步驟:創(chuàng)建組件構(gòu)造器、注冊(cè)組件和使用組件。這篇文章主要介紹了vue 注冊(cè)組件的使用,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2018-05-05
  • 詳解vue axios二次封裝

    詳解vue axios二次封裝

    這篇文章給大家分享了vue axios二次封裝的相關(guān)知識(shí)點(diǎn)等內(nèi)容以及實(shí)例代碼,有興趣的朋友可以參考學(xué)習(xí)下。
    2018-07-07
  • vue模態(tài)框?qū)崿F(xiàn)動(dòng)態(tài)錨點(diǎn)

    vue模態(tài)框?qū)崿F(xiàn)動(dòng)態(tài)錨點(diǎn)

    這篇文章主要為大家詳細(xì)介紹了vue模態(tài)框?qū)崿F(xiàn)動(dòng)態(tài)錨點(diǎn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 詳解Vue.js v-for不支持IE9的解決方法

    詳解Vue.js v-for不支持IE9的解決方法

    這篇文章主要介紹了詳解Vue.js v-for不支持IE9的解決方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • 使用 Element UI Table 的 slot-scope方法

    使用 Element UI Table 的 slot-scope方法

    這篇文章主要介紹了使用 Element UI Table 的 slot-scope方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • vue使用WEB自帶TTS實(shí)現(xiàn)語音文字互轉(zhuǎn)的操作方法

    vue使用WEB自帶TTS實(shí)現(xiàn)語音文字互轉(zhuǎn)的操作方法

    這篇文章主要介紹了vue使用WEB自帶TTS實(shí)現(xiàn)語音文字互轉(zhuǎn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2024-01-01
  • vue2使用ts?vue-class-component的過程

    vue2使用ts?vue-class-component的過程

    vue-property-decorator?是一個(gè)?Vue.js?的裝飾器庫,它提供了一些裝飾器來讓你在?Vue?組件中定義屬性、計(jì)算屬性、方法、事件等,本文給大家介紹vue2使用ts?vue-class-component的相關(guān)知識(shí),感興趣的朋友一起看看吧
    2023-11-11
  • vue.js中引入vuex儲(chǔ)存接口數(shù)據(jù)及調(diào)用的詳細(xì)流程

    vue.js中引入vuex儲(chǔ)存接口數(shù)據(jù)及調(diào)用的詳細(xì)流程

    這篇文章主要給大家介紹了關(guān)于在vue.js中引入vuex儲(chǔ)存接口數(shù)據(jù)及調(diào)用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-12-12

最新評(píng)論

在线国产日韩欧美视频| av亚洲中文天堂字幕网| 国产极品精品免费视频| 国产97在线视频观看| 亚洲免费成人a v| 亚洲图库另类图片区| 馒头大胆亚洲一区二区| 日本黄色三级高清视频| 久久久久久久久久久免费女人| 经典亚洲伊人第一页| 丝袜国产专区在线观看| 久久久超爽一二三av| 女警官打开双腿沦为性奴| 欧美偷拍亚洲一区二区| 精品乱子伦一区二区三区免费播| 久久精品国产23696| 播放日本一区二区三区电影| 亚洲精品 日韩电影| www天堂在线久久| gav成人免费播放| 亚洲黄色av网站免费播放| 五十路熟女av天堂| 韩国AV无码不卡在线播放| 东京热男人的av天堂| 天美传媒mv视频在线观看| 国产免费av一区二区凹凸四季| 精品区一区二区三区四区人妻| av一本二本在线观看| 2017亚洲男人天堂| 91免费观看国产免费| av在线shipin| 五月激情婷婷久久综合网| 清纯美女在线观看国产| 国产又色又刺激在线视频 | 2025年人妻中文字幕乱码在线| 国产第一美女一区二区三区四区| 亚洲中文字幕国产日韩| 免费av岛国天堂网站| 青青青青青青草国产| 午夜大尺度无码福利视频| 人妻av无码专区久久绿巨人| 免费十精品十国产网站| 精内国产乱码久久久久久| 夜夜骑夜夜操夜夜奸| 999久久久久999| 强行扒开双腿猛烈进入免费版| 91九色porny蝌蚪国产成人| 熟女视频一区,二区,三区| 天天色天天操天天透| 亚洲图片偷拍自拍区| av在线免费资源站| 在线视频国产欧美日韩| 少妇高潮一区二区三区| 青青青青青操视频在线观看| 少妇ww搡性bbb91| 亚洲日本一区二区三区| 国产精品久久综合久久| 亚洲中文字字幕乱码| 夏目彩春在线中文字幕| 成人30分钟免费视频| 国产极品美女久久久久久| 91www一区二区三区| 超pen在线观看视频公开97| 换爱交换乱高清大片| 丝袜肉丝一区二区三区四区在线| 初美沙希中文字幕在线 | 一区二区久久成人网| 香蕉91一区二区三区| 欧美黑人巨大性xxxxx猛交| 亚洲精品午夜aaa久久| 免费啪啪啪在线观看视频| 国产使劲操在线播放| 国产精品成人xxxx| 日韩伦理短片在线观看| 欧美日韩一区二区电影在线观看| 亚洲综合图片20p| 国产一区二区久久久裸臀| 自拍偷拍 国产资源| 男人操女人的逼免费视频| 成人H精品动漫在线无码播放| 91小伙伴中女熟女高潮| 91精品一区二区三区站长推荐| 99精品一区二区三区的区| 91老师蜜桃臀大屁股| 粉嫩欧美美人妻小视频| 521精品视频在线观看| 久久久久久久99精品| 亚洲狠狠婷婷综合久久app| 中文字幕一区二区三区人妻大片| 亚洲欧美福利在线观看| 久久综合老鸭窝色综合久久| 绝顶痉挛大潮喷高潮无码| 亚洲成人三级在线播放| 中国无遮挡白丝袜二区精品| 青青在线视频性感少妇和隔壁黑丝 | 精品久久久久久高潮| 经典av尤物一区二区| 美女吃鸡巴操逼高潮视频| 天天日天天透天天操| 久久精品视频一区二区三区四区 | 日韩精品一区二区三区在线播放| 伊人情人综合成人久久网小说 | 美女视频福利免费看| 99久久99一区二区三区| 91国产在线免费播放| 日韩一区二区三区三州| 亚洲av成人免费网站| 久久精品亚洲国产av香蕉| 欧美一级视频一区二区| 熟妇一区二区三区高清版| 白白操白白色在线免费视频| 日韩三级黄色片网站| yy96视频在线观看| 亚洲在线一区二区欧美| 1024久久国产精品| 精品一区二区亚洲欧美| 1区2区3区4区视频在线观看| 久久一区二区三区人妻欧美| 玖玖一区二区在线观看| 男大肉棒猛烈插女免费视频| 免费手机黄页网址大全| 天码人妻一区二区三区在线看| AV无码一区二区三区不卡| av中文字幕电影在线看| 1000部国产精品成人观看视频| 99热色原网这里只有精品| 久碰精品少妇中文字幕av| 国产使劲操在线播放| 色吉吉影音天天干天天操| 欧美精品亚洲精品日韩在线| 97国产精品97久久| 伊人精品福利综合导航| 天天操夜夜操天天操天天操| yy96视频在线观看| 亚洲 中文 自拍 另类 欧美| 国产麻豆精品人妻av| 夜色撩人久久7777| 欧美专区第八页一区在线播放| 黄色成年网站午夜在线观看| 自拍偷拍日韩欧美一区二区| 91av精品视频在线| 日本一区美女福利视频| av黄色成人在线观看| 久久精品国产亚洲精品166m| 中文字幕午夜免费福利视频| 91国内精品自线在拍白富美| 91天堂天天日天天操| 天天操天天爽天天干| 在线观看国产网站资源| 涩涩的视频在线观看视频| 欧美日韩人妻久久精品高清国产| 婷婷五月亚洲综合在线| 亚洲自拍偷拍精品网| 国产av国片精品一区二区| 97人妻色免费视频| 久碰精品少妇中文字幕av| 日美女屁股黄邑视频| okirakuhuhu在线观看| 宅男噜噜噜666免费观看| 日本熟女精品一区二区三区| 精彩视频99免费在线| 青青热久免费精品视频在线观看| 午夜久久香蕉电影网| 少妇与子乱在线观看| 91九色国产熟女一区二区 | 亚洲一区久久免费视频| av俺也去在线播放| 亚洲一区二区三区uij| 日韩av大胆在线观看| av成人在线观看一区| 岳太深了紧紧的中文字幕| 日韩少妇人妻精品无码专区| 国产女人被做到高潮免费视频 | 国产女孩喷水在线观看| 久草福利电影在线观看| 亚洲Av无码国产综合色区| 国产精品一区二区久久久av| 欧美另类一区二区视频| 红桃av成人在线观看| 91色九色porny| 亚洲国产精品美女在线观看| 在线免费观看视频一二区| 亚洲区欧美区另类最新章节| av在线免费中文字幕| 国产精品成人xxxx| 91精品综合久久久久3d动漫| 人妻自拍视频中国大陆| 99久久久无码国产精品性出奶水 | jiuse91九色视频| 亚洲福利精品福利精品福利| 青青草在观免费国产精品| 久久丁香婷婷六月天| 国产精品大陆在线2019不卡| 天天日天天玩天天摸| 国产黄色高清资源在线免费观看| 在线免费91激情四射| 成年人中文字幕在线观看| 午夜美女福利小视频| 精品成人午夜免费看| 亚洲护士一区二区三区| 在线视频自拍第三页| av中文字幕在线观看第三页| 亚洲偷自拍高清视频| 午夜毛片不卡免费观看视频| 亚洲一区二区三区uij| 91九色porny国产蝌蚪视频| 大黑人性xxxxbbbb| 久久免看30视频口爆视频| mm131美女午夜爽爽爽| 99精品视频在线观看免费播放| 韩国爱爱视频中文字幕| 亚洲精品国品乱码久久久久| 日本人竟这样玩学生妹| 在线观看成人国产电影| 制丝袜业一区二区三区| 亚洲精品国品乱码久久久久| 亚洲熟女综合色一区二区三区四区| 91高清成人在线视频| 五十路人妻熟女av一区二区| 日本av熟女在线视频| 日本18禁久久久久久| 黑人巨大精品欧美视频| 啊啊好大好爽啊啊操我啊啊视频 | 亚洲天堂av最新网址| 天天躁日日躁狠狠躁av麻豆| 亚洲成人av在线一区二区| 亚洲欧美一区二区三区电影| 亚洲最大黄 嗯色 操 啊| 少妇人妻久久久久视频黄片| 色偷偷伊人大杳蕉综合网| 亚洲av日韩高清hd| 精品乱子伦一区二区三区免费播| 一区二区视频在线观看视频在线| 护士特殊服务久久久久久久| 19一区二区三区在线播放| 在线视频精品你懂的| 午夜精品亚洲精品五月色| 最新97国产在线视频| 亚洲一区二区三区久久受| 免费男阳茎伸入女阳道视频| 欧美第一页在线免费观看视频| 欧美viboss性丰满| 欧美精产国品一二三产品区别大吗| 免费av岛国天堂网站| www久久久久久久久久久| 日韩美女搞黄视频免费| 岛国av高清在线成人在线| 一区二区三区久久中文字幕| 真实国模和老外性视频| 黄色片黄色片wyaa| 天天日天天日天天射天天干| 国产使劲操在线播放| 久久永久免费精品人妻专区| 狠狠的往里顶撞h百合| 日韩二区视频一线天婷婷五| 国产av一区2区3区| 国产精品自拍在线视频| jiujiure精品视频在线| 97超碰人人搞人人| 成人免费公开视频无毒 | 97人人模人人爽人人喊| nagger可以指黑人吗| 五月天久久激情视频| 中文字幕免费在线免费| 久久精品亚洲国产av香蕉| 久草极品美女视频在线观看| 欧美80老妇人性视频| 亚洲美女高潮喷浆视频| 久草极品美女视频在线观看| 人妻少妇一区二区三区蜜桃| 93精品视频在线观看| 国产女孩喷水在线观看| 自拍偷拍亚洲欧美在线视频| 国产精品自拍偷拍a| 国产又粗又猛又爽又黄的视频美国| 日本韩国免费福利精品| 精品人妻伦一二三区久| 中文字幕在线第一页成人| 婷婷久久久综合中文字幕| 可以免费看的www视频你懂的| 成人福利视频免费在线| 亚洲欧美激情国产综合久久久| 天天日天天日天天擦| 国产日韩一区二区在线看| 人妻丝袜精品中文字幕| 伊人成人综合开心网| 美女小视频网站在线| 亚洲 人妻 激情 中文| 中文字幕 人妻精品| 曰本无码人妻丰满熟妇啪啪| 欧美成人小视频在线免费看| 中文字幕第三十八页久久| 国产日本欧美亚洲精品视| 亚洲午夜福利中文乱码字幕| 欧亚日韩一区二区三区观看视频| 欧美伊人久久大香线蕉综合| 一区二区在线视频中文字幕| 欧美viboss性丰满| 中文字幕一区二区人妻电影冢本 | 亚洲精品亚洲人成在线导航| 亚洲高清视频在线不卡| 国产av福利网址大全| 三级等保密码要求条款| 超碰97免费人妻麻豆| 91久久综合男人天堂| 色偷偷伊人大杳蕉综合网| 国产真实灌醉下药美女av福利| 成人资源在线观看免费官网| 欧美成人综合色在线噜噜| 黄色三级网站免费下载| 在线视频国产欧美日韩| 99热99这里精品6国产| 亚洲欧美综合另类13p| 青青热久免费精品视频在线观看| 日噜噜噜夜夜噜噜噜天天噜噜噜 | 日本特级片中文字幕| 色噜噜噜噜18禁止观看| 日本高清在线不卡一区二区| 精品黑人一区二区三区久久国产| 亚洲欧美精品综合图片小说| 日本一区精品视频在线观看| 中文字幕av第1页中文字幕| 岛国免费大片在线观看| 国产刺激激情美女网站| 亚洲av一妻不如妾| 精品亚洲中文字幕av| 亚洲伊人久久精品影院一美女洗澡| 日韩一区二区三区三州| 91久久国产成人免费网站| av视屏免费在线播放| 91老熟女连续高潮对白| 在线免费观看视频一二区| 伊人情人综合成人久久网小说 | 大香蕉伊人中文字幕| 99精品免费观看视频| 天天干天天操天天爽天天摸| 玩弄人妻熟妇性色av少妇| 好吊视频—区二区三区| 天天躁日日躁狠狠躁躁欧美av| 高清成人av一区三区| 男生舔女生逼逼视频| 欧美熟妇一区二区三区仙踪林| 1区2区3区4区视频在线观看| 国产一区二区神马久久| 国产刺激激情美女网站| 黄片三级三级三级在线观看| 99re6热在线精品| 国产成人精品av网站| 欧美精品 日韩国产| 成人免费公开视频无毒| 51国产偷自视频在线播放| 丝袜美腿视频诱惑亚洲无| 精品国产污污免费网站入口自 | 五十路人妻熟女av一区二区| 2021年国产精品自拍| 亚洲精品麻豆免费在线观看| 91色秘乱一区二区三区| 人人人妻人人澡人人| 狠狠躁狠狠爱网站视频| 91精品国产麻豆国产| 一区二区三区四区视频在线播放 | 视频啪啪啪免费观看| 免费一级黄色av网站| 被大鸡吧操的好舒服视频免费 | 亚洲国产最大av综合| avjpm亚洲伊人久久| 亚洲国产欧美一区二区三区久久 | 亚洲欧美成人综合视频| 日韩精品中文字幕在线| 亚洲av自拍偷拍综合| 鸡巴操逼一级黄色气| 免费观看理论片完整版| 国产一区二区火爆视频| 美女被肏内射视频网站| 久久尻中国美女视频| 操日韩美女视频在线免费看| 精品人人人妻人人玩日产欧| rct470中文字幕在线| 天天日天天舔天天射进去| 国产日韩一区二区在线看 | 极品粉嫩小泬白浆20p主播| 婷婷久久久久深爱网| 欧美性受xx黑人性猛交| 天天日天天日天天擦| 一色桃子人妻一区二区三区| 最新的中文字幕 亚洲 | 国产熟妇一区二区三区av| 国产麻豆91在线视频| 精品久久久久久高潮| 日本少妇的秘密免费视频| 亚洲自拍偷拍综合色| 青青青艹视频在线观看| 久久农村老妇乱69系列| 中文字幕人妻被公上司喝醉在线| 一区二区三区视频,福利一区二区| 在线免费观看黄页视频| 欧美日韩亚洲国产无线码| 中文字幕在线观看国产片| 揄拍成人国产精品免费看视频| 中文字幕乱码av资源| 色婷婷久久久久swag精品| 黄色黄色黄片78在线| 日韩精品一区二区三区在线播放| 人妻少妇一区二区三区蜜桃| 国产1区,2区,3区| 日本韩国在线观看一区二区| 自拍 日韩 欧美激情| 成人av免费不卡在线观看| 毛茸茸的大外阴中国视频| 午夜精品一区二区三区更新| 综合激情网激情五月天| 国产欧美日韩第三页| 天天摸天天干天天操科普| 国产亚洲精品品视频在线| 久久免看30视频口爆视频| 中文字幕综合一区二区| 久久香蕉国产免费天天| 国产精品一二三不卡带免费视频| 国产又粗又硬又猛的毛片视频| 免费观看污视频网站| 亚洲欧美清纯唯美另类| 亚洲欧洲一区二区在线观看| 欧美香蕉人妻精品一区二区| 亚洲一区二区三区在线高清| mm131美女午夜爽爽爽| 亚洲中文精品字幕在线观看| 亚洲欧美福利在线观看| 亚洲va国产va欧美va在线| 美女操逼免费短视频下载链接| 涩涩的视频在线观看视频| 欧美专区日韩专区国产专区| 国产av福利网址大全| 人妻另类专区欧美制服| 国产亚洲视频在线二区| 国产精品国产三级麻豆| 家庭女教师中文字幕在线播放| 快点插进来操我逼啊视频| 久久精品36亚洲精品束缚| 美味人妻2在线播放| 亚洲成人av一区久久| 国产成人自拍视频播放| 午夜激情高清在线观看| 老司机福利精品免费视频一区二区| 日本五十路熟新垣里子| 天天干天天插天天谢| 青青在线视频性感少妇和隔壁黑丝 | 同居了嫂子在线播高清中文| 亚洲免费va在线播放| 久久机热/这里只有| 沙月文乃人妻侵犯中文字幕在线 | 大鸡巴操娇小玲珑的女孩逼| 国产综合高清在线观看| 激情内射在线免费观看| 91人妻人人做人人爽在线| 免费观看理论片完整版| 91九色国产熟女一区二区| 鸡巴操逼一级黄色气| 又粗又长 明星操逼小视频| 欧美老妇精品另类不卡片| 最新黄色av网站在线观看| 欧美交性又色又爽又黄麻豆| 2022精品久久久久久中文字幕| 91欧美在线免费观看| 中文字幕亚洲中文字幕| 中文字幕一区二 区二三区四区 | nagger可以指黑人吗| 66久久久久久久久久久| 亚洲一区二区三区久久午夜 | 国产午夜激情福利小视频在线| 成人区人妻精品一区二视频| 在线视频免费观看网| 成人免费做爰高潮视频| 亚洲精品高清自拍av| 亚洲国产精品黑丝美女| 又大又湿又爽又紧A视频| 99热99这里精品6国产| 亚洲精品国品乱码久久久久| 清纯美女在线观看国产| 九一传媒制片厂视频在线免费观看| 91精品国产黑色丝袜| 天天夜天天日天天日| 91精品综合久久久久3d动漫| 天天爽夜夜爽人人爽QC| 天天艹天天干天天操| 动色av一区二区三区| 亚洲综合色在线免费观看| 人妻最新视频在线免费观看| 78色精品一区二区三区| 少妇一区二区三区久久久| 国产中文字幕四区在线观看| 视频一区二区在线免费播放| 日美女屁股黄邑视频| 免费看国产av网站| 5528327男人天堂| 天天通天天透天天插| 日本一本午夜在线播放| 91高清成人在线视频| 国产精品人妻熟女毛片av久| 一区二区三区四区五区性感视频| 55夜色66夜色国产精品站| 做爰视频毛片下载蜜桃视频1| 亚洲va国产va欧美va在线| 久久精品在线观看一区二区| 91色九色porny| 黄色视频在线观看高清无码 | 蜜桃视频在线欧美一区| 亚洲一区制服丝袜美腿| 青青擦在线视频国产在线| 亚洲欧美综合另类13p| 中文字幕在线观看极品视频| 91欧美在线免费观看| 免费成人va在线观看| 91‖亚洲‖国产熟女| 欧美视频一区免费在线| 水蜜桃国产一区二区三区| 欧美老妇精品另类不卡片| www天堂在线久久| 视频一区二区综合精品| 韩国男女黄色在线观看| 亚洲日产av一区二区在线| av视屏免费在线播放| 亚洲中文字幕人妻一区| 国产精品污污污久久| 久久久久久国产精品| 超鹏97历史在线观看| 天天日夜夜操天天摸| 亚洲图库另类图片区| 91人妻精品一区二区久久| 日本女人一级免费片| 97精品人妻一区二区三区精品| 日韩特级黄片高清在线看| 欧美综合婷婷欧美综合| gav成人免费播放| 亚洲午夜电影之麻豆| 农村胖女人操逼视频| 国产精品大陆在线2019不卡| 成人在线欧美日韩国产| 中文字幕,亚洲人妻| 国产午夜男女爽爽爽爽爽视频| 在线观看免费视频色97| 国产福利小视频二区| av手机在线观播放网站| 国产成人精品午夜福利训2021| 国产精品欧美日韩区二区 | www日韩毛片av| 久草视频在线免播放| 欧美成人综合色在线噜噜| 午夜精品一区二区三区福利视频| 午夜av一区二区三区| 97年大学生大白天操逼| 国产三级影院在线观看| 蜜桃专区一区二区在线观看| 在线免费观看视频一二区| 一区二区熟女人妻视频| 91在线免费观看成人| 一级黄片久久久久久久久| 亚洲美女自偷自拍11页| 天天操夜夜操天天操天天操| 丝袜肉丝一区二区三区四区在线| 98精产国品一二三产区区别| 国产精品视频一区在线播放| 天天日天天敢天天干| 日本女人一级免费片| av手机在线免费观看日韩av| 天堂av中文在线最新版| 成人av天堂丝袜在线观看| 亚洲中文字幕人妻一区| 国产日韩欧美视频在线导航| 精品美女久久久久久| 国产+亚洲+欧美+另类| 成年美女黄网站18禁久久| 国产熟妇乱妇熟色T区| 伊人开心婷婷国产av| 欧美日韩熟女一区二区三区| 天天干天天操天天摸天天射| 成年人午夜黄片视频资源| 国产精品人久久久久久| 国产一区av澳门在线观看| 亚洲 中文字幕在线 日韩| 熟妇一区二区三区高清版| 青青草国内在线视频精选| 久久久久国产成人精品亚洲午夜| 动漫av网站18禁| 97欧洲一区二区精品免费| okirakuhuhu在线观看| 888欧美视频在线| 天天射夜夜操综合网| 欧美色婷婷综合在线| 80电影天堂网官网| 好男人视频在线免费观看网站| 综合国产成人在线观看| 秋霞午夜av福利经典影视| rct470中文字幕在线| 午夜精品一区二区三区更新| 蜜桃专区一区二区在线观看| 精品国产污污免费网站入口自| 日韩剧情片电影在线收看| 一区二区三区的久久的蜜桃的视频| 亚洲国产精品中文字幕网站| 天天摸天天日天天操| 亚洲 欧美 精品 激情 偷拍| 日韩欧美国产一区ab| 亚洲一区二区三区精品视频在线 | 国产中文精品在线观看| 国产一区二区欧美三区| 早川濑里奈av黑人番号| 亚洲另类图片蜜臀av| 自拍偷拍日韩欧美一区二区| 丰满少妇翘臀后进式| 中文字幕在线第一页成人| 青青青aaaa免费| 免费男阳茎伸入女阳道视频| 天天操天天干天天插| 青青青青视频在线播放| 亚洲老熟妇日本老妇| 直接观看免费黄网站| 天天躁日日躁狠狠躁躁欧美av | 天天色天天舔天天射天天爽| 岛国黄色大片在线观看| 亚洲免费福利一区二区三区| 亚洲一级av无码一级久久精品 | 青青色国产视频在线| 中国无遮挡白丝袜二区精品| 日本在线一区二区不卡视频| 国产欧美精品一区二区高清| 一区二区三区激情在线| 欧美中国日韩久久精品| 亚洲中文字字幕乱码| 男人的天堂一区二区在线观看| 亚洲偷自拍高清视频| 色av色婷婷人妻久久久精品高清| 毛茸茸的大外阴中国视频| 91色老99久久九九爱精品| 亚洲中文精品人人免费| 青青色国产视频在线| 国产一级麻豆精品免费| 一级黄色av在线观看| 天天操天天操天天碰| 超碰在线中文字幕一区二区| 亚洲高清一区二区三区视频在线| 视频二区在线视频观看| 黑人性生活视频免费看| weyvv5国产成人精品的视频| 日韩精品一区二区三区在线播放| 成人在线欧美日韩国产| xxx日本hd高清| av网站色偷偷婷婷网男人的天堂| 国产a级毛久久久久精品| 青青社区2国产视频| 青青擦在线视频国产在线| 日本后入视频在线观看| 欧美偷拍亚洲一区二区| 东京热男人的av天堂| 桃色视频在线观看一区二区 | 日韩二区视频一线天婷婷五| 人人超碰国字幕观看97| 制丝袜业一区二区三区| 国产普通话插插视频| 国产福利小视频大全| 欧美激情电影免费在线| 午夜在线观看岛国av,com| 欧美日韩一区二区电影在线观看| 国产精品久久久久久久精品视频| 狠狠地躁夜夜躁日日躁| 91福利视频免费在线观看| 精品老妇女久久9g国产| 久久久久国产成人精品亚洲午夜| jiujiure精品视频在线| 亚洲免费va在线播放| 中文字幕乱码av资源| 在线免费91激情四射| 在线观看av2025| 亚洲护士一区二区三区| 亚洲成人av一区在线| 蜜桃臀av蜜桃臀av| 午夜美女少妇福利视频| 日韩伦理短片在线观看| 好太好爽好想要免费| 久久久久久97三级| 这里有精品成人国产99| 日本少妇人妻xxxxx18| 亚洲一级 片内射视正片| 美女福利视频导航网站| 亚洲护士一区二区三区| 亚洲精品成人网久久久久久小说| 非洲黑人一级特黄片| 国产黑丝高跟鞋视频在线播放 | 国产综合精品久久久久蜜臀| 黄色av网站免费在线| av手机在线免费观看日韩av| 国产黄色高清资源在线免费观看| 福利视频一区二区三区筱慧| 91色老99久久九九爱精品| 福利一二三在线视频观看| 女警官打开双腿沦为性奴| 福利视频广场一区二区| 女生自摸在线观看一区二区三区| 亚洲精品久久综合久| 亚洲少妇高潮免费观看| 男人天堂色男人av| 超级福利视频在线观看| 欧美另类重口味极品在线观看| 老鸭窝日韩精品视频观看| 欧美成人黄片一区二区三区| 传媒在线播放国产精品一区| 香蕉av影视在线观看| 天天日天天日天天擦| 欧美80老妇人性视频| 在线免费观看日本片| 激情人妻校园春色亚洲欧美 | 亚洲欧美一卡二卡三卡| 最新中文字幕乱码在线| 天天日天天操天天摸天天舔| 九一传媒制片厂视频在线免费观看 | 社区自拍揄拍尻屁你懂的| 亚洲 欧美 自拍 偷拍 在线| 99热碰碰热精品a中文| 国内资源最丰富的网站| 丝袜美腿欧美另类 中文字幕| 东京热男人的av天堂| 精品久久久久久久久久久99| 精品成人午夜免费看| 国产精品国产三级国产午| 38av一区二区三区| 午夜美女福利小视频| 青青青青操在线观看免费| 亚洲精品成人网久久久久久小说 | 国产精品久久久久国产三级试频| 国产性感美女福利视频| 视频一区二区在线免费播放| 日本黄在免费看视频| 好吊视频—区二区三区| 日日摸夜夜添夜夜添毛片性色av| 青青草原网站在线观看| 福利午夜视频在线观看| 欧美日本在线观看一区二区| 亚洲在线观看中文字幕av| 国产欧美日韩第三页| 大香蕉日本伊人中文在线| 亚洲另类图片蜜臀av| 白嫩白嫩美女极品国产在线观看| 日本美女成人在线视频| 香蕉av影视在线观看| 黄色av网站免费在线| 最新国产精品拍在线观看| 天天做天天干天天操天天射| 91国内精品自线在拍白富美| 97a片免费在线观看| 又粗又硬又猛又爽又黄的| 中文字幕熟女人妻久久久| 91啪国自产中文字幕在线| 日韩中文字幕精品淫| 老熟妇xxxhd老熟女| mm131美女午夜爽爽爽| 日韩激情文学在线视频| 国产剧情演绎系列丝袜高跟| 大鸡巴插入美女黑黑的阴毛| 深夜男人福利在线观看| 天天草天天色天天干| 早川濑里奈av黑人番号| 日韩欧美中文国产在线| 91久久国产成人免费网站| 国产黄色片在线收看| 插逼视频双插洞国产操逼插洞 | 国产日韩欧美美利坚蜜臀懂色| 懂色av之国产精品| 国产精品探花熟女在线观看| 日本熟妇色熟妇在线观看| 骚货自慰被发现爆操| 韩国女主播精品视频网站| 同居了嫂子在线播高清中文| 人妻另类专区欧美制服| 人妻3p真实偷拍一二区| 日本人妻少妇18—xx| 日本熟女精品一区二区三区| 在线观看的a站 最新| 精品91高清在线观看| 瑟瑟视频在线观看免费视频| 午夜极品美女福利视频| 一区二区视频在线观看免费观看 | 亚洲精品 日韩电影| 色综合久久五月色婷婷综合| 天天操夜夜骑日日摸| 国产不卡av在线免费| 97瑟瑟超碰在线香蕉| 中文字幕人妻av在线观看| 亚洲国际青青操综合网站| 宅男噜噜噜666免费观看| 任你操视频免费在线观看| 99精品国产aⅴ在线观看 | 日本美女成人在线视频| 99精品国自产在线人| 国产三级精品三级在线不卡| 精内国产乱码久久久久久| h国产小视频福利在线观看| 香蕉av影视在线观看| 夜女神免费福利视频| 唐人色亚洲av嫩草| 日本一区美女福利视频| 99精品国产免费久久| 天天日天天添天天爽| 只有精品亚洲视频在线观看| 2022国产精品视频| 久久久久久久精品老熟妇| 中文字幕亚洲久久久| 青青青青青青草国产| 国产又粗又硬又大视频| 国产黄网站在线观看播放| 亚洲欧美清纯唯美另类| 1区2区3区4区视频在线观看| 国产福利在线视频一区| 这里只有精品双飞在线播放| 国际av大片在线免费观看| 大香蕉大香蕉在线有码 av| 亚洲狠狠婷婷综合久久app| 老司机午夜精品视频资源| 在线免费观看日本伦理| 亚洲精品欧美日韩在线播放| 人妻熟女在线一区二区| 中文字幕av第1页中文字幕| 日本精品美女在线观看| 在线免费观看日本片| 超黄超污网站在线观看| 国产亚洲国产av网站在线| 五十路息与子猛烈交尾视频| 天天躁日日躁狠狠躁躁欧美av| 亚洲综合色在线免费观看| 国产片免费观看在线观看| 精品视频国产在线观看| 一个人免费在线观看ww视频| 国产麻豆精品人妻av| 精品一区二区三区三区色爱| 久精品人妻一区二区三区 | 黄片三级三级三级在线观看| 天天色天天舔天天射天天爽| 91色网站免费在线观看| 成人亚洲精品国产精品| 一区二区三区的久久的蜜桃的视频 | 亚洲1卡2卡三卡4卡在线观看| 日韩中文字幕福利av| 在线成人日韩av电影| 97年大学生大白天操逼| 天天色天天舔天天射天天爽| 1区2区3区不卡视频| 久久久久久性虐视频| 五十路息与子猛烈交尾视频 | 中文字幕一区二 区二三区四区| 日本欧美视频在线观看三区| 日本最新一二三区不卡在线 | 亚洲精品国偷自产在线观看蜜桃| 一级黄片大鸡巴插入美女| 99婷婷在线观看视频| 同居了嫂子在线播高清中文| 亚洲一区自拍高清免费视频| 日本午夜爽爽爽爽爽视频在线观看 | 天天躁夜夜躁日日躁a麻豆| 久草视频 久草视频2| 日韩欧美亚洲熟女人妻| 成人国产影院在线观看| 中文字幕在线一区精品| 欧美精品伦理三区四区| 色婷婷久久久久swag精品| 久久久久久久一区二区三| av在线免费中文字幕| 成人国产激情自拍三区| 亚洲伊人色一综合网| 天天操天天插天天色| 国产又粗又硬又猛的毛片视频| 亚洲区美熟妇久久久久| yy96视频在线观看| 日本一二三区不卡无| 国产又粗又猛又爽又黄的视频在线| 成年午夜免费无码区| 成人H精品动漫在线无码播放| 亚洲av日韩av网站| 高潮喷水在线视频观看| 大陆精品一区二区三区久久| av成人在线观看一区| 毛片一级完整版免费| 中文字幕+中文字幕| 又黄又刺激的午夜小视频| 国产一区自拍黄视频免费观看| 亚洲福利午夜久久久精品电影网| 亚洲成人三级在线播放| 含骚鸡巴玩逼逼视频| 日韩中文字幕福利av| 亚洲欧美国产综合777| 欧美精品欧美极品欧美视频| 成年美女黄网站18禁久久| 亚洲成人av在线一区二区| 熟女视频一区,二区,三区| 这里有精品成人国产99| 日辽宁老肥女在线观看视频| 动漫美女的小穴视频| 大黑人性xxxxbbbb| 亚洲 自拍 色综合图| 天天干天天操天天玩天天射| 北条麻妃av在线免费观看| 国产乱子伦精品视频潮优女| yy6080国产在线视频| 2o22av在线视频| 激情五月婷婷免费视频| 91精品国产黑色丝袜| 成年午夜影片国产片| 天天干天天操天天插天天日| 亚洲少妇人妻无码精品| 特黄老太婆aa毛毛片| 国产91久久精品一区二区字幕| 2o22av在线视频| 美女被肏内射视频网站| 91人妻人人做人人爽在线| 老鸭窝日韩精品视频观看| 四川五十路熟女av| 91色秘乱一区二区三区| 日本最新一二三区不卡在线| 久久机热/这里只有| 成人性黑人一级av| 欧美一区二区三区啪啪同性| 精产国品久久一二三产区区别 | 五月天色婷婷在线观看视频免费| 国产视频在线视频播放| 在线观看免费岛国av| 国产精品中文av在线播放| 精彩视频99免费在线| mm131美女午夜爽爽爽| 亚洲av可乐操首页| av在线资源中文字幕| 亚洲精品国偷自产在线观看蜜桃| 日本精品视频不卡一二三| 适合午夜一个人看的视频| 亚洲国产精品美女在线观看| 五月天色婷婷在线观看视频免费| 人妻另类专区欧美制服| 99精品久久久久久久91蜜桃| 日韩视频一区二区免费观看| 中文字幕,亚洲人妻| 99热99这里精品6国产| 亚洲av可乐操首页| 亚洲欧美另类手机在线| 噜噜色噜噜噜久色超碰| 激情五月婷婷免费视频| 免费高清自慰一区二区三区网站| 亚洲男人在线天堂网| 在线免费观看日本伦理| 国产精品一区二区av国| 小穴多水久久精品免费看| av手机免费在线观看高潮| 久久精品国产亚洲精品166m| 亚洲av一妻不如妾| 北条麻妃高跟丝袜啪啪| 久碰精品少妇中文字幕av| 大骚逼91抽插出水视频| 国产亚洲视频在线观看| 天堂女人av一区二区| 人人妻人人人操人人人爽| 揄拍成人国产精品免费看视频 | 亚洲精品麻豆免费在线观看| 福利视频一区二区三区筱慧| 亚洲最大免费在线观看| 青青青激情在线观看视频| 边摸边做超爽毛片18禁色戒 | 中文字幕 码 在线视频| 免费av岛国天堂网站| 免费无毒热热热热热热久| 91社福利《在线观看| 国产污污污污网站在线| 国产综合精品久久久久蜜臀| 国产使劲操在线播放| 国产麻豆国语对白露脸剧情| 4个黑人操素人视频网站精品91| 日本熟女50视频免费| 日本熟妇一区二区x x| 大胸性感美女羞爽操逼毛片| 欧美韩国日本国产亚洲| 亚洲男人让女人爽的视频| 国产不卡av在线免费| 把腿张开让我插进去视频| 日韩激情文学在线视频 | huangse网站在线观看| caoporn蜜桃视频| 免费费一级特黄真人片 | 一二三中文乱码亚洲乱码one| 精品视频一区二区三区四区五区| 我想看操逼黄色大片| 久久久精品国产亚洲AV一| 色天天天天射天天舔| 成年美女黄网站18禁久久| 91九色porny蝌蚪国产成人| 伊人开心婷婷国产av| 国产剧情演绎系列丝袜高跟| 亚洲精品国产综合久久久久久久久 | 性色av一区二区三区久久久| 日韩欧美中文国产在线| 这里只有精品双飞在线播放| 岛国av高清在线成人在线| 99热久久极品热亚洲| av中文字幕国产在线观看| 18禁污污污app下载| 中文字幕一区二区亚洲一区| 在线网站你懂得老司机| 亚洲中文字幕校园春色| 久久这里只有精品热视频| 日本人妻少妇18—xx| 成熟丰满熟妇高潮xx×xx| 懂色av之国产精品| 毛片av在线免费看| 欧美成人综合视频一区二区 | 熟女妇女老妇一二三区| 亚洲综合一区成人在线| 国产三级精品三级在线不卡| 日本熟妇丰满厨房55| 99久久99久国产黄毛片| 91福利视频免费在线观看| 国产不卡av在线免费| 成人国产激情自拍三区| 一级a看免费观看网站| 91免费福利网91麻豆国产精品| 91试看福利一分钟| 天天操天天操天天碰| 黄色在线观看免费观看在线| 天天做天天干天天舔| 边摸边做超爽毛片18禁色戒| 国产精品污污污久久| 中文字幕人妻av在线观看| 亚洲欧美另类手机在线| 动漫av网站18禁| 91快播视频在线观看| 青青青爽视频在线播放| 女蜜桃臀紧身瑜伽裤| 午夜激情久久不卡一区二区| 噜噜色噜噜噜久色超碰| 亚洲成人情色电影在线观看| 中文字幕 码 在线视频| 亚洲狠狠婷婷综合久久app| 国产又粗又硬又猛的毛片视频| 亚洲精品国品乱码久久久久| 9l人妻人人爽人人爽| 日噜噜噜夜夜噜噜噜天天噜噜噜 | 国产极品美女久久久久久| 欧美专区第八页一区在线播放| 九色精品视频在线播放| 国产a级毛久久久久精品| 一区二区三区在线视频福利| 天天日天天日天天擦| 青青青青青手机视频| 在线观看的黄色免费网站| 在线免费视频 自拍| 狠狠的往里顶撞h百合| 成人免费毛片aaaa| 亚洲图库另类图片区| 福利视频网久久91| 适合午夜一个人看的视频| 香蕉91一区二区三区| 日本男女操逼视频免费看| 亚洲综合乱码一区二区| 91人妻精品一区二区在线看| 亚洲av日韩精品久久久| 清纯美女在线观看国产| 91亚洲手机在线视频播放| 亚洲av第国产精品| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 青青青青青免费视频| 欧美中国日韩久久精品| 亚洲高清国产自产av| 亚洲最大黄了色网站| 男女之间激情网午夜在线| 日本熟妇一区二区x x| 大陆胖女人与丈夫操b国语高清| 自拍偷拍亚洲欧美在线视频| 午夜成午夜成年片在线观看| 欧美日韩国产一区二区三区三州| 大鸡吧插逼逼视频免费看 | 男人的天堂一区二区在线观看| 中文字幕无码日韩专区免费| 999九九久久久精品| 国产真实乱子伦a视频| 国产亚洲国产av网站在线| av中文字幕福利网| 免费高清自慰一区二区三区网站| 成人亚洲国产综合精品| 精品国产亚洲av一淫| 老司机福利精品免费视频一区二区| 中文字幕高清免费在线人妻| 熟女人妻在线观看视频| 日本少妇精品免费视频| 精品日产卡一卡二卡国色天香| 91色秘乱一区二区三区| 日韩精品电影亚洲一区| 亚洲av无乱一区二区三区性色| 日本18禁久久久久久| 色狠狠av线不卡香蕉一区二区| 极品性荡少妇一区二区色欲| 一区二区三区麻豆福利视频| av中文在线天堂精品| 五月婷婷在线观看视频免费| 激情小视频国产在线| 岛国av高清在线成人在线| 非洲黑人一级特黄片| 操人妻嗷嗷叫视频一区二区| 性色av一区二区三区久久久| 91www一区二区三区| 一区二区三区美女毛片| 国产欧美精品一区二区高清| 天天干天天搞天天摸| 亚洲欧美精品综合图片小说| 成人区人妻精品一区二视频| 亚洲伊人色一综合网| 午夜影院在线观看视频羞羞羞| 色天天天天射天天舔| 国产精品人妻66p| 五十路老熟女码av| 久久丁香花五月天色婷婷| 大黑人性xxxxbbbb| 亚洲图片欧美校园春色| 人妻丝袜榨强中文字幕| 亚洲天堂成人在线观看视频网站| 年轻的人妻被夫上司侵犯| 日韩亚国产欧美三级涩爱| 93精品视频在线观看| 岛国av高清在线成人在线| 天天日天天日天天擦| 成年人黄色片免费网站| 日本熟妇丰满厨房55| 亚洲激情偷拍一区二区| 人妻少妇亚洲精品中文字幕| 中文字日产幕乱六区蜜桃| 免费男阳茎伸入女阳道视频| 亚洲国产精品久久久久久6| 99热色原网这里只有精品| 一区二区三区的久久的蜜桃的视频| 亚洲综合在线视频可播放| 久久久精品欧洲亚洲av| 一区二区三区久久中文字幕| 少妇一区二区三区久久久| 成人av电影免费版| 亚洲精品国产综合久久久久久久久| 不卡一区一区三区在线| 一区二区三区激情在线| 亚洲特黄aaaa片| 99精品国产aⅴ在线观看| av手机在线观播放网站| 最新国产精品拍在线观看| 涩涩的视频在线观看视频| 中文字幕一区二区三区蜜月 | 久久久极品久久蜜桃| ka0ri在线视频| 成人亚洲精品国产精品| 成人国产激情自拍三区| 家庭女教师中文字幕在线播放| 视频 国产 精品 熟女 | 91精品激情五月婷婷在线| 日本乱人一区二区三区| 色婷婷综合激情五月免费观看| 一区二区三区精品日本| 亚洲 中文字幕在线 日韩| 免费无毒热热热热热热久| 欧美日韩v中文在线| 99精品国产aⅴ在线观看| 亚洲国产最大av综合| 亚洲av无乱一区二区三区性色| 自拍偷拍一区二区三区图片| 福利视频一区二区三区筱慧| 特黄老太婆aa毛毛片| 亚洲 人妻 激情 中文| 一区二区麻豆传媒黄片| 国产精品成人xxxx| 亚洲中文字幕人妻一区| 熟女人妻一区二区精品视频| 国产在线观看免费人成短视频| 在线观看免费视频色97| 青青青青在线视频免费观看| 91福利在线视频免费观看| 青青擦在线视频国产在线| 日韩欧美高清免费在线| 成人综合亚洲欧美一区| 亚洲精品中文字幕下载| 扒开腿挺进肉嫩小18禁视频| 国际av大片在线免费观看| 视频二区在线视频观看| 中文字幕av一区在线观看| 日韩欧美高清免费在线| 色综合久久无码中文字幕波多| 黄工厂精品视频在线观看| 精品老妇女久久9g国产| 偷拍自拍亚洲视频在线观看| 亚洲第一黄色在线观看 | 亚洲精品av在线观看| 操的小逼流水的文章| 蜜桃久久久久久久人妻| 亚洲精品久久视频婷婷| 欧美视频中文一区二区三区| 国产日韩av一区二区在线| 大胆亚洲av日韩av| 亚洲成人熟妇一区二区三区 | 日本韩国亚洲综合日韩欧美国产| 97成人免费在线观看网站| 99精品国产aⅴ在线观看| 国产实拍勾搭女技师av在线| 亚洲综合在线观看免费| av网址国产在线观看| 阴茎插到阴道里面的视频| 国产va在线观看精品| 久精品人妻一区二区三区| 久久久精品999精品日本| av俺也去在线播放| 男大肉棒猛烈插女免费视频| 91免费黄片可看视频| 黄色片一级美女黄色片| 精品一区二区三区欧美| 91小伙伴中女熟女高潮| 天天日天天天天天天天天天天 | 久久久久久cao我的性感人妻| 激情国产小视频在线| 啪啪啪啪啪啪啪免费视频| 888欧美视频在线| 老司机福利精品免费视频一区二区| 国产精品一区二区久久久av| 91国语爽死我了不卡| 青草亚洲视频在线观看| 欧美精品 日韩国产| 国产97在线视频观看| 日本男女操逼视频免费看| 免费岛国喷水视频在线观看 | 日本韩国亚洲综合日韩欧美国产| 亚洲一区自拍高清免费视频| 色婷婷精品大在线观看| 欧美亚洲偷拍自拍色图| 摧残蹂躏av一二三区| 亚洲熟色妇av日韩熟色妇在线| 亚洲精品ww久久久久久| 亚洲熟色妇av日韩熟色妇在线 | 新婚人妻聚会被中出| 熟女在线视频一区二区三区| 黄色男人的天堂视频| 一区二区麻豆传媒黄片 | 99热这里只有精品中文| 白白操白白色在线免费视频| 人人妻人人爽人人澡人人精品| 韩国AV无码不卡在线播放| 久久www免费人成一看片| 日韩人妻在线视频免费| av成人在线观看一区| 国产精品人妻一区二区三区网站 | 人妻丝袜av在线播放网址| 天天日夜夜操天天摸| 亚洲天堂第一页中文字幕| 日噜噜噜夜夜噜噜噜天天噜噜噜| 性生活第二下硬不起来| 精品首页在线观看视频| 欧美另类重口味极品在线观看| 日本午夜久久女同精女女| 日美女屁股黄邑视频| 蜜臀成人av在线播放| 色综合久久五月色婷婷综合| 亚洲一区自拍高清免费视频| 丝袜美腿欧美另类 中文字幕| 国产精品黄页网站视频| xxx日本hd高清| 我想看操逼黄色大片| 欧美成人精品欧美一级黄色| av手机免费在线观看高潮| 精品人妻一二三区久久| www日韩毛片av| 成人av在线资源网站| 天天操天天弄天天射| 精品久久久久久高潮| 一区二区三区的久久的蜜桃的视频| av手机在线观播放网站| 欧美激情电影免费在线| 亚洲 中文字幕在线 日韩| 一区二区三区 自拍偷拍| 中文亚洲欧美日韩无线码| 91高清成人在线视频| 日韩欧美高清免费在线| 懂色av蜜桃a v| 成人av免费不卡在线观看| 女生被男生插的视频网站| 日本www中文字幕| 丰满少妇人妻xxxxx| 香蕉av影视在线观看| 亚洲变态另类色图天堂网| 天天干狠狠干天天操| 日韩二区视频一线天婷婷五| 日本在线一区二区不卡视频| 91麻豆精品久久久久| 久久午夜夜伦痒痒想咳嗽P| 久久久精品精品视频视频| 中文字幕最新久久久| eeuss鲁片一区二区三区| 欧美激情电影免费在线| 婷婷色中文亚洲网68| 88成人免费av网站| aⅴ五十路av熟女中出| 国产精品精品精品999| 久久永久免费精品人妻专区| 视频一区 视频二区 视频| av在线观看网址av| 五十路熟女av天堂| 在线免费91激情四射 | 日韩成人性色生活片| 18禁美女无遮挡免费| 亚洲成人免费看电影| 亚洲va天堂va国产va久| tube69日本少妇| 日韩欧美一级黄片亚洲| 亚洲一区二区人妻av| 91九色porny国产蝌蚪视频| 老鸭窝在线观看一区| 蜜桃色婷婷久久久福利在线| 9国产精品久久久久老师| 十八禁在线观看地址免费| 亚洲1卡2卡三卡4卡在线观看| 午夜成午夜成年片在线观看| 精品人人人妻人人玩日产欧| 97精品成人一区二区三区| 毛茸茸的大外阴中国视频| 污污小视频91在线观看| 久久丁香婷婷六月天| 免费观看污视频网站| 91久久精品色伊人6882| 国产真实乱子伦a视频 | 日日日日日日日日夜夜夜夜夜夜| 亚洲熟妇无码一区二区三区| 97瑟瑟超碰在线香蕉| av手机免费在线观看高潮| 久久久久久cao我的性感人妻| 久草视频在线免播放| 在线视频国产欧美日韩| 欧美精品国产综合久久| 日韩欧美亚洲熟女人妻| 不卡一不卡二不卡三| 亚洲国产精品美女在线观看| 天天干天天搞天天摸| 天码人妻一区二区三区在线看| 男大肉棒猛烈插女免费视频| 五十路熟女av天堂| 午夜场射精嗯嗯啊啊视频| 亚洲 欧美 精品 激情 偷拍| 亚洲女人的天堂av| 91桃色成人网络在线观看| 国产卡一卡二卡三乱码手机| 亚洲图库另类图片区| 性生活第二下硬不起来| 国产精品视频资源在线播放| 久久美欧人妻少妇一区二区三区| 福利视频广场一区二区| 欧美专区第八页一区在线播放 | 蜜桃精品久久久一区二区| 91麻豆精品久久久久| 人妻久久无码中文成人| 91免费福利网91麻豆国产精品| 亚洲国产成人最新资源| 日本丰满熟妇BBXBBXHD| 成人影片高清在线观看| av天堂中文字幕最新| 激情五月婷婷综合色啪| 午夜婷婷在线观看视频| 天堂资源网av中文字幕| 人人超碰国字幕观看97| 日韩美女福利视频网| 亚洲av无女神免非久久| 夫妻在线观看视频91| 最新的中文字幕 亚洲| 日韩三级黄色片网站| 一区国内二区日韩三区欧美| 亚洲成人av在线一区二区| 硬鸡巴动态操女人逼视频| 成人精品在线观看视频| 春色激情网欧美成人| 伊人开心婷婷国产av| 一区二区三区四区视频| 亚洲中文精品人人免费| 国产麻豆剧传媒精品国产av蜜桃 | 中文字幕日韩精品就在这里| 午夜精彩视频免费一区| 91久久国产成人免费网站| 北条麻妃高跟丝袜啪啪| 精品久久久久久久久久久久人妻| 2021年国产精品自拍| 99re久久这里都是精品视频| 青青在线视频性感少妇和隔壁黑丝| 动色av一区二区三区| 偷偷玩弄新婚人妻h视频| 人妻在线精品录音叫床| 精品首页在线观看视频| 一区国内二区日韩三区欧美| 天天干夜夜操啊啊啊| 国产精品黄大片在线播放| 欧美一级视频一区二区| 欧美日本aⅴ免费视频| 国产精品成久久久久三级蜜臀av| 欧美成人精品欧美一级黄色| 狠狠操狠狠操免费视频| 日本免费一级黄色录像| 日韩美女精品视频在线观看网站| 亚洲少妇高潮免费观看| 天天日天天敢天天干| 色综合久久五月色婷婷综合| 国产福利小视频免费观看| 一区二区三区国产精选在线播放| 亚洲丝袜老师诱惑在线观看| 大香蕉伊人国产在线| 天天日天天天天天天天天天天| 天天夜天天日天天日| 大陆胖女人与丈夫操b国语高清| 福利视频一区二区三区筱慧 | 91片黄在线观看喷潮| 国产日韩精品免费在线| 最近中文2019年在线看| 欧美乱妇无乱码一区二区| 亚洲人一区二区中文字幕| 日本脱亚入欧是指什么| 三级等保密码要求条款| 久久免看30视频口爆视频| 亚洲一区久久免费视频| 人妻熟女在线一区二区| 中文字幕第一页国产在线| 韩国女主播精品视频网站| 高潮视频在线快速观看国家快速| 欧美在线一二三视频| 伊拉克及约旦宣布关闭领空| 久草视频在线看免费| 天天射,天天操,天天说| brazzers欧熟精品系列| 男人的天堂av日韩亚洲| 丰满少妇翘臀后进式| 最新黄色av网站在线观看| 2018最新中文字幕在线观看| 成人蜜臀午夜久久一区| 超碰97人人做人人爱| 女同互舔一区二区三区| 亚洲福利天堂久久久久久| 日韩三级电影华丽的外出| 日韩剧情片电影在线收看| 男女第一次视频在线观看| 91麻豆精品传媒国产黄色片| 真实国产乱子伦一区二区| 国产日韩欧美视频在线导航| 免费男阳茎伸入女阳道视频 | 中国黄片视频一区91| 国产妇女自拍区在线观看| 欧美日韩情色在线观看| 大鸡吧插入女阴道黄色片| 一区二区三区四区五区性感视频 | 中国老熟女偷拍第一页| 国产激情av网站在线观看| 成年午夜免费无码区| 人妻久久久精品69系列| 欧美日韩中文字幕欧美| 国产无遮挡裸体免费直播视频| 人人妻人人人操人人人爽| 亚洲成高清a人片在线观看| 日本最新一二三区不卡在线| 天天插天天狠天天操| 久久这里只有精彩视频免费| 97精品视频在线观看| 一区二区在线观看少妇| 亚洲激情av一区二区| 久草视频在线一区二区三区资源站 | 18禁免费av网站| 国产精品黄大片在线播放| 中文字幕之无码色多多| 91色秘乱一区二区三区| 蝴蝶伊人久久中文娱乐网| 中国黄色av一级片| 亚洲av无女神免非久久| 插小穴高清无码中文字幕| 97人人模人人爽人人喊| 绝顶痉挛大潮喷高潮无码| 欧美成人小视频在线免费看| 男人操女人逼逼视频网站| 不戴胸罩引我诱的隔壁的人妻| 日本在线不卡免费视频| 国产日韩精品一二三区久久久| 欧美精品中文字幕久久二区| 亚洲精品国产综合久久久久久久久| 久久人人做人人妻人人玩精品vr| 一区二区三区美女毛片| 亚洲综合另类欧美久久| 大鸡巴后入爆操大屁股美女| 不戴胸罩引我诱的隔壁的人妻 | 日本黄色特一级视频| 亚洲av天堂在线播放| 国产免费av一区二区凹凸四季| 青娱乐蜜桃臀av色| 91片黄在线观看喷潮| 91精品综合久久久久3d动漫| 国产夫妻视频在线观看免费| 人妻少妇亚洲一区二区| 国语对白xxxx乱大交| 大尺度激情四射网站| 一级黄片大鸡巴插入美女| 骚货自慰被发现爆操| 国产亚洲天堂天天一区| 自拍偷拍,中文字幕| 亚洲 欧美 精品 激情 偷拍 | 亚洲欧美一区二区三区电影| 一区二区三区精品日本| 天天干天天日天天干天天操| 视频一区 视频二区 视频| 精品日产卡一卡二卡国色天香| 91久久人澡人人添人人爽乱| 特大黑人巨大xxxx| 极品性荡少妇一区二区色欲| 自拍偷拍一区二区三区图片| 免费成人va在线观看| 老司机免费视频网站在线看| 欧美怡红院视频在线观看| 国产精品欧美日韩区二区| 精品人妻伦一二三区久| 亚洲特黄aaaa片| 99精品一区二区三区的区| 国产一区二区在线欧美| 亚洲熟妇x久久av久久| 亚洲视频在线观看高清| 午夜福利人人妻人人澡人人爽| 大鸡巴操b视频在线| 2021久久免费视频| 黄色片黄色片wyaa| 九色视频在线观看免费| 亚洲男人的天堂a在线| 伊人情人综合成人久久网小说| 国内自拍第一页在线观看| 国产91精品拍在线观看| 国产高清97在线观看视频| 国产视频一区在线观看| 国产成人精品亚洲男人的天堂| 一区二区熟女人妻视频| 男大肉棒猛烈插女免费视频| 精品首页在线观看视频| 老鸭窝日韩精品视频观看| 9久在线视频只有精品| 青草亚洲视频在线观看| 亚洲成人av在线一区二区| 在线观看av亚洲情色| 中文字幕高清在线免费播放| 2022天天干天天操| 精品久久久久久高潮| 日韩伦理短片在线观看| 91九色porny国产蝌蚪视频| 亚洲推理片免费看网站| av中文字幕在线观看第三页| 老司机福利精品免费视频一区二区 | 中文字幕在线视频一区二区三区 | 天天操,天天干,天天射| 天天色天天舔天天射天天爽| 国产激情av网站在线观看| 午夜久久久久久久精品熟女| 天天日天天干天天舔天天射| 啊啊好大好爽啊啊操我啊啊视频| 国产真实乱子伦a视频| 中文字幕成人日韩欧美| 亚洲激情偷拍一区二区| 国产美女一区在线观看| 精品国产在线手机在线| 第一福利视频在线观看| av中文字幕在线导航| 2022中文字幕在线| 欧美日本国产自视大全| 都市家庭人妻激情自拍视频| 伊人成人综合开心网| 91大屁股国产一区二区| 欧美色婷婷综合在线| 一区二区三区国产精选在线播放| 亚洲护士一区二区三区| 欧美成人黄片一区二区三区| 亚洲va国产va欧美精品88| jiujiure精品视频在线| 国产日韩av一区二区在线| 在线免费观看av日韩| 欧美色呦呦最新网址| 中文字幕高清在线免费播放| 欧美性感尤物人妻在线免费看| 2022精品久久久久久中文字幕| 人人爱人人妻人人澡39| 久久久精品精品视频视频| 视频一区 二区 三区 综合| mm131美女午夜爽爽爽| 五十路熟女av天堂| 青青青青青青青青青国产精品视频| 韩国一级特黄大片做受| 激情五月婷婷免费视频| 激情综合治理六月婷婷| 日本丰满熟妇BBXBBXHD| 丝袜肉丝一区二区三区四区在线看| 亚洲精品高清自拍av| 黄色男人的天堂视频| 亚洲高清一区二区三区视频在线| 丰满的继坶3中文在线观看| 成人av亚洲一区二区| rct470中文字幕在线| 国产精品女邻居小骚货| www日韩a级s片av| 精品一区二区三区欧美| 91久久国产成人免费网站| 韩国爱爱视频中文字幕| 四川乱子伦视频国产vip| 在线不卡成人黄色精品| 久久人人做人人妻人人玩精品vr| 人人妻人人爽人人添夜| 天天日天天做天天日天天做| 人妻丝袜诱惑我操她视频| 国产剧情演绎系列丝袜高跟| 夜夜操,天天操,狠狠操| 中文字幕高清免费在线人妻| 美女吃鸡巴操逼高潮视频| 亚洲 中文 自拍 另类 欧美| 成人区人妻精品一区二视频| 青青青青青青青青青国产精品视频| 亚洲粉嫩av一区二区三区| av手机免费在线观看高潮| 激情五月婷婷综合色啪| 很黄很污很色的午夜网站在线观看| 无套猛戳丰满少妇人妻| 青青擦在线视频国产在线| 清纯美女在线观看国产| 黑人变态深video特大巨大| 成人国产影院在线观看| 日本福利午夜电影在线观看| 黄色片一级美女黄色片| 成人av在线资源网站| 91亚洲精品干熟女蜜桃频道| 国产在线观看免费人成短视频| 一区二区三区另类在线| 18禁美女黄网站色大片下载| 啪啪啪啪啪啪啪啪av| 亚洲女人的天堂av| av中文字幕国产在线观看| 久久午夜夜伦痒痒想咳嗽P| 2020中文字幕在线播放| 91精品国产综合久久久蜜| 美洲精品一二三产区区别| 欧美一区二区三区高清不卡tv| 国产精品视频欧美一区二区| 91国产资源在线视频| 99人妻视频免费在线| www骚国产精品视频| 亚洲精品国产久久久久久| aⅴ精产国品一二三产品| 91精品综合久久久久3d动漫| av在线观看网址av| 国产高清97在线观看视频| 欧美日韩情色在线观看| 色97视频在线播放| 久久久久五月天丁香社区 | 丁香花免费在线观看中文字幕| 亚洲高清自偷揄拍自拍| 福利视频网久久91| 91一区精品在线观看| 人妻无码色噜噜狠狠狠狠色| 伊人开心婷婷国产av| 在线播放国产黄色av| 91在线免费观看成人| 国产精品熟女久久久久浪潮| 国产va在线观看精品| 国产女人叫床高潮大片视频| 久久久久五月天丁香社区| 亚洲综合一区成人在线| 午夜婷婷在线观看视频| 欧美80老妇人性视频| 护士小嫩嫩又紧又爽20p| 国产精品三级三级三级| 天堂av在线最新版在线| 老司机午夜精品视频资源 | 国产成人综合一区2区| 女生被男生插的视频网站| 亚洲精品福利网站图片| 午夜精品亚洲精品五月色| 亚洲熟女女同志女同| jiuse91九色视频| 秋霞午夜av福利经典影视| 成人国产小视频在线观看| 99久久激情婷婷综合五月天| 色偷偷伊人大杳蕉综合网| 欧美日韩一区二区电影在线观看| 亚洲视频在线视频看视频在线| 精品久久久久久久久久中文蒉| 日本人妻欲求不满中文字幕| 五十路人妻熟女av一区二区| 中文字幕一区二区亚洲一区| 100%美女蜜桃视频| 一区二区三区视频,福利一区二区| 91精品免费久久久久久| 97国产精品97久久| 丰满的继坶3中文在线观看| 69精品视频一区二区在线观看| 亚洲福利午夜久久久精品电影网| 蜜桃精品久久久一区二区| 日本一道二三区视频久久| 国产麻豆剧传媒精品国产av蜜桃 | 一区二区三区麻豆福利视频| 99久久中文字幕一本人| 亚洲一区二区三区五区| av在线免费观看亚洲天堂| 国产精品视频资源在线播放| 久久99久久99精品影院| 日韩无码国产精品强奸乱伦| 久久久制服丝袜中文字幕| 人人妻人人人操人人人爽| 日本后入视频在线观看| 99人妻视频免费在线| 精品av国产一区二区三区四区 | 青青青激情在线观看视频| 日本av熟女在线视频| 91精品免费久久久久久| 欧美精品黑人性xxxx| 中文字幕人妻被公上司喝醉在线| 中国黄片视频一区91| 大香蕉伊人国产在线| 自拍偷拍 国产资源| 99热碰碰热精品a中文| 美女操逼免费短视频下载链接| 成人精品在线观看视频| 免费在线看的黄网站| 2025年人妻中文字幕乱码在线| 最新中文字幕乱码在线| 白白操白白色在线免费视频 | 午夜毛片不卡免费观看视频| 18禁美女黄网站色大片下载| 19一区二区三区在线播放| 午夜精品亚洲精品五月色| 极品粉嫩小泬白浆20p主播| 欲乱人妻少妇在线视频裸| 涩涩的视频在线观看视频| 91大屁股国产一区二区| 绝顶痉挛大潮喷高潮无码 | 熟妇一区二区三区高清版| 少妇与子乱在线观看| 在线视频自拍第三页| 亚洲综合另类欧美久久| 欧美第一页在线免费观看视频| 国产精品视频男人的天堂| 老司机免费福利视频网| 久久久久久久久久久久久97| 888欧美视频在线| 自拍偷拍日韩欧美亚洲| 亚洲天堂精品久久久| 午夜精品福利一区二区三区p| 精品美女福利在线观看| 国产黑丝高跟鞋视频在线播放| 国产伦精品一区二区三区竹菊| 在线视频免费观看网| 日本女人一级免费片| 日韩av大胆在线观看| 日韩激情文学在线视频| 欧美伊人久久大香线蕉综合| 午夜大尺度无码福利视频| 五十路在线观看完整版| 桃色视频在线观看一区二区 | 免费高清自慰一区二区三区网站| 神马午夜在线观看视频| 不卡精品视频在线观看| 欧美成人一二三在线网| 中文字幕一区二 区二三区四区| 欧美日韩中文字幕欧美| 啪啪啪18禁一区二区三区| 国产日韩欧美视频在线导航 | 女蜜桃臀紧身瑜伽裤| 日本午夜福利免费视频| 2022中文字幕在线| 人妻丝袜av在线播放网址| 黄色视频在线观看高清无码| 97色视频在线观看| 久草电影免费在线观看| japanese日本熟妇另类| 中文字幕日韩91人妻在线| 欧美另类一区二区视频| 91精品国产黑色丝袜| 和邻居少妇愉情中文字幕| 青青青爽视频在线播放| 欧美专区第八页一区在线播放| 中文字幕成人日韩欧美| rct470中文字幕在线| 玩弄人妻熟妇性色av少妇| 一二三区在线观看视频| 黄色的网站在线免费看| 亚洲激情,偷拍视频| 欧美日韩在线精品一区二区三| 自拍偷区二区三区麻豆| 大香蕉伊人中文字幕| 黄色片年轻人在线观看| 中文字幕亚洲中文字幕| 亚洲中文字字幕乱码| 亚洲国产精品久久久久蜜桃| 亚洲中文字幕校园春色| 欧美色婷婷综合在线| asmr福利视频在线观看| 日韩av中文在线免费观看| 日本av熟女在线视频| 天天干天天搞天天摸| 日本丰满熟妇BBXBBXHD| 免费大片在线观看视频网站| 超碰在线中文字幕一区二区| 亚洲综合自拍视频一区| 五月天久久激情视频| 亚洲国产精品久久久久久6| 91麻豆精品91久久久久同性| 国产一区成人在线观看视频 | 欧美黑人性猛交xxxxⅹooo| 亚洲国产香蕉视频在线播放| 一区二区三区av高清免费| 亚洲欧美一区二区三区爱爱动图| 国产第一美女一区二区三区四区 | 91人妻精品一区二区在线看| 久久久久久久精品成人热| 精品久久婷婷免费视频| 免费国产性生活视频| 午夜免费体验区在线观看| 青青青aaaa免费| 男女啪啪啪啪啪的网站| 色秀欧美视频第一页| 国产女人露脸高潮对白视频| 中文字幕人妻三级在线观看| 粉嫩欧美美人妻小视频| 最新欧美一二三视频| 一区二区三区另类在线| 欧美国产亚洲中英文字幕| 美女骚逼日出水来了| av老司机精品在线观看| 丝袜美腿欧美另类 中文字幕| 国产一级精品综合av| 精品人人人妻人人玩日产欧| 成年人啪啪视频在线观看| 日本熟妇色熟妇在线观看| 91桃色成人网络在线观看| 在线免费观看靠比视频的网站| 蜜桃臀av蜜桃臀av| 国产精品女邻居小骚货| 91国内视频在线观看| 国产麻豆国语对白露脸剧情| 精品视频中文字幕在线播放| 婷婷久久久综合中文字幕| 中文字母永久播放1区2区3区| 熟女人妻三十路四十路人妻斩| 日本啪啪啪啪啪啪啪| 青青青青青操视频在线观看| 又粗又硬又猛又黄免费30| 99热99re在线播放| 早川濑里奈av黑人番号| 日本福利午夜电影在线观看| 欧美美女人体视频一区| 久久精品国产999| 老鸭窝在线观看一区| 国产又粗又猛又爽又黄的视频在线 | 日本一二三区不卡无| 亚洲va国产va欧美精品88| 天天干天天操天天爽天天摸| av网址国产在线观看| 天堂va蜜桃一区入口| 大鸡巴后入爆操大屁股美女| 丝袜国产专区在线观看| 88成人免费av网站| 色哟哟在线网站入口| 国产无遮挡裸体免费直播视频 | 五月婷婷在线观看视频免费 | 做爰视频毛片下载蜜桃视频1| 午夜频道成人在线91| 欧美女同性恋免费a| av在线免费中文字幕| 亚洲丝袜老师诱惑在线观看| 老师让我插进去69AV| 黄色大片免费观看网站| 啪啪啪18禁一区二区三区| 中文字幕日韩无敌亚洲精品| 九九热99视频在线观看97| 又粗又硬又猛又爽又黄的| 亚洲狠狠婷婷综合久久app| 中国无遮挡白丝袜二区精品 | 人妻少妇一区二区三区蜜桃| 亚洲精品精品国产综合| 日本性感美女视频网站| av中文字幕福利网| 天堂中文字幕翔田av| 亚洲精品国偷自产在线观看蜜桃| av亚洲中文天堂字幕网| 91免费观看在线网站| 亚洲人一区二区中文字幕| 午夜毛片不卡免费观看视频| 蜜桃色婷婷久久久福利在线 | 亚洲伊人av天堂有码在线| 中文字幕高清在线免费播放| 精品av久久久久久久| 国产亚洲欧美另类在线观看| 日日夜夜大香蕉伊人| av中文字幕国产在线观看| 午夜影院在线观看视频羞羞羞| 最新97国产在线视频| 亚洲av自拍偷拍综合| 高潮视频在线快速观看国家快速| 欧美偷拍亚洲一区二区| av在线资源中文字幕| 中文字幕无码一区二区免费| 女同互舔一区二区三区| 国产大学生援交正在播放| 中国黄片视频一区91| 91麻豆精品传媒国产黄色片| 999久久久久999| 欧亚日韩一区二区三区观看视频| 国产成人无码精品久久久电影| 欧美黑人性暴力猛交喷水| 日本一区美女福利视频| aiss午夜免费视频| 日韩av熟妇在线观看| 一级黄片久久久久久久久| 中文字幕欧美日韩射射一| 无码中文字幕波多野不卡| 大陆胖女人与丈夫操b国语高清| 91精品综合久久久久3d动漫| 五月天色婷婷在线观看视频免费| 亚洲av日韩av第一区二区三区| 国产精品黄片免费在线观看| 精品欧美一区二区vr在线观看| 在线观看911精品国产| 国产不卡av在线免费| 做爰视频毛片下载蜜桃视频1| 欧美黑人与人妻精品| 岛国毛片视频免费在线观看| 一级a看免费观看网站| 在线免费观看国产精品黄色| 97超碰人人搞人人| 无码中文字幕波多野不卡| 欧美精品一区二区三区xxxx| 91人妻精品一区二区久久| 日韩a级黄色小视频| 91精品国产麻豆国产| 18禁免费av网站| 成人30分钟免费视频| 欧美亚洲中文字幕一区二区三区| 粉嫩av懂色av蜜臀av| 欧美在线一二三视频| 五月激情婷婷久久综合网| 91免费观看国产免费| 青青青青青操视频在线观看| 自拍偷拍日韩欧美亚洲| 午夜极品美女福利视频| 人人人妻人人澡人人| av在线免费中文字幕| 91破解版永久免费| 国产自拍黄片在线观看| 日韩少妇人妻精品无码专区| av日韩在线免费播放| 亚洲熟色妇av日韩熟色妇在线| 中文字幕免费在线免费| av完全免费在线观看av| 国产女人露脸高潮对白视频| 偷青青国产精品青青在线观看| 日韩一区二区电国产精品| 2025年人妻中文字幕乱码在线| 成人H精品动漫在线无码播放| 亚洲天堂第一页中文字幕 | 久久尻中国美女视频| 日本裸体熟妇区二区欧美| 亚洲一区二区三区在线高清| 日本成人不卡一区二区| 亚洲一区二区三区久久受| 18禁网站一区二区三区四区| 黄网十四区丁香社区激情五月天 | 岛国黄色大片在线观看| 国产伦精品一区二区三区竹菊| asmr福利视频在线观看| 国产一区成人在线观看视频| 午夜大尺度无码福利视频| 日日操夜夜撸天天干| 午夜婷婷在线观看视频| 亚洲老熟妇日本老妇| 亚洲av日韩av第一区二区三区| 中英文字幕av一区| 国产又粗又猛又爽又黄的视频美国| 亚洲中文字幕乱码区| 18禁污污污app下载| 人人超碰国字幕观看97| 爱有来生高清在线中文字幕| 青青青青在线视频免费观看| 免费费一级特黄真人片| 狠狠操操操操操操操操操| 性色av一区二区三区久久久| 超碰在线观看免费在线观看 | 日本丰满熟妇BBXBBXHD| 视频二区在线视频观看| 亚洲人妻30pwc| 日本特级片中文字幕| 黄色片黄色片wyaa| 成人性黑人一级av| 91麻豆精品传媒国产黄色片| av中文在线天堂精品| 年轻的人妻被夫上司侵犯| 欧美亚洲自偷自拍 在线| 亚洲av日韩高清hd| 巨乳人妻日下部加奈被邻居中出 | 国产三级影院在线观看| 中文字幕一区二 区二三区四区 | 青草亚洲视频在线观看| 色在线观看视频免费的| 天天日天天干天天搡| 日韩近亲视频在线观看| 日韩视频一区二区免费观看| 亚洲成人精品女人久久久| 红桃av成人在线观看| 色偷偷伊人大杳蕉综合网| 日本熟女50视频免费| 国产综合视频在线看片| 中文人妻AV久久人妻水| 亚洲国产成人av在线一区| 亚洲成av人无码不卡影片一| 中文字幕综合一区二区| 国产亚洲精品视频合集| 精品国产高潮中文字幕| 久久久久久97三级| 国产又粗又猛又爽又黄的视频美国| 天天操天天弄天天射| 欧美黄片精彩在线免费观看| 国产精品一区二区三区蜜臀av| 最新黄色av网站在线观看| 欧美 亚洲 另类综合| 免费黄色成人午夜在线网站| 亚洲熟女综合色一区二区三区四区| 2025年人妻中文字幕乱码在线| 国产精品中文av在线播放| 久久精品亚洲成在人线a| 国产精品久久久久网| 色呦呦视频在线观看视频| 老熟妇凹凸淫老妇女av在线观看| 在线观看日韩激情视频| 福利在线视频网址导航| 97人妻夜夜爽二区欧美极品| 亚洲精品国产综合久久久久久久久| 国产卡一卡二卡三乱码手机| 亚洲福利天堂久久久久久| 国产超码片内射在线| 国产真实灌醉下药美女av福利| 国产欧美精品不卡在线| 亚洲欧美清纯唯美另类| 青青尤物在线观看视频网站| 日日夜夜大香蕉伊人| 国产精品黄片免费在线观看| 国产品国产三级国产普通话三级| 天天操天天爽天天干| 丝袜亚洲另类欧美变态| 一区二区三区四区视频| 人妻少妇中文有码精品| 中文字幕免费在线免费| 91精品国产黑色丝袜| 色哟哟在线网站入口| 天天躁夜夜躁日日躁a麻豆| 97欧洲一区二区精品免费| 亚洲av可乐操首页| 亚洲av香蕉一区区二区三区犇| 可以在线观看的av中文字幕| av天堂资源最新版在线看| 国产三级片久久久久久久| 日韩欧美一级黄片亚洲| 青青草在观免费国产精品| 中国黄片视频一区91| 把腿张开让我插进去视频| 亚洲蜜臀av一区二区三区九色| 经典av尤物一区二区| 亚洲精品中文字幕下载| 人妻少妇性色欲欧美日韩| 婷婷久久久久深爱网| 国产真实乱子伦a视频| 91九色porny国产蝌蚪视频| www日韩毛片av| 91精品国产高清自在线看香蕉网 | 姐姐的朋友2在线观看中文字幕| 国产视频在线视频播放| 十八禁在线观看地址免费| 日韩美女精品视频在线观看网站| 午夜免费体验区在线观看| 一个色综合男人天堂| 男人操女人的逼免费视频| 成人av电影免费版| 色秀欧美视频第一页| 我想看操逼黄色大片| 19一区二区三区在线播放| 精品一区二区三区三区88| 福利一二三在线视频观看| 精品一区二区三区在线观看| 视频 一区二区在线观看| 久久精品国产23696| 亚洲天堂av最新网址| 亚洲av自拍偷拍综合| 国产乱子伦精品视频潮优女| 国产熟妇乱妇熟色T区| av在线免费中文字幕| 黑人大几巴狂插日本少妇| 午夜影院在线观看视频羞羞羞| 国产一级麻豆精品免费| 精品亚洲国产中文自在线| 亚洲美女高潮喷浆视频| 韩国黄色一级二级三级| av中文字幕国产在线观看| 直接观看免费黄网站| 91成人在线观看免费视频| 亚洲狠狠婷婷综合久久app| 国产精品国产三级国产精东 | 肏插流水妹子在线乐播下载| 天天日天天干天天干天天日| 福利午夜视频在线观看| 中文字幕人妻三级在线观看| 老司机欧美视频在线看| 青青伊人一精品视频| 青青尤物在线观看视频网站| 国产成人一区二区三区电影网站| 天天操夜夜骑日日摸| 日本性感美女写真视频| 国产一区二区火爆视频| 婷婷六月天中文字幕| 日韩精品一区二区三区在线播放| 人人妻人人澡欧美91精品| 天天干天天插天天谢| 成人亚洲国产综合精品| 精品亚洲国产中文自在线| 国产精品一区二区av国| 日本特级片中文字幕| 亚洲综合乱码一区二区| 秋霞午夜av福利经典影视| 天天干天天爱天天色| 欧洲黄页网免费观看| 韩国亚洲欧美超一级在线播放视频| 女同互舔一区二区三区| 姐姐的朋友2在线观看中文字幕| 天天摸天天干天天操科普| 亚洲特黄aaaa片| 国产成人自拍视频在线免费观看| 插逼视频双插洞国产操逼插洞| 亚洲成人熟妇一区二区三区| 在线播放一区二区三区Av无码| 久久尻中国美女视频| 五月天中文字幕内射| 欧美老鸡巴日小嫩逼| 中文字幕日韩无敌亚洲精品| 日本阿v视频在线免费观看| 色噜噜噜噜18禁止观看| 欧美爆乳肉感大码在线观看| 在线观看免费视频色97| 国产亚洲精品欧洲在线观看| 日韩中文字幕福利av| 18禁污污污app下载| 国产欧美日韩第三页| 欧洲亚洲欧美日韩综合| 亚洲综合乱码一区二区| aaa久久久久久久久| 黑人变态深video特大巨大| 日本xx片在线观看| 亚洲精品午夜aaa久久| 五月婷婷在线观看视频免费| 国产午夜无码福利在线看| 亚洲成人激情视频免费观看了| weyvv5国产成人精品的视频| 偷拍自拍亚洲视频在线观看| 青青草国内在线视频精选| 久久农村老妇乱69系列| 国产黄网站在线观看播放| 色婷婷精品大在线观看| 喷水视频在线观看这里只有精品| 日日夜夜精品一二三| 91久久综合男人天堂| 性色蜜臀av一区二区三区| 亚洲精品国品乱码久久久久| 精品国产亚洲av一淫| 亚洲公开视频在线观看| 中文字幕视频一区二区在线观看| 亚洲欧美综合在线探花| 成人免费毛片aaaa| 国产高清在线观看1区2区| 欧美精品欧美极品欧美视频| 午夜免费体验区在线观看| 啪啪啪啪啪啪啪啪av| 亚洲一区制服丝袜美腿| 一区二区三区欧美日韩高清播放| 18禁美女黄网站色大片下载| 粉嫩av懂色av蜜臀av| 清纯美女在线观看国产| 最后99天全集在线观看| 中文字幕奴隷色的舞台50| 蜜桃精品久久久一区二区| 最新日韩av传媒在线| 亚洲一区二区三区久久午夜| 日辽宁老肥女在线观看视频| 欧美区一区二区三视频| 欧美美女人体视频一区| av视网站在线观看| 自拍偷拍vs一区二区三区| 91一区精品在线观看| 久久麻豆亚洲精品av| 亚洲另类在线免费观看| 日本在线不卡免费视频| 自拍偷拍 国产资源| 丝袜美腿视频诱惑亚洲无| 成人久久精品一区二区三区| 欧美区一区二区三视频| 国产高清精品极品美女| 在线网站你懂得老司机| 天天操天天插天天色| 岛国一区二区三区视频在线| 欧美亚洲中文字幕一区二区三区 | 青草青永久在线视频18| 日韩欧美国产一区不卡| 久久久久久久久久久久久97| 国产精品sm调教视频| 天干天天天色天天日天天射| 国产精品伦理片一区二区| 中国熟女一区二区性xx| 亚洲日本一区二区久久久精品| 国产精品久久久黄网站| 人妻丝袜av在线播放网址| h国产小视频福利在线观看| 蜜臀成人av在线播放| 2020韩国午夜女主播在线| 白嫩白嫩美女极品国产在线观看| 亚洲视频乱码在线观看| 18禁精品网站久久| 日韩亚国产欧美三级涩爱| 日韩伦理短片在线观看| 东京热男人的av天堂| 精品首页在线观看视频| 超碰97免费人妻麻豆| 国产精品亚洲а∨天堂免| 中文字幕日韩精品就在这里| 精品老妇女久久9g国产| 国产高清精品一区二区三区| 青青草精品在线视频观看| 大香蕉大香蕉在线有码 av| 色噜噜噜噜18禁止观看| 4个黑人操素人视频网站精品91| 久久农村老妇乱69系列| 五月婷婷在线观看视频免费| 亚洲 色图 偷拍 欧美| 久碰精品少妇中文字幕av| 国产乱子伦一二三区| 91亚洲国产成人精品性色| 成人国产影院在线观看| 日本又色又爽又黄又粗| 免费十精品十国产网站| 欧美aa一级一区三区四区| 姐姐的朋友2在线观看中文字幕| 国产综合视频在线看片| 丰满少妇翘臀后进式| 抽查舔水白紧大视频| gogo国模私拍视频| 啪啪啪啪啪啪啪啪啪啪黄色| 直接观看免费黄网站| 青青草成人福利电影| 偷拍美女一区二区三区| 国产性感美女福利视频| 超级福利视频在线观看| 成人激情文学网人妻| 蜜臀成人av在线播放| 亚洲人妻视频在线网| 综合色区亚洲熟妇shxstz| 中文字幕高清免费在线人妻| 男人的网址你懂的亚洲欧洲av| 国产露脸对白在线观看| 亚洲少妇高潮免费观看| 性色蜜臀av一区二区三区| 久久久久久国产精品| 免费69视频在线看| 国产亚洲成人免费在线观看| 99热久久这里只有精品| 伊人精品福利综合导航| 久精品人妻一区二区三区| 国产熟妇人妻ⅹxxxx麻豆| 在线视频自拍第三页| 成年午夜影片国产片| 一区二区三区精品日本| 青青草亚洲国产精品视频| 欧美精品久久久久久影院| 亚洲精品欧美日韩在线播放| 在线观看国产网站资源| 国产伦精品一区二区三区竹菊| 中国把吊插入阴蒂的视频| 国产91精品拍在线观看| 东京热男人的av天堂| 都市家庭人妻激情自拍视频| 午夜精品一区二区三区更新| 天天色天天操天天透| 精品黑人巨大在线一区| 91国语爽死我了不卡| 在线可以看的视频你懂的 | 欧美精品 日韩国产| 清纯美女在线观看国产| 国产精品久久久久网| 2020av天堂网在线观看| 女同互舔一区二区三区| chinese国产盗摄一区二区| 国产成人精品亚洲男人的天堂| 亚洲在线观看中文字幕av| 中文字幕一区二 区二三区四区 | 97a片免费在线观看| 欧美性感尤物人妻在线免费看| 亚洲国产在人线放午夜| 9国产精品久久久久老师| 久久久久只精品国产三级| 婷婷久久久久深爱网| 高潮喷水在线视频观看| 在线成人日韩av电影| 国产大鸡巴大鸡巴操小骚逼小骚逼| 国产麻豆乱子伦午夜视频观看| 77久久久久国产精产品| 人妻爱爱 中文字幕| 亚洲av自拍偷拍综合| av在线免费中文字幕| 亚洲国产美女一区二区三区软件 | 国产一区成人在线观看视频| 热思思国产99re| 天天通天天透天天插| aaa久久久久久久久| 2017亚洲男人天堂| 欧美成人综合色在线噜噜| 免费在线播放a级片| 国产激情av网站在线观看| 成人高潮aa毛片免费| 天天日天天爽天天干| 2021天天色天天干| 欧美一区二区中文字幕电影| 国产精品久久久久久久久福交 | 国产精品大陆在线2019不卡| 久久久人妻一区二区| 日本a级视频老女人| 熟女少妇激情五十路| 人妻丝袜诱惑我操她视频| 色伦色伦777国产精品| 免费黄高清无码国产| 欧洲日韩亚洲一区二区三区| 久久久久久性虐视频| 日韩中文字幕在线播放第二页| 日韩影片一区二区三区不卡免费| 一区二区三区国产精选在线播放| 天天艹天天干天天操| www久久久久久久久久久| 97瑟瑟超碰在线香蕉| 亚洲高清免费在线观看视频| 制服丝袜在线人妻中文字幕| 国产一区二区视频观看| 在线免费观看靠比视频的网站| 亚洲公开视频在线观看| 久草电影免费在线观看| 亚洲中文精品字幕在线观看| 色婷婷六月亚洲综合香蕉| 插小穴高清无码中文字幕| 亚洲中文字字幕乱码| 成人在线欧美日韩国产| 91九色国产porny蝌蚪| 蜜桃视频入口久久久| 在线视频免费观看网| 天天干天天日天天谢综合156| 少妇高潮无套内谢麻豆| 一个色综合男人天堂| 欧美黑人与人妻精品| 国产男女视频在线播放| 亚洲欧美另类手机在线| 婷婷五月亚洲综合在线| caoporn蜜桃视频| 欧美少妇性一区二区三区| 久久久麻豆精亚洲av麻花| 中文字幕成人日韩欧美| 在线观看国产免费麻豆| 国内资源最丰富的网站| 日本美女性生活一级片| 人妻少妇精品久久久久久| 中文字幕免费福利视频6| 97国产精品97久久| 欧美一级片免费在线成人观看| 美女操逼免费短视频下载链接| 大学生A级毛片免费视频| 亚洲精品中文字幕下载| gogo国模私拍视频| 青青青青青青青在线播放视频| 骚货自慰被发现爆操| 国产无遮挡裸体免费直播视频| 色花堂在线av中文字幕九九| 美女操逼免费短视频下载链接| 视频一区 二区 三区 综合| 欧美va不卡视频在线观看| 无码中文字幕波多野不卡 | 91精品高清一区二区三区| 国产成人精品av网站| 天天色天天爱天天爽| 18禁美女羞羞免费网站| 一区二区三区四区视频在线播放| 日本少妇高清视频xxxxx| 亚洲在线免费h观看网站| 天天插天天狠天天操| 亚洲精品无码久久久久不卡 | 国产麻豆剧果冻传媒app| 93人妻人人揉人人澡人人| 亚洲国产第一页在线观看| 成人蜜臀午夜久久一区| 国产又色又刺激在线视频 | 国产之丝袜脚在线一区二区三区| 中文字幕在线第一页成人 | 一区二区视频在线观看免费观看| 久久久久久久精品成人热| 青青青视频手机在线观看| 巨乳人妻日下部加奈被邻居中出| 九一传媒制片厂视频在线免费观看| 大香蕉伊人中文字幕| 精品一区二区三区午夜| weyvv5国产成人精品的视频| 在线观看av观看av| 色哟哟在线网站入口| 大香蕉福利在线观看| 黑人借宿ntr人妻的沦陷2| 夜色福利视频在线观看| 精品久久久久久高潮| 国产精品久久久久久久精品视频| 亚洲欧美成人综合在线观看| 日韩精品二区一区久久| okirakuhuhu在线观看| 欧美80老妇人性视频| 亚洲成人国产av在线| 九九热99视频在线观看97| 午夜久久久久久久精品熟女| 天天干天天爱天天色| 欧美怡红院视频在线观看| 成年人啪啪视频在线观看| 蜜桃视频17c在线一区二区| 最新欧美一二三视频| 国产精品精品精品999| 精品美女福利在线观看| 日比视频老公慢点好舒服啊| 女同性ⅹxx女同hd| 国产大鸡巴大鸡巴操小骚逼小骚逼 | 日本人妻少妇18—xx| 亚洲成人激情av在线| 亚洲综合一区二区精品久久| 一级a看免费观看网站| 亚洲视频在线观看高清| 欧美3p在线观看一区二区三区|