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

這應該是全網最詳細的Vue3.5版本解讀

開發 前端
對于開發者來說Vue3.5版本中還是新增了許多有趣的功能的,比如:onEffectCleanup?函數、onWatcherCleanup?函數、pause和resume?方法、watch的deep?選項支持傳入數字、useId?函數、Teleport?組件新增defer?延遲屬性、useTemplateRef函數。

前言

Vue3.5正式版在這兩天發布了,網上已經有了不少關于Vue3.5版本的解讀文章。但是歐陽發現這些文章對3.5中新增的功能介紹都不是很全,所以導致不少同學有個錯覺,覺得Vue3.5版本不過如此,選擇跳過這個版本等下個大版本再去更新。所以歐陽寫了這篇超級詳細的Vue3.5版本解讀文章,小伙伴們可以看看在3.5版本中有沒有增加一些你期待的功能。

版本號

這次的版本號是天元突破紅蓮螺巖,這是07年出的一個二次元動漫,歐陽是沒看過的。在此之前我一直以為這次的版本號會叫黑神話:悟空,可能悟空不夠二次元吧。

響應式

響應式相關的內容主要分為:重構響應式、響應式props支持解構、新增onEffectCleanup函數、新增base watch函數、新增onWatcherCleanup函數、新增pause和resume方法。

重構響應式

這次響應式的重構是屬于Vue內部優化,對于普通開發者來說是無感的。重構后內存占用減少了56%,優化手段主要是通過版本計數和雙向鏈表數據結構,靈感來源于Preact signals。后續歐陽會出一系列關于響應式相關的源碼文章,大家可以關注一波歐陽。

響應式props支持解構

在3.5中響應式props支持解構終于正式穩定了,在沒有這個功能之前我們想要在js中訪問prop必須要這樣寫:props.name,否則name將會丟失響應式。

有了響應式props解構后,在js中我們就可以直接解構出name來使用,比如下面這樣的代碼:

<script setup lang="ts">
const { name } = defineProps({
  name: String,
});

console.log(name);
</script>

當defineProps搭配解構一起使用后,在編譯時就可以將name處理成props.name。編譯后簡化的代碼如下:

setup(__props) {
  console.log(__props.name);
  const __returned__ = {};
  return __returned__;
}

從上面的代碼可以看到console.log(name)經過編譯后變成了console.log(__props.name),這樣處理后name當然就不會丟失響應式了。

新增onEffectCleanup函數

在組件卸載之前或者下一次watchEffect回調執行之前會自動調用onEffectCleanup函數,有了這個函數后你就不需要在組件的beforeUnmount鉤子函數去統一清理一些timer了。比如下面這個場景:

import { watchEffect, ref } from "vue";
import { onEffectCleanup } from "@vue/reactivity";

const flag = ref(true);
watchEffect(() => {
  if (flag.value) {
    const timer = setInterval(() => {
      // 做一些事情
      console.log("do something");
    }, 200);
    onEffectCleanup(() => {
      clearInterval(timer);
    });
  }
});

上面這個例子在watchEffect中會去注冊一個循環調用的定時器,如果不使用onEffectCleanup,那么我們就需要在beforeUnmount鉤子函數中去清理定時器。

但是有了onEffectCleanup后,將clearInterval放在他的回調中就可以了。當組件卸載時會自動執行onEffectCleanup傳入的回調函數,也就是會執行clearInterval清除定時器。

還有一點值得注意的是onEffectCleanup函數目前沒有在vue包中暴露出來,如果你想使用可以像我這樣從@vue/reactivity包中導入onEffectCleanup函數。

新增base watch函數

我們之前使用的watch函數是和Vue組件以及生命周期一起實現的,他們是深度綁定的,所以watch函數代碼的位置在vue源碼中的runtime-core模塊中。

但是有的場景中我們只想使用vue的響應式功能,也就是vue源碼中的reactivity模塊,比如小程序vuemini。為此我們不得不將runtime-core模塊也導入到項目中,或者像vuemini一樣去手寫一個watch函數。

在3.5版本中重構了一個base watch函數,這個函數的實現和vue組件沒有一毛錢關系,所以他是在reactivity模塊中。詳情可以查看我之前的文章:Vue3.5新增的baseWatch讓watch函數和Vue組件徹底分手

還有一點就是這個base watch函數對于普通開發者來說沒有什么影響,但是對于一些下游項目,比如vuemini來說是和受益的。

新增onWatcherCleanup函數

和前面的onEffectCleanup函數類似,在組件卸載之前或者下一次watch回調執行之前會自動調用onWatcherCleanup函數,同樣有了這個函數后你就不需要在組件的beforeUnmount鉤子函數去統一清理一些timer了。比如下面這個場景:

import { watch, ref, onWatcherCleanup } from "vue";

watch(flag, () => {
  const timer = setInterval(() => {
    // 做一些事情
    console.log("do something");
  }, 200);
  onWatcherCleanup(() => {
    console.log("清理定時器");
    clearInterval(timer);
  });
});

和onEffectCleanup函數不同的是我們可以從vue中import導入onWatcherCleanup函數。

新增pause和resume方法

有的場景中我們可能想在“一段時間中暫停一下”,不去執行watch或者watchEffect中的回調。等業務條件滿足后再去恢復執行watch或者watchEffect中的回調。在這種場景中pause和resume方法就能派上用場啦。

下面這個是watchEffect的例子,代碼如下:

<template>
  <button @click="count++">count++</button>
  <button @click="runner2.pause()">暫停</button>
  <button @click="runner2.resume()">恢復</button>
</template>

<script setup lang="ts">
import { watchEffect } from "vue";

const count = ref(0);
const runner2 = watchEffect(() => {
  if (count.value > 0) {
    console.log(count.value);
  }
});
</script>

在上面的demo中,點擊count++按鈕后理論上每次都會執行一次watchEffect的回調。

但是當我們點擊了暫停按鈕后就會執行pause方法進行暫停,在暫停期間watchEffect的回調就不會執行了。

當我們再次點擊了恢復按鈕后就會執行resume方法進行恢復,此時watchEffect的回調就會重新執行。

console.log的結果如下圖:

圖片圖片

從上圖中可以看到count打印到4后就沒接著打印了,因為我們執行了pause方法暫停了。當重新執行了resume方法恢復后可以看到count又重新開始打印了,此時從8開始打印了。

不光watchEffect可以執行pause和resume方法,watch一樣也可以執行pause和resume方法。代碼如下:

const runner = watch(count, () => {
  if (count.value > 0) {
    console.log(count.value);
  }
});

runner.pause() // 暫停方法
runner.resume() // 恢復方法

watch的deep選項支持傳入數字

在以前deep選項的值要么是false,要么是true,表明是否深度監聽一個對象。在3.5中deep選項支持傳入數字了,表明監控對象的深度。

比如下面的這個demo:

const obj1 = ref({
  a: {
    b: 1,
    c: {
      d: 2,
      e: {
        f: 3,
      },
    },
  },
});

watch(
  obj1,
  () => {
    console.log("監聽到obj1變化");
  },
  {
    deep: 3,
  }
);

function changeDeep3Obj() {
  obj1.value.a.c.d = 20;
}

function changeDeep4Obj() {
  obj1.value.a.c.e.f = 30;
}

在上面的例子watch的deep選項值是3,表明監聽到對象的第3層。

changeDeep3Obj函數中就是修改對象的第3層的d屬性,所以能夠觸發watch的回調。

而changeDeep4Obj函數是修改對象的第4層的f屬性,所以不能觸發watch的回調。

SSR服務端渲染

服務端渲染SSR主要有這幾個部分:新增useId函數、Lazy Hydration  懶加載水合、data-allow-mismatch

新增useId函數

有時我們需要生成一個隨機數塞到DOM元素上,比如下面這個場景:

<template>
  <label :htmlFor="id">Do you like Vue3.5?</label>
  <input type="checkbox" name="vue3.5" :id="id" />
</template>

<script setup lang="ts">
const id = Math.random();
</script>

在這個場景中我們需要生成一個隨機數id,在普通的客戶端渲染中這個代碼是沒問題的。

但是如果這個代碼是在SSR服務端渲染中那么就會報警告了,如下圖:

圖片圖片

上面報錯的意思是服務端和客戶端生成的id不一樣,因為服務端和客戶端都執行了一次Math.random()生成id。由于Math.random()每次執行的結果都不同,自然服務端和客戶端生成的id也不同。

useId函數的作用就是為了解決這個問題。

當然useId也可以用于客戶端渲染的一些場景,比如在列表中我們需要一個唯一鍵,但是服務端又沒有給我們,這時我們就可以使用useId給列表中的每一項生成一個唯一鍵。

Lazy Hydration  懶加載水合

異步組件現在可以通過 defineAsyncComponent() API 的 hydrate 選項來控制何時進行水合。(歐陽覺得這個普通開發者用不上,所以就不細講了)

data-allow-mismatch

SSR中有的時候確實在服務端和客戶端生成的html不一致,比如在DOM上面渲染當前時間,代碼如下:

<template>
  <div>當前時間是:{{ new Date() }}</div>
</template>

這種情況是避免不了會出現前面useId例子中的那種警告,此時我們可以使用data-allow-mismatch屬性來干掉警告,代碼如下:

<template>
  <div data-allow-mismatch>當前時間是:{{ new Date() }}</div>
</template>

Custom Element 自定義元素改進

這個歐陽也覺得平時大家都用不上,所以就不細講了。

Teleport組件新增defer延遲屬性

Teleport組件的作用是將children中的內容傳送到指定的位置去,比如下面的代碼:

<div id="target"></div>
<Teleport to="#target">被傳送的內容</Teleport>

文案被傳送的內容最終會渲染在id="target"的div元素中。

在之前有個限制,就是不能將<div id="target">放在Teleport組件的后面。

這個也很容易理解DOM是從上向下開始渲染的,如果先渲染到Teleport組件。然后就會去找id的值為target的元素,如果找不到當然就不能成功的將Teleport組件的子節點傳送到target的位置。

在3.5中為了解決這個問題,在Teleport組件上新增了一個defer延遲屬性。

加了defer延遲屬性后就能將target寫在Teleport組件的后面,代碼如下:

<Teleport defer to="#target">被傳送的內容</Teleport>
<div id="target"></div>

defer延遲屬性的實現也很簡單,就是等這一輪渲染周期結束后再去渲染Teleport組件。所以就算是target寫在Teleport組件的后面,等到渲染Teleport組件的時候target也已經渲染到頁面上了。

useTemplateRef函數

vue3中想要訪問DOM和子組件可以使用ref進行模版引用,但是這個ref有一些讓人迷惑的地方。

比如定義的ref變量到底是一個響應式數據還是DOM元素?

還有template中ref屬性的值明明是一個字符串,比如ref="inputEl",怎么就和script中同名的inputEl變量綁到一塊了呢?

3.5中的useTemplateRef函數就可以完美的解決了這些問題。

這是3.5之前使用ref訪問input輸入框的例子:

<input type="text" ref="inputEl" />

const inputEl = ref<HTMLInputElement>();

這個寫法很不符合編程直覺,不知道有多少同學和歐陽一樣最開始用vue3時會給ref屬性綁定一個響應式變量。比如這樣::ref="inputEl"

更加要命的是這樣寫還不會報錯,就是inputEl中的值一直是undefined。

最后一番排查后才發現ref屬性應該是綁定的變量名稱:ref="inputEl"

使用useTemplateRef函數后就好多了,代碼如下:

<input type="text" ref="inputRef" />

const inputEl = useTemplateRef<HTMLInputElement>("inputRef");

使用useTemplateRef函數后會返回一個ref變量,useTemplateRef函數傳的參數是字符串"inputRef"。

在template中ref屬性的值也是字符串"inputRef",所以useTemplateRef函數的返回值就指向了DOM元素input輸入框。這個比3.5之前的體驗要好很多了,詳情可以查看我之前的文章:牛逼!Vue3.5的useTemplateRef讓ref操作DOM更加絲滑

總結

對于開發者來說Vue3.5版本中還是新增了許多有趣的功能的,比如:onEffectCleanup函數、onWatcherCleanup函數、pause和resume方法、watch的deep選項支持傳入數字、useId函數、Teleport組件新增defer延遲屬性、useTemplateRef函數。

這些功能在一些特殊場景中還是很有用的,歐陽的個人看法還是得將Vue升到3.5。

責任編輯:武曉燕 來源: 前端歐陽
相關推薦

2017-12-19 17:54:31

前端ajax跨域cors

2024-09-02 08:48:45

2015-12-01 10:54:49

安全產品采購供應商選擇信息安全官

2024-09-04 11:42:17

Vue3.5源碼API

2023-07-10 18:30:48

2014-07-28 10:22:05

5G5G網絡無線網絡

2012-12-27 14:54:48

簡歷求職者

2021-01-15 23:28:50

區塊鏈開發數字化

2024-11-06 10:47:53

2022-12-01 16:56:03

智慧城市安全環境能源

2020-03-19 15:21:57

智慧城市藝術社會

2015-09-16 09:09:46

設計WindowsLinux

2017-09-04 16:43:08

Linux云原生環境開源

2018-08-23 17:38:01

多云混合云云平臺

2018-08-29 11:14:32

2017-03-21 15:20:11

數據團隊模式思路

2023-10-13 08:51:11

IT員工iPod

2023-07-11 16:36:28

數據管理

2023-05-29 15:55:39

2012-11-29 10:50:34

點贊
收藏

51CTO技術棧公眾號

精品一区二区三区免费播放| 久久99国产精品视频| 亚洲最快最全在线视频| 国产精品午夜av在线| 无码人妻精品一区二区| 91免费精品| 欧美一级片在线观看| 青青草精品视频在线| 北岛玲日韩精品一区二区三区| 国产在线一区二区| 97成人精品区在线播放| 青花影视在线观看免费高清| 欧美日韩精品一区二区三区在线观看| 欧美日韩情趣电影| 每日在线更新av| 好了av在线| 91视频免费看| http;//www.99re视频| 男人的天堂av网站| 亚洲日本国产| 另类专区欧美制服同性| 少妇光屁股影院| 成人豆花视频| 欧美色网站导航| 九一国产精品视频| 在线观看wwwxxxx| 国产精品女人毛片| 欧美成ee人免费视频| 亚洲xxx在线| 美女性感视频久久| 国产成人精品久久亚洲高清不卡| 欧美国产日韩在线观看成人| 成人精品久久| 亚洲女人天堂色在线7777| 性一交一黄一片| 国产aa精品| 欧美日韩久久一区| 国产激情在线观看视频| 妞干网免费在线视频| 亚洲影院免费观看| 大桥未久一区二区三区| 日本中文字幕伦在线观看| 久久精品亚洲麻豆av一区二区| 国产一区二区三区黄| 亚洲欧美黄色片| 国产精品1024| 99国产在线视频| 99热这里精品| 国产美女av一区二区三区| 国产欧美婷婷中文| 亚洲一二区视频| 久久精品国产成人一区二区三区| 国产精品久久久久久久久久| 国产第一页在线观看| 爽爽淫人综合网网站| 日本中文字幕不卡免费| 潘金莲一级淫片aaaaaa播放| 噜噜噜久久亚洲精品国产品小说| 欧美中文在线免费| 久久夜色精品国产噜噜亚洲av| 国产精品一卡| 国产成人精品在线视频| 亚洲精品无码久久久久| 免费在线视频一区| 成人精品aaaa网站| aa视频在线免费观看| 国产高清久久久| 国产精品乱码| 黄色片在线看| 国产精品丝袜在线| 做爰高潮hd色即是空| dj大片免费在线观看| 亚洲自拍与偷拍| 成人免费观看cn| 高清不卡亚洲| 欧美日韩一区中文字幕| 超碰在线资源站| 99re8这里有精品热视频8在线| 日韩成人高清在线| 手机在线成人av| 青青草国产免费一区二区下载| 亚洲最新av在线网站| 91狠狠综合久久久| 亚洲国产精品一区| 国产精品视频26uuu| 国产成人精品一区二三区四区五区 | 成人av在线资源| 久久66热这里只有精品| 成人在线观看一区| 一区二区三区中文字幕在线观看| 欧美日韩福利在线| 日本美女久久| 精品第一国产综合精品aⅴ| 三上悠亚影音先锋| 欧美福利在线| 国产成人一区二区在线| aaa一区二区| 久久婷婷综合激情| 精品久久免费观看| 欧洲一区精品| 6080午夜不卡| 欧美老熟妇乱大交xxxxx| 天天揉久久久久亚洲精品| 国内精品免费午夜毛片| 在线观看国产精品入口男同| 成av人片一区二区| 一区二区免费在线观看| 天堂а√在线最新版中文在线| 欧美日韩国产精选| 国产男女猛烈无遮挡a片漫画 | 精品人妻少妇一区二区| 久久精品超碰| 精品爽片免费看久久| 精品国产视频一区二区三区| 在线视频免费在线观看一区二区| 91精品久久久久久久久久 | 亚洲国产中文在线二区三区免| 亚洲欧美三级在线| 久久成人在线观看| 激情图片小说一区| 欧美一区二区三区在线免费观看| 青春草视频在线观看| 欧美日韩卡一卡二| 性少妇bbw张开| 激情婷婷久久| 亚洲综合中文字幕在线| 午夜毛片在线| 日本精品一级二级| 一起草在线视频| 欧美日韩1区2区3区| 国产伊人精品在线| p色视频免费在线观看| 欧美午夜激情视频| 亚洲观看黄色网| 狠狠入ady亚洲精品经典电影| 国产免费一区二区三区在线能观看| 日韩私人影院| 午夜精品久久久久久久99水蜜桃| 曰本三级日本三级日本三级| 图片区亚洲欧美小说区| 国产这里只有精品| 日本视频在线| 欧美日韩国产另类不卡| 天堂av网手机版| 免费av网站大全久久| 欧日韩一区二区三区| 成人美女视频| 亚洲色图美腿丝袜| 男人天堂视频网| 欧美激情中文字幕一区二区| 五月天婷婷激情视频| 欧美色图激情小说| 国产精品旅馆在线| 日本欧美在线视频免费观看| 欧美久久久久免费| 成人观看免费视频| 成人免费va视频| 国模无码视频一区二区三区| 日韩精选在线| 69影院欧美专区视频| 青青草在线免费视频| 欧洲生活片亚洲生活在线观看| 精品无码人妻一区二区免费蜜桃| 水蜜桃久久夜色精品一区的特点| 亚洲国产精品123| 亚洲精品大全| 欧美激情网友自拍| 午夜激情在线视频| 91国产精品成人| 久久av红桃一区二区禁漫| 国产一区二区三区四区五区美女| 欧美精品在欧美一区二区| 加勒比色老久久爱综合网| 久久久在线视频| 每日更新av在线播放| 欧美午夜电影网| 国产黄色片在线免费观看| 99久久国产综合精品女不卡| 黄色三级视频在线| 中文字幕一区二区av | 午夜精品福利一区二区三区av | 日本成熟性欧美| 自拍视频在线播放| 日韩精品一区二区三区三区免费| 久久久久久久久久免费视频| 中文在线一区二区 | 国产三级精品三级在线观看国产| 国产成人综合精品在线| 先锋影音在线资源站91| 亚洲精品小视频| 国产美女自慰在线观看| 午夜精品久久久久久| 91免费在线看片| 成人av在线资源网站| 丝袜制服一区二区三区| 欧美日本精品| 亚洲欧洲一区二区福利| 国产成人aa在线观看网站站| 人九九综合九九宗合| 性xxxfreexxxx性欧美| 亚洲欧美一区二区三区情侣bbw| 波多野结衣一区二区三区四区| 亚洲在线成人精品| 色婷婷国产精品免| 99视频精品全部免费在线| 中文字幕中文在线| 国产精品亚洲综合久久| 亚洲电影一二三区| 国产精品毛片久久久| 成人免费观看网址| 一二区成人影院电影网| 98精品在线视频| 羞羞网站在线免费观看| 久久精品国产视频| 成人亚洲综合天堂| 日韩电影大全免费观看2023年上| 国产片在线播放| 欧美日韩一级视频| 中文字幕xxxx| 精品高清一区二区三区| 久久精品久久精品久久| 亚洲欧美日韩在线播放| 国产极品视频在线观看| 久久久久久久久久久久久女国产乱 | 久久综合资源网| 成人欧美精品一区二区| 国产在线精品一区二区三区不卡| 免费看国产黄色片| 肉丝袜脚交视频一区二区| 欧美日韩亚洲一| 夜夜爽av福利精品导航| 欧美久久久久久久久久久久久| 亚洲婷婷免费| 欧美中日韩在线| 在线播放不卡| 日本福利视频一区| 国内久久精品| 成年人看的毛片| 伊人久久婷婷| 日本xxxxxxxxxx75| 一本久道久久综合狠狠爱| 好吊妞无缓冲视频观看| 亚洲美女色禁图| av动漫在线观看| 久久精品动漫| 性欧美极品xxxx欧美一区二区| 日韩精品久久理论片| www.激情小说.com| 久久99精品国产麻豆不卡| 中文字幕22页| 国产成人免费视频网站| 久久久久亚洲AV成人网人人小说| 国产成人精品免费网站| 国产免费一区二区三区最新6| 不卡免费追剧大全电视剧网站| 69亚洲乱人伦| 久久久久久久av麻豆果冻| 精品成人无码一区二区三区| 国产日韩亚洲欧美综合| 国产3级在线观看| 一区二区不卡在线视频 午夜欧美不卡在 | 秋霞av鲁丝片一区二区| 亚洲精品国产成人| 国产黄在线观看| 久久在线观看视频| 懂色av一区| 欧美最猛性xxxxx(亚洲精品)| 视频二区不卡| 成人情趣片在线观看免费| 一区中文字幕| 女人一区二区三区| 亚洲欧美偷拍自拍| 日本a在线免费观看| 玖玖精品视频| 亚洲视频在线不卡| 91在线高清观看| www.4hu95.com四虎| 一区二区三区美女| 黄色污污网站在线观看| 欧美猛男男办公室激情| 蜜桃视频在线观看www| 亚洲视频在线视频| 污视频网站在线免费| 国产91色在线| 精品91福利视频| 久久久久久久久久久久久久一区 | 成人一级片在线观看| 日本黄色网址大全| 亚洲三级在线看| 精品欧美一区二区三区免费观看 | 日韩欧美午夜| 国产自产在线视频| 久久激情五月激情| 97香蕉碰碰人妻国产欧美| 国产精品美女久久久久高潮| 日本中文字幕网| 欧美日韩成人综合在线一区二区| 涩涩视频免费看| 久久久国产一区二区| 亚洲电影观看| 成人一区二区在线| 欧美激情电影| 国产精品亚洲a| 国产很黄免费观看久久| 蜜桃av乱码一区二区三区| 亚洲国产精品久久久男人的天堂 | 99精品一级欧美片免费播放| 亚洲欧美卡通另类91av| 性生活在线视频| 国产精品久久久久影院亚瑟 | 欧美区在线观看| 欧美孕妇孕交xxⅹ孕妇交| 欧美肥婆姓交大片| 婷婷久久免费视频| 色女人综合av| 毛片一区二区| 精品无码在线视频| 午夜伊人狠狠久久| 亚洲国产精品suv| 久久成人精品一区二区三区| 日韩欧美少妇| 青娱乐一区二区| 久久aⅴ国产紧身牛仔裤| jjzzjjzz欧美69巨大| 亚洲免费在线观看视频| 91禁在线观看| 中文字幕日韩av综合精品| 日韩大片欧美大片| 欧美黄色直播| 久久久久.com| 免费毛片视频网站| 日韩欧美在线中文字幕| 婷婷国产在线| 欧美性受xxx| 亚洲婷婷伊人| 少妇激情一区二区三区| 国产校园另类小说区| 国产熟妇一区二区三区四区| 亚洲女人被黑人巨大进入| 日韩大尺度黄色| 色播五月综合| 韩国欧美一区二区| 免费在线观看黄色av| 欧美电影免费提供在线观看| 亚洲综合伊人久久大杳蕉| 91视频在线免费观看| 午夜精品影院| 在线免费看黄色片| 精品人伦一区二区三区蜜桃免费| 天堂成人在线观看| 欧美最近摘花xxxx摘花| 精品国产一区二区三区四区| 黄色aaa级片| 中文字幕在线不卡国产视频| 国产美女无遮挡永久免费| 欧美激情2020午夜免费观看| 精品嫩草影院| 成熟老妇女视频| 中文字幕制服丝袜成人av| 99精品视频在线播放免费| 欧美华人在线视频| 日韩成人av在线资源| 久久久精品三级| 亚洲欧美激情一区二区| 免费国产黄色片| 奇米一区二区三区四区久久| 欧美日韩亚洲在线观看| 欧美视频亚洲图片| 亚洲一区二区三区国产| 男女污污视频在线观看| 成人乱人伦精品视频在线观看| 欧美婷婷在线| 色婷婷在线影院| 777亚洲妇女| 国产污视频在线播放| 亚洲日本欧美在线| 国产成人av电影在线| 国产一区二区视频网站| 久久精品一区中文字幕| 国产一区在线电影| www.久久91| 午夜视频在线观看一区二区 | 国产激情久久久久久熟女老人av| 久久久91精品| 美女视频亚洲色图| 中文久久久久久| 亚洲国产精品尤物yw在线观看| 毛片在线播放网站| www.久久爱.cn| 日韩经典中文字幕一区| 久草资源在线视频| 国产一区二区精品丝袜| 999久久久精品一区二区| 久久久国产欧美| 欧美日韩国产色| 免费网站免费进入在线| 久久综合精品一区| 国产精品亚洲专一区二区三区 | 樱桃视频成人在线观看| 日韩国产精品毛片|