人妻精品在线观看一区二区三区,蜜臀av精品一区二区三区网站,中文一区二区三区亚洲欧美,熟女人妇精品一区二区,人妻av在线观看视频,欧美日韩国产三级精品网站,黄色免费网站直接进入,超碰公开福利正在播放,国产毛片乡下农村妇女毛片

帶你聊聊typeScript中的extends關(guān)鍵字

來源:php中文網(wǎng) | 2023-02-13 19:56:21 |

extends是 typeScript 中的關(guān)鍵字。在 typeScript 的類型編程世界里面,它所扮演的角色實(shí)在是太重要了,所以,我們不得不需要重視它,深入學(xué)習(xí)它。在我看來,掌握它就是進(jìn)入高級(jí) typeScript 類型編程世界的敲門磚。但是,現(xiàn)實(shí)是,它在不同的上下文中,具體不同的,相差很大的語義。如果沒有深入地對(duì)此進(jìn)行梳理,它會(huì)給開發(fā)者帶來很大的困惑。梳理并深入學(xué)習(xí)它,最后掌握它,這就是我編寫這篇文章的初衷。


【資料圖】

extends 的幾個(gè)語義

讓我們開門見山地說吧,在 typeScript 在不同的上下文中,extends有以下幾個(gè)語義。不同語義即有不同的用途:

用于表達(dá)類型組合;用于表達(dá)面向?qū)ο笾小割悺沟睦^承用于表達(dá)泛型的類型約束;在條件類型(conditional type)中,充當(dāng)類型表達(dá)式,用于求值。

extends 與 類型組合/類繼承

extends可以跟 interface結(jié)合起來使用,用于表達(dá)類型組合。

示例 1-1

interface ChildComponentProps {    onChange: (val: string)=> void}interface ParentComponentProps extends ChildComponentProps {    value: string}

在 react 組件化開發(fā)模式中,存在一種自底向上的構(gòu)建模式 - 我們往往會(huì)先把所有最底層的子組件的 props構(gòu)建好,最后才定義 container component(負(fù)責(zé)提升公共 state,聚合和分發(fā) props) 的 props。此時(shí),inferface 的 extends正好能表達(dá)這種語義需求 - 類型的組合(將所有子組件的 props聚合到一塊)。

當(dāng)然,interfaceextends從句是可以跟著多個(gè)組合對(duì)象,多個(gè)組合對(duì)象之間用逗號(hào),隔開。比如ParentComponentProps組合多個(gè)子組件的 props

示例 1-2

interface ChildComponentProps {    onChange: (val: string)=> void}interface ChildComponentProps2 {    onReset: (value: string)=> void}interface ParentComponentProps extends ChildComponentProps, ChildComponentProps2 {    value: string}

注意,上面指出的是「多個(gè)組合對(duì)象」,這里也包括了Class。對(duì),就是普通面向概念中的「類」。也就是說,下面的代碼也是合法的:

示例 1-3

interface ChildComponentProps {    onChange: (val: string)=> void}interface ChildComponentProps2 {    onReset: (value: string)=> void}class SomeClass {    private name!: string // 變量聲明時(shí),變量名跟著一個(gè)感嘆號(hào)`!`,這是「賦值斷言」的語法    updateName(name:string){        this.name = name || ""    }}interface ParentComponentProps extendsChildComponentProps,ChildComponentProps2,SomeClass {    value: string}

之所以這也是合法的,一切源于一個(gè)特性:在 typeScript 中,一個(gè) class 變量既是「值」也是「類型」。在interface extends class的上下文中,顯然是取 class 是「類型」的語義。一個(gè) interface extends另外一個(gè) class,可以理解為 interface 拋棄這個(gè) class 的所有實(shí)現(xiàn)代碼,只是跟這個(gè) class 的「類型 shape」 進(jìn)行組合。還是上面的示例代碼中,從類型 shape 的角度,SomeClass就等同于下面的 interface:

示例 1-4

interface SomeClass {   name: string   updateName: (name:string)=> void}

好了,以上就是 extends關(guān)鍵字的「類型組合」的語義。事情開始發(fā)生了轉(zhuǎn)折。

如果某個(gè) interface A 繼承了某個(gè) class B,那么這個(gè) interface A 還是能夠被其他 interface 去繼承(或者說組合)。但是,如果某個(gè) class 想要 implements這個(gè) interface A,那么這個(gè) class 只能是 class B 本身或者 class B 的子類。

示例 1-5

class Control {   private state: any;  constructor(intialValue: number){    if(intialValue > 10){      this.state = false    }else {      this.state = true    }  }  checkState(){    return this.state;  }}interface SelectableControl extends Control {  select(): void;}// 下面的代碼會(huì)報(bào)錯(cuò):Class "DropDownControl" incorrectly implements interface// "SelectableControl".// Types have separate declarations of a private property "state".(2420)class DropDownControl  implements SelectableControl {  private state = false;  checkState(){    // do something  }  select(){    // do something  }}

要想解決這個(gè)問題,class DropDownControl必須要繼承 Controlclass 或者Controlclass 的子類:

示例 1-6

class Control {   private state: any;  constructor(intialValue: number){    if(intialValue > 10){      this.state = false    }else {      this.state = true    }  }  checkState(){    return this.state;  }}interface SelectableControl extends Control {  select(): void;}// 下面的代碼就不會(huì)報(bào)錯(cuò),且能得到預(yù)期的運(yùn)行結(jié)果class DropDownControl  extends Control  implements SelectableControl {  // private state = false;  //checkState(){    // do something  //}  select(){    // do something  }}const dropDown = new DropDownControl(1);dropDown.checkState(); // OkdropDown.select(); // Ok

上面這個(gè)示例代碼扯出了 extends關(guān)鍵字的另外一個(gè)語義 - 「繼承」。當(dāng)extends用于 typeScript 的類之間,它的準(zhǔn)確語義也就是 ES6 中面向?qū)ο笾小竐xtends」關(guān)鍵字的語義。AClass extends BClass不再應(yīng)該解讀為「類型的組合」而是面向?qū)ο缶幊讨械摹窤Class 繼承 BClass」和「AClass 是父類 BClass 的子類」。與此同時(shí),值得指出的是,此時(shí)的 extends關(guān)鍵字是活在了「值的世界」, 遵循著 ES6 中 extends關(guān)鍵字一樣的語義。比較顯著的一點(diǎn)就是,ts 中的 extends也是不能在同一時(shí)間去繼承多個(gè)父類的。比如,下面的代碼就會(huì)報(bào)錯(cuò):

示例 1-7

class A {}class B {}// 報(bào)錯(cuò): Classes can only extend a single class.(1174)class C extends A,B {}

關(guān)于具有「繼承」語義的 extends更多行為特性的闡述已經(jīng)屬于面向?qū)ο缶幊谭妒降姆懂犃?,這里就不深入討論了,有興趣的同學(xué)可以自行去了解。

至此,我們算是了解 extends關(guān)鍵字跟 interfaceclass結(jié)合起來所表達(dá)的兩種不同的語義:

類型的組合面向?qū)ο蟾拍钪小割惖睦^承」

接下來,我們看看用于表達(dá)泛型類型約束的 extends

extends 與類型約束

更準(zhǔn)確地說,這一節(jié)是要討論 extends跟泛型形參結(jié)合時(shí)候的「類型約束」語義。在更進(jìn)一步討論之前,我們不妨先復(fù)習(xí)一下,泛型形參聲明的語法以及我們可以在哪些地方可以聲明泛型形參。

具體的泛型形參聲明語法是:

標(biāo)識(shí)符后面用尖括號(hào)<>包住一個(gè)或者多個(gè)泛型形參

多個(gè)泛型形參用,號(hào)隔開

泛型新參的名字可以隨意命名(我們見得最多就是使用單個(gè)英文字母T,U之類的)。

在 typeScript 中,我們可以在以下地方去聲明一個(gè)泛型形參。

在普通的函數(shù)聲明中:
function dispatch<A>(action: A): A {    // Do something}
在函數(shù)表達(dá)式形態(tài)的類型注解中:
const dispatch: <A>(action: A)=> A =  (action)=> {  return action}// 或者interface Store { dispatch: <A>(action: A)=> A}
interface的聲明中:
interface Store<S> { dispatch: <A>(action: A)=> A reducer: <A>(state: S,action: A)=> S}
class的聲明中:
class GenericAdd<AddableType> {  zeroValue!: AddableType;  add!: (x: AddableType, y: AddableType) => AddableType;}let myGenericNumber = new GenericNumber<number>();myGenericNumber.zeroValue = 0;myGenericNumber.add = function (x, y) {    return x + y;};
在自定義類型聲明中:
type Dispatch<A>=(action:A)=> A
在類型推導(dǎo)中:typeScript // 此處,F(xiàn) 和 Rest 就是泛型形參 type GetFirstLetter<S> = S extends `${infer F extends `${number}`}${infer Rest}` ? F : S; 以上就是簡單梳理后的可以產(chǎn)生泛型形參的地方,可能還有疏漏,但是這里就不深入發(fā)掘了。

下面重點(diǎn)來了 - 凡是有泛型形參的地方,我們都可以通過 extends來表達(dá)類型約束。這里的類型約束展開說就是,泛型形參在實(shí)例化時(shí)傳進(jìn)來的類型實(shí)參必須要滿足我們所聲明的類型約束。到這里,問題就來了,我們該怎樣來理解這里的「滿足」呢?在深究此問題之前,我們來看看類型約束的語法:

`泛型形參` extends `某個(gè)類型`

為了引出上面所說「滿足」的理解難題,我們不妨先看看下面的示例的代碼:

示例 2-1

// case 1type UselessType<T extends number> = T;type Test1 = UselessType<any> // 這里會(huì)報(bào)錯(cuò)嗎?type Test1_1 = UselessType<number|string> // 這里會(huì)報(bào)錯(cuò)嗎?// case 2type UselessType2<T extends {a:1, b:2}> = T;type Test2 = UselessType2<{a:1, b:2, c:3}> // 這里會(huì)報(bào)錯(cuò)嗎?type Test2_1 = UselessType2<{a:1}> // 這里會(huì)報(bào)錯(cuò)嗎?type Test2_2 = UselessType2<{[key:string]: any}> // 這里會(huì)報(bào)錯(cuò)嗎?type Test2_3 = {a:1, b:2} extends  {[key:string]: any} ? true : false// case 3class BaseClass {    name!: string}class SubClass extends  BaseClass{    sayHello!: (name: string)=> void}class SubClass2 extends  SubClass{    logName!: ()=> void}type UselessType3<T extends SubClass> = T;type Test3 = UselessType3<{name: "鯊叔"}> // 這里會(huì)報(bào)錯(cuò)嗎?type Test3_1 = UselessType3<SubClass> // 這里會(huì)報(bào)錯(cuò)嗎?type Test3_2 = UselessType3<BaseClass> // 這里會(huì)報(bào)錯(cuò)嗎?

不知道讀者朋友們在沒有把上述代碼拷貝到 typeScript 的 playground 里面去驗(yàn)證之前你是否能全部猜中。如果能,證明你對(duì) extends在類型約束的語義上下文中的行為表現(xiàn)已經(jīng)掌握的很清楚了。如果不能,請?jiān)试S我為你娓娓道來。

相信有部分讀者了解過 typeScript 的類型系統(tǒng)的設(shè)計(jì)策略。由于 js 是一門動(dòng)態(tài)弱類型的腳本語言,再加上需要考慮 typeScript 與 js 的互操性和兼容性。所以, typeScript 類型系統(tǒng)被設(shè)計(jì)為一個(gè)「structural typing」系統(tǒng)(結(jié)構(gòu)化類型系統(tǒng))。所謂的結(jié)構(gòu)化類型系統(tǒng)的一個(gè)顯著的特點(diǎn)就是 - 具有某個(gè)類型 A 的值是否能夠賦值給另外一個(gè)類型 B 的值的依據(jù)是,類型 A 的類型結(jié)構(gòu)是否跟類型 B 的類型結(jié)構(gòu)是否兼容。而類型之間是否兼容看重的類型的結(jié)構(gòu)而不是類型的名字。再說白一點(diǎn),就是 B 類型有的屬性和方法,你 A 類型也必須有。到這里,就很容易引出一個(gè)廣為大眾接受的,用于理解類型「可賦值性」行為的心智模型,即:

用集合的角度去看類型。故而這里有「父集」和 「子集」的概念,「父集」包含 「子集」;

在 typeScript 的類型系統(tǒng)中, 子集類型是可以賦值給父集類型。

在泛型形參實(shí)例化時(shí),如果 extends前面的類型是它后面的類型的子集,那么我們就說當(dāng)前的實(shí)例化是「滿足」我們所聲明的類型約束的。

以下是 示例 2-1的運(yùn)行結(jié)果:

實(shí)際上,上面的那個(gè)心智模型是無法匹配到以上示例在 typeScript@4.9.4 上的運(yùn)行結(jié)果。以上面這個(gè)心智模型(子集類型能賦值給父集類型,反之則不然)來看示例的運(yùn)行結(jié)果,我們會(huì)有下面的直覺認(rèn)知偏差:

case 1 中,anynumber的父集,為什么它能賦值給 number類型的值?case 1 中,number | string應(yīng)該是 number的父集,所以,它不能賦值給 number類型的值。case 1 中,number & string應(yīng)該是 number的父集,按理說,這里應(yīng)該報(bào)錯(cuò),但是為什么卻沒有?case 2 中,{a:1}{a:1,b:2}的子集,按理說,它能賦值給 {a:1,b:2}類型的值啊,為什么會(huì)報(bào)錯(cuò)?case 3 中,感覺{name: "鯊叔"}SubClass的子集,按理說,它能賦值給 SubClass類型的值啊,為什么會(huì)報(bào)錯(cuò)?case 3 中,感覺BaseClassSubClass的子集,按理說,它能賦值給 SubClass類型的值啊,為什么會(huì)報(bào)錯(cuò)?

經(jīng)過反復(fù)驗(yàn)證和查閱資料,正確的認(rèn)知如下:

case 1 中,any是任何類型的子集,也是任何類型的父集。這里 typeScript 往寬松方向去處理,即取 number的子集之意;number | string之所以不能賦值給 number,并不是因?yàn)?number | stringnumber的父集,而是因?yàn)槁?lián)合類型遇到 extends關(guān)鍵字所產(chǎn)生的「分配律」的結(jié)果。即是因?yàn)?number|string extends number的結(jié)果等于 (number extend number) | (string extends number)的結(jié)果。顯然,(number string extends number的值是 false的,所以,整個(gè)類型約束就不滿足;對(duì)象類型的類型不能采用 子集類型 extends 父集類型 = true的心智模型來理解。而是得采用 父集類型 extends 子集類型 = true。與此同時(shí),當(dāng)子集類型中有明確字面量 key-value 對(duì)的時(shí)候,父集類型中也必須需要有。否則的話,就是不可賦值給子集類型。number & string應(yīng)該被視為對(duì)象類型的類型,遵循上面一條的規(guī)則。

基于上面的正確認(rèn)知,我們不妨把我們的心智模型修正一下:

應(yīng)該使用「父類型」和「子類型」的概念去理解滿足類型約束背后所遵循的規(guī)則;在類型約束 AType extends BType中,如果 ATypeBType的子類型,那么我們就會(huì)說 AType是滿足我們所聲明的類型約束的;根據(jù)下面的 「ts 類型層級(jí)關(guān)系圖」來判斷兩種類型的父-子類型關(guān)系:

關(guān)于上面這張圖,有幾點(diǎn)可以單獨(dú)拿出來強(qiáng)調(diào)一下:

any無處不在。它既是任何類型的子類型,也是任何類型的父類型,甚至可能是任意類型自己。所以,它可以賦值給任何類型;{}充當(dāng) typeScript 類型的時(shí)候,它是有特殊含義的 - 它對(duì)應(yīng)是(Object.prototype.__proto__)=null在 js 原型鏈上的地位,它被視為所有的對(duì)象類型的基類。array的字面量形式的子類型就是tuple,function的字面量形式的子類型就是函數(shù)表達(dá)式類型。tuple函數(shù)表達(dá)式類型都被囊括到 字面量類型中去。

現(xiàn)在我們用這個(gè)新的心智模型去理解一下 示例 2-1報(bào)錯(cuò)的地方:

type Test1_1 = UselessType<number|string>之所以報(bào)錯(cuò),是因?yàn)樵陬愋图s束中,如果 extends前面的類型是聯(lián)合類型,那么要想滿足類型約束,則聯(lián)合類型的每一個(gè)成員都必須滿足類型約束才行。這就是所謂的「聯(lián)合類型的分配律」。顯然,string extends number是不成立的,所以整個(gè)聯(lián)合類型就不滿足類型約束;對(duì)于對(duì)象類型的類型 - 即強(qiáng)調(diào)由屬性和方法所組成的集合類型,我們需要先用面向?qū)ο蟮母拍顏泶_定兩個(gè)類型中,誰是子類,誰是父類。這里的判斷方法是 - 如果 A 類型相比 B 類型多出了一些屬性/方法的話(這也同時(shí)意味著 B 類型擁有的屬性或者方法,A 類型也必須要有),那么 A 類型就是父類,B 類型就是子類。然后,我們再轉(zhuǎn)換到子類型和父類型的概念上來 - 父類就是「父類型」,子類就是「子類型」。type Test2_1 = UselessType2<{a:1}> 之所以報(bào)錯(cuò),是因?yàn)?code>{a:1}是{a:1, b:2}的父類型,所以是不能賦值給{a:1, b:2};{[key:string]: any}并不能成為 {a:1, b:2}的子類型,因?yàn)?,父類型有的屬?方法,子類型必須顯式地?fù)碛小?code>{[key:string]: any}沒有顯式地?fù)碛校?,它不?{a:1, b:2}的子類型,而是它的父類型。type Test3 = UselessType3<{name: "鯊叔"}>type Test3_2 = UselessType3<BaseClass> 報(bào)錯(cuò)的原因也是因?yàn)橐驗(yàn)槿鄙倭讼鄳?yīng)的屬性/方法,所以,它們都不是SubClass的子類型。

到這里,我們算是剖析完畢。下面總結(jié)一下。

當(dāng) extends緊跟在泛型形參后面時(shí),它是在表達(dá)「類型約束」的語義;在 AType extends BType中,只有 ATypeBType的子類型,ts 通過類型約束的檢驗(yàn);面對(duì)兩個(gè) typeScript 類型,到底誰是誰的子類型,我們可以根據(jù)上面給出的 「ts 類型層級(jí)關(guān)系圖」來判斷。而對(duì)于一些充滿迷惑的邊緣用例,死記硬背即可。

extends 與條件類型

眾所周知,ts 中的條件類型就是 js 世界里面的「三元表達(dá)式」。只不過,相比值世界里面的三元表達(dá)式最終被計(jì)算出一個(gè)「值」,ts 的三元表達(dá)式最終計(jì)算出的是「類型」。下面,我們先來復(fù)習(xí)一下它的語法:

AType extends BType ?  CType :  DType

在這里,extends關(guān)鍵字出現(xiàn)在三元表達(dá)的第一個(gè)子句中。按照我們對(duì) js 三元表達(dá)式的理解,我們對(duì) typeScript 的三元表達(dá)式的理解應(yīng)該是相似的:如果 AType extends BType為邏輯真值,那么整個(gè)表達(dá)式就返回 CType,否則的話就返回DType。作為過來人,只能說,大部分情況是這樣的,在幾個(gè)邊緣 case 里面,ts 的表現(xiàn)讓你大跌眼鏡,后面會(huì)介紹。

跟 js 的三元表達(dá)式支持嵌套一樣,ts 的三元表達(dá)式也支持嵌套,即下面也是合法的語法:

AType extends BType ?  (CType extends DType ? EType : FType) : (GType extends HType ? IType : JType)

到這里,我們已經(jīng)看到了 typeScript 的類型編程世界的大門了。因?yàn)?,三元表達(dá)式本質(zhì)就是條件-分支語句,而后者就是邏輯編輯世界的最基本的要素了。而在我們進(jìn)入 typeScript 的類型編程世界之前,我們首要搞清楚的是,AType extends BType何時(shí)是邏輯上的真值。

幸運(yùn)的是,我們可以復(fù)用「extends 與類型約束」上面所產(chǎn)出的心智模型。簡而言之,如果 ATypeBType的子類型,那么代碼執(zhí)行就是進(jìn)入第一個(gè)條件分支語句,否則就會(huì)進(jìn)入第二個(gè)條件分支語句。

上面這句話再加上「ts 類型層級(jí)關(guān)系圖」,我們幾乎可以理解AType extends BType99% 的語義。還剩下 1% 就是那些違背正常人直覺的特性表現(xiàn)。下面我們重點(diǎn)說說這 1% 的特性表現(xiàn)。

extends 與 {}

我們開門見山地問吧:“請說出下面代碼的運(yùn)行結(jié)果?!?/p>

type Test = 1 extends {} ? true : false // 請問 `Test` 類型的值是什么?

如果你認(rèn)真地去領(lǐng)會(huì)上面給出的「ts 類型層級(jí)關(guān)系圖」,我相信你已經(jīng)知道答案了。如果你是基于「鴨子辯型」的直觀理解去判斷,那么我相信你的答案是true。但是我的遺憾地告訴你,在 typeScript@4.9.4中,答案是false。這明顯是違背人類直覺的。于是乎,你會(huì)有這么一個(gè)疑問:“字面量類型 1{}類型似乎牛馬不相及,既不形似,也不神似,它怎么可能是是「字面量空對(duì)象」的子類型呢?”

好吧,就像我們在上一節(jié)提過的,{}在 typeScript 中,不應(yīng)該被理解為字面量空對(duì)象。它是一個(gè)特殊存在。它是一切有值類型的基類。ts 對(duì)它這么定位,似乎也合理。因?yàn)楹魬?yīng)了一個(gè)事實(shí) - 在 js 中,一切都是對(duì)象 (字面量 1在 js 引擎內(nèi)部也是會(huì)被包成一個(gè)對(duì)象 - Number()的實(shí)例)。

現(xiàn)在,你不妨拿別的各種類型去測試一下它跟 {}的關(guān)系,看看結(jié)果是不是跟我說的一樣。最后,有一個(gè)注意點(diǎn)值的強(qiáng)調(diào)一下。假如我們忽略無處不在,似乎是百變星君的 any{}的父類型只有一個(gè) - unknown。不信,我們可以試一試:

type Test = unknown extends {} ? true : false // `Test` 類型的值是 `false`

Test2類型的值是 false,從而證明了unknown{}的父類型。

extends 與 any

也許你會(huì)覺得,extendsany有什么好講得嘛。你上面不是說了「any」既是所有類型的子類型,又是所有類型的父類型。所以,以下示例代碼得到的類型一定是true:

type Test = any extends number ? true : false

額......在 typeScript@4.9.4 中, 結(jié)果似乎不是這樣的 - 上面示例代碼的運(yùn)行結(jié)果是boolean。這到底是怎么回事呢?這是因?yàn)?,?typeScript 的條件類型中,當(dāng)any出現(xiàn)在 extends前面的時(shí)候,它是被視為一個(gè)聯(lián)合里類型。這個(gè)聯(lián)合類型有兩個(gè)成員,一個(gè)是extends后面的類型,一個(gè)非extends后面的類型。還是用上面的示例舉例子:

type Test = any extends number ? true : false// 其實(shí)等同于type Test = (number | non-number) extends number ? true : false// 根據(jù)聯(lián)合類型的分配率,展開得到type Test = (number extends number ? true : false) | (non-number extends number ? true : false)          = true | false          = boolean// 不相信我?我們再來試一個(gè)例子:type Test2 = any extends number ? 1 : 2// 其實(shí)等同于type Test2 = (number | non-number) extends number ? 1 : 2// 根據(jù)聯(lián)合類型的分配率,展開得到type Test = (number extends number ? 1 : 2) | (non-number extends number ? 1 : 2)          = 1 | 2

也許你會(huì)問,如果把 any放在后面呢?比如:

type Test = number extends any ? true : false

這種情況我們可以依據(jù) 「任意類型都是any的子類型」得到最終的結(jié)果是true。

關(guān)于 extends 與 any 的運(yùn)算結(jié)果,總結(jié)一下,總共有兩種情況:

any extends SomeType(非 any 類型) ? AType : BType的結(jié)果是聯(lián)合類型 AType | BTypeSomeType(可以包含 any 類型) extends any ? AType : BType的結(jié)果是 AType

extends 與 never

在 typeScript 的三元表達(dá)式中,當(dāng) never遇見 extends,結(jié)果就變得很有意思了??梢該Q個(gè)角度說,是很奇怪。假設(shè),我現(xiàn)在要你實(shí)現(xiàn)一個(gè) typeScript utility 去判斷某個(gè)類型(不考慮any)是否是never的時(shí)候,你可能會(huì)不假思索地在想:因?yàn)?never是處在 typeScript 類型層級(jí)的最底層,也就是說,除了它自己,沒有任何類型是它的子類型。所以答案肯定是這樣:

type IsNever<T> = T extends never ? true : false

然后,你信心滿滿地給泛型形參傳遞個(gè)never去測試,你發(fā)現(xiàn)結(jié)果是never,而不是true或者false:

type  Test = IsNever<never> // Test 的值為 `never`, 而不是我們期待的  `true`

再然后,你不甘心,你寫下了下面的代碼去進(jìn)行再次測試:

type  Test = never extends never ? true : false // Test 的值為 `true`, 符合我們的預(yù)期

你會(huì)發(fā)現(xiàn),這次的結(jié)果卻是符合我們的預(yù)期的。此時(shí),你腦海里面肯定有千萬匹草泥馬奔騰而過。是的,ts 類型系統(tǒng)中,某些行為就是那么的匪夷所思。

對(duì)于這種違背直覺的特性表現(xiàn),當(dāng)前的解釋是:當(dāng) never充當(dāng)實(shí)參去實(shí)例化泛型形參的時(shí)候,它被看作沒有任何成員的聯(lián)合類型。當(dāng) tsc 對(duì)沒有成員的聯(lián)合類型執(zhí)行分配律時(shí),tsc 認(rèn)為這么做沒有任何意義,所以就不執(zhí)行這段代碼,直接返回 never

那正確的實(shí)現(xiàn)方式是什么???是這個(gè):

type IsNever<T> = [T] extends [never] ? true : false

原理是什么啊?答曰:「通過放入 tuple 中,消除了聯(lián)合類型碰上 extends時(shí)所產(chǎn)生的分配律」。

extends 與 聯(lián)合類型

上面也提到了,在 typeScript 三元表達(dá)中,當(dāng) extends前面的類型是聯(lián)合類型的時(shí)候,ts 就會(huì)產(chǎn)生類似于「乘法分配律」行為表現(xiàn)。具體可以用下面的示例來表述:

type Test = (AType | BType) extends SomeType ? "yes" : "no"          =  (AType extends SomeType ? "yes" : "no") | (BType extends SomeType ? "yes" : "no")

我們再來看看「乘法分配律」:(a+b)*c = a*c + b*c。對(duì)比一下,我們就是知道,三元表達(dá)式中的 |就是乘法分配律中的 +, 三元表達(dá)式中的 extends就是乘法分配律中的 *。下面是表達(dá)這種類比的偽代碼:

type Test = (AType + BType) * (SomeType ? "yes" : "no")          =  AType * (SomeType ? "yes" : "no") + BType * (SomeType ? "yes" : "no")

另外,還有一個(gè)很重要的特性是,當(dāng)聯(lián)合類型的泛型形參的出現(xiàn)在三元表達(dá)式中的真值或者假值分支語句中,它指代的是正在遍歷的聯(lián)合類型的成員元素。在編程世界里面,利用聯(lián)合類型的這個(gè)特性,我們可以遍歷聯(lián)合類型的所有成員類型。比如,ts 內(nèi)置的 utility Exclude<T,U>就是利用這種特性所實(shí)現(xiàn)的:

type  MyExclude<T,U>= T extends U ? never :  T; // 第二個(gè)條件分支語句中, T 指代的是正在遍歷的成員元素type Test = MyExclude<"a"|"b"|"c", "a"> // "b"|"c"

在上面的實(shí)現(xiàn)中,在你將類型實(shí)參代入到三元表達(dá)式中,對(duì)于第二個(gè)條件分支的T記得要理解為"a"|"b"|"c"的各個(gè)成員元素,而不是理解為完整的聯(lián)合類型。

有時(shí)候,聯(lián)合類型的這種分配律不是我們想要的。那么,我們該怎么消除這種特性呢?其實(shí)上面在講「extends 與 never 」的時(shí)候也提到了。那就是,用方括號(hào)[]包住 extends前后的兩個(gè)類型參數(shù)。此時(shí),兩個(gè)條件分支里面的聯(lián)合類型參數(shù)在實(shí)例化時(shí)候的值將會(huì)跟 extends子句里面的是一樣的。

// 具有分配律的寫法type ToArray<Type> = Type extends any ? Type[] : never; //type StrArrOrNumArr = ToArray<string | number>; // 結(jié)果是:`string[] | number[]`// 消除分配律的寫法type ToArrayNonDist<Type> = [Type] extends [any] ? Type[] : never;type StrArrOrNumArr2 = ToArray<string | number>; // 結(jié)果是:`(string | number)[]`

也許你會(huì)覺得 string[] | number[](string | number)[]是一樣的,我只能說:“客官,要不您再仔細(xì)瞧瞧?”。

extends 判斷類型嚴(yán)格相等

在 typeScript 的類型編程世界里面,很多時(shí)候我們需要判斷兩個(gè)類型是否是一模一樣的,即這里所說的「嚴(yán)格相等」。如果讓你去實(shí)現(xiàn)這個(gè) utility 的話,你會(huì)怎么做呢?我相信,不少人會(huì)跟我一樣,不假思索地寫下了下面的答案:

type  IsEquals<T,U>= T extends U ? U extends T ? true : false :  false

這個(gè)答案似乎是邏輯正確的。因?yàn)?,如果只有自己才可能既是自己的子類型也是自己的父類型。然后,我們用很多測試用例去測,似乎結(jié)果也都符合我們的預(yù)期。直到我們碰到下面的邊緣用例:

type  Test1= IsEquals<never,never> // 期待結(jié)果:true,實(shí)際結(jié)果: nevertype  Test2= IsEquals<1,any> // 期待結(jié)果:false,實(shí)際結(jié)果: booleantype  Test3= IsEquals<{readonly a: 1},{a:1}> // 期待結(jié)果:false,實(shí)際結(jié)果: true

沒辦法, typeScript 的類型系統(tǒng)有太多的違背常識(shí)的設(shè)計(jì)與實(shí)現(xiàn)了。如果還是沿用上面的思路,即使你把上面的特定用例修復(fù)好了,但是說不定還有其他的邊緣用例躲在某個(gè)陰暗的角度等著你。所以,對(duì)于「如何判斷兩個(gè) typeScript 類型是嚴(yán)格相等」的這個(gè)問題上,目前社區(qū)里面從 typeScript 實(shí)現(xiàn)源碼角度上給出了一個(gè)終極答案:

type IsEquals<X, Y> =      (<T>() => (T extends  X ? 1 : 2)) extends      (<T>() => (T extends  Y ? 1 : 2))      ? true      : false;

目前我還沒理解這個(gè)終極答案為什么是行之有效的,但是從測試結(jié)果來看,它確實(shí)是 work 的,并且被大家所公認(rèn)。所以,目前為止,對(duì)于這個(gè)實(shí)現(xiàn)只能是死記硬背了。

extends 與類型推導(dǎo)

type Test<A> = A extends SomeShape ? 第一個(gè)條件分支 : 第二支條件分支

當(dāng) typeScript 的三元表達(dá)式遇見類型推導(dǎo)infer SomeType, 在語法上是有硬性要求的:

infer只能出現(xiàn)在 extends子句中,并且只能出現(xiàn)在 extends關(guān)鍵字后面緊跟在 infer后面所聲明的類型形參只能在三元表達(dá)式的第一個(gè)條件分支(即,真值分支語句)中使用

除了語法上有硬性要求,我們也要正確理解 extends 遇見類型推導(dǎo)的語義。在這個(gè)上下文中,infer SomeType更像是具有某種結(jié)構(gòu)的類型的占位符。SomeShape中可以通過 infer來聲明多個(gè)類型形參,它們與一些已知的類型值共同組成了一個(gè)代表具有如此形態(tài)的SomeShape。而 A extends SomeShape 是我們開發(fā)者在表達(dá):「tsc,請按照顧我所聲明的這種結(jié)構(gòu)去幫我推導(dǎo)得出各個(gè)泛型形參在運(yùn)行時(shí)的值,以便供我進(jìn)一步消費(fèi)這些值」,而 tsc 會(huì)說:「好的,我盡我所能」。

「tsc 會(huì)盡我所能地去推導(dǎo)出具體的類型值」這句話的背后蘊(yùn)含著不少的 typeScript 未在文檔上交代的行為表現(xiàn)。比如,當(dāng)類型形參與類型值共同出現(xiàn)在「數(shù)組」,「字符串」等可遍歷的類型中,tsc 會(huì)產(chǎn)生類似于「子串/子數(shù)組匹配」的行為表現(xiàn) - 也就是說,tsc 會(huì)以非貪婪匹配模式遍歷整個(gè)數(shù)組/字符串進(jìn)行子串/數(shù)組匹配,直到匹配到最小的子串/子數(shù)組為止。這個(gè)結(jié)果,就是我們類型推導(dǎo)的泛型形參在運(yùn)行時(shí)的值。

舉個(gè)例子,下面的代碼是實(shí)現(xiàn)一個(gè)ReplaceOnce類型 utility 代碼:

type ReplaceOnce<  S extends string,  From extends string,  To extends string> = From extends ""  ? S  : S extends `${infer Left}${From}${infer Right}`  ? `${Left}${To}${Right}`  : S  “”type Test = Replace<"foobarbar", "bar", ""> // 結(jié)果是:“foobar”

tsc 在執(zhí)行上面的這行代碼「S extends ${infer Left}${From}${infer Right}」的時(shí)候,背后做了一個(gè)從左到右的「子串匹配」行為,直到匹配到所傳遞進(jìn)來的子串From為止。這個(gè)時(shí)候,也是 resolve 出形參LeftRight具體值的時(shí)候。

以上示例很好的表達(dá)出我想要表達(dá)的「當(dāng)extends跟類型推導(dǎo)結(jié)合到一塊所產(chǎn)生的一些微妙且未見諸于官方文檔的行為表現(xiàn)」。在 typeScript 高級(jí)類型編程中,善于利用這一點(diǎn)能夠幫助我們?nèi)ソ鉀Q很多「子串/子數(shù)組匹配」相關(guān)的問題。

總結(jié)

在 typeScript 在不同的上下文中,extends有以下幾個(gè)語義:

用于表達(dá)類型組合;用于表達(dá)面向?qū)ο笾小割悺沟睦^承用于表達(dá)泛型的類型約束;在條件類型(conditional type)中,充當(dāng)類型表達(dá)式,用于求值。

最值得注意的是,extends在條件類型中與其他幾個(gè)特殊類型結(jié)合所產(chǎn)生的特殊語義。幾個(gè)特殊類型是:

{}anynever聯(lián)合類型

【推薦學(xué)習(xí):javascript高級(jí)教程】

以上就是帶你聊聊typeScript中的extends關(guān)鍵字的詳細(xì)內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!

關(guān)鍵詞: TypeScript JavaScript

5060午夜看片免费| 视频一区二区三区国产在线| 人妻久久一区二区三区精品99| 超碰97在线视频观看| 国产69精品久久久久久妇| 欧美一区二区三区再线播放| 在线中文字幕有码视频| 91国产激情视频在线观看| 成人永久免费激情视频在线| 成人A级毛片无码免费看| 欧美一区二区三区黄片| 人妻少妇亚洲自拍av| 搬开女人下面使劲插视频| 国产性一交一乱―色―情人| 欧美性色黄大片人与善| 亚洲素人中文字幕在线| 青青青青草免费视频看看| 日韩综合在线超乳人妻一区| 91最新黄色免费网站| 亚洲熟女一区二区av| 国产美女视频免费观看网| 麻豆av国语对白麻豆| 最新欧美69堂在线视频| 97人妻超碰在线免费视频| 国产很黄很色精品久久久| 国产爱爱视频在线播放| 青青热久免费精品视频| 人妻中文字幕免费av| 中文字幕日韩在线久久| 久久久免费一区二区三区| 99视频在线精品免费| 国产精品一级二级三级四级| 中文字幕人妻丝袜成熟乱三区| 亚洲激情av一区二区三区| 日本丝袜美腿在线观看| 久久久久久4久久久8| 国产免费三级三级三级| 人妻丝袜美腿中文字幕| 国产成人av午夜精品免费| 久久综合熟女中文字幕| 人妻av蜜臀一区二不卡| 香蕉免费一区二区三区在线观看| 青青操新免费观看视频| 法国大屁股骚妇口交视屏| 国产一二三自拍视频在线观看| 久久婷婷色香五月综合激激情| 色综合久久综合欧美综合| 欧美情色大片在线观看| 亚洲一二三区精品在线观看| 久久亚洲精品色噜噜狠狠| 国产亚洲欧美日韩三级| 国产精品久久久久精品| 99re成人精品免费视频| 久久久久久噜噜噜久久久精品| 99久久国产一区二区三区| 久久久久久精品一区二区三区| 欧美性欧美三级全透明时装秀 | 亚洲sm一区二区三区| 亚洲不伦丝袜人妻在线| 日韩精品乱码av在线播放| 国产成人黄色精品视频| 蜜桃臀美女福利xxoo| 在线国产视频精品视频| 精品无人区一区二区三区av| 在线播放亚洲一级特黄片| 一区二区三区蜜桃在线观看| 亚洲综合图片一区二区三区| 青青青草青在线视频免费观看了| 能效等级一级二级三级| VA乱伦无码视频免费播放| 97人妻超碰在线免费视频| 亚洲黄色分享大全探花| 超碰人妻免费一区二区| 丁香婷婷久久久久成人天堂国产| 凹凸在线视频免费观看| 欧美一区二区三区四区在线观看| 久久成人在线播放视频| 伊人av超碰伊人久久久| 成人黄色在线免费播放| 国产精品国产三级国产普通话一| 国产av自拍资源网址| 得得的爱在线视频免费观看| 精品国产99国产精品亚洲| 久久黃色特三片視頻視頻視視頻| 黄色福利视频网址大全| 久久精品国产熟女亚洲av| 99国产小视频在线播放| 中文字幕久久人妻综合| 欧美成人天天综合在线视色| 免费的床上很黄不遮挡视频 | 大奶少妇白虎高潮流视频| 久久久久久久久久久亚洲| 六年级小女生光滑的小嫩逼| 综合久久国产中文人妻少妇在线| 久久人人爽人人爽人人片669| 亚洲 综合 欧美 日韩| 国产免费午夜福利视频| 久久香蕉亚洲欧美av精品| 欧美青青一区二区三区| 国产91av精品在线观看| 亚洲av无码一区二区三区免看| 久久久久久精品久久久久久| 免费激情视频在线观看| 日韩熟女少妇一区二区三区| 明星性感丝袜图片大全| 国产成人av午夜精品免费| 国产精品国产三级国产普通话一| 撒玛利亚女孩在线观看免费全集| 色视频在线免费观看视频播放| 国产性一交一乱―色―情人| 国产精品丝袜制服在线| 久久青青草原在线视频| 久久香蕉亚洲欧美av精品| av岛国一区二区三区久久| 国产视频免费在线播放| 精品亚洲一区二区三区ftp| 国产熟女熟妇一区二区三区av| 欧美日韩一区二区三四| 亚洲精品你懂的在线观看| 久久天天躁狠狠躁夜夜av| 在线观看无码免费你懂的| 亚洲少妇av一区二区三区| 国产精彩自拍视频在线观看| 中文字幕亚洲久久爽一区| 熟女系列丰满熟妇一区二区三区 | 欧美日韩午夜精品不卡综合| 日韩av大片在线免费观看| 中文字幕在线亚洲视频| 免费的黄网站在线观看视频| 国产免费av国片精品| 国产免费九九久久精品a级| 青草视频在线观看亚洲| 九九久久99最新精品| 女女同性女同区二区日韩| 中文字幕亚洲久久爽一区| 欧美激情1区2区3区4区| 亚洲熟女区一区二区三| 激情视频 超黄 在线免费| 久久国产精品av大全| 亚洲三级黄色在线观看| 中文字幕乱码亚洲三区| 亚洲三级黄色在线观看| 91麻豆精品在线播放| 精品人妻一区二区三区综合部| 国产97自拍视频在线观看| 亚洲中文字幕乱码免费播放| 你懂得在线免费观看99| 欧美一级内射视频在线播放| 18免费在线观看av| 国产欧美一区二区精品性| 巨乳少妇av中文字幕| 国产成人亚洲综合av| 成年人黄视频免费观看网站| 97国产视频在线观看| 青青青青国产在线视频| 国产精品自拍首页视频| 熟女人妻专区中文字幕| 亚洲国产欧美精品在线| 亚洲一区二区av在线| 久久综合中文字幕日韩精品| 日本午夜免费在线视频| 吖v在线观看欧美一区二区三区| 想神马有神马舞蹈视频| 国产三级欧美系列日韩系列| 成人区人妻精品一区二区| 九九久久99最新精品| 熟女人妻中文字幕免费观看| 久久99久久精品免观看吃奶| 大型黄色av网站在线播放观看| 自拍视频在线观看青青网| 在线观看不卡一区二区三区| 国产97色伦在线观看| 99视频一区在线观看| 欧美日韩精品成人在线| 91超碰国产在线观看| 国产自产拍午夜免费视频| 久久热视频在线免费观看| 国产视频免费在线播放| 国产精品髙潮呻吟久久av| 成人黄色免费观看网址| 青草视频中文字幕在线观看| 欧美日韩精品欧美日韩| 精品人妻少妇一区二区三级| 爆乳美女粉嫩阴蒂被插视频| 国产免费午夜福利视频| 成人一区二区三区在线午夜| 美女在线观看免费在线观看| 日韩欧美久久一区二区| 韩国性感美女热舞视频| 人妻在线免费观看二区| 熟女阿av一区二区三| 小视频在线观看你懂的| 超碰97国产在线免费观看| 最新成人精品视频在线| 青春草视频免费观看在线| 色婷婷一区二区三区四区在线| 午夜不卡在线免费视频| 国产精品髙潮呻吟久久av| 欧美一区二区三区四区免费| 成人啪精品视频网站午夜| 91精品国产色综合久久不卡蜜 | 人妻精品系列一区二区三区| 最近中文字幕免费mv在线直播| 国产婷婷色一区二区三区五区| 我的放荡丝袜美腿老师| 欧洲一区二区三区在线播放| 95国产成人精品视频| 国产精品丝袜熟女一二三| av中文在线中文av| 蜜臀av在线观看免费| 青草成人在线观看视频| 色综合久久久久久久久8噜啦噜| 夜夜欢性恔真人免费视频| 欧美视频精品综合在线| 久久久精品久久久久久69| 亚洲自拍一区在线观看| 午夜av中文字幕在线观看| 九九激综合五月天国产| 免费国产草莓视频在线观看黄| 欧美三级精品三级在线| 亚洲日本韩国一级二级三级| 久久久久久人妻精品一区| 男人插女人逼免费视频| 亚洲欧美精品丝袜中文字幕| 99人妻精品一区二区三区| 在线亚洲视频中文字幕| 性感丝袜美女写真视频| 中文字幕在线视频首页| 国产精品成人自产拍在线| 亚洲免费成人精品视频| 最好看的中文字幕av| 久久国产精品av大全| 蜜臀av入口一区二区三区| 成人黄动漫在线观看网站| 韩国三级一区二区在线观看| 亚洲 综合 欧美 日韩| 中文字幕乱码激情av| 亚洲一区美腿丝袜在线播放| 久久香蕉国产熟女线看| av黄色资源中文字幕| 精品久久久人妻中文字幕| 男生把小鸡鸡插到大美女的屁股| 白浆熟女精品国产91| 国产97视频免费在线观看| 人妻一区二区在线免费播放| 日本视频在线一区二区三区| 九九久久99最新精品| 国产免费无码一区二区视频无码| 91精品福利自产拍在线观看| 国产女人叫床高潮大片免费| 亚洲一区美腿丝袜在线播放| 欧美日韩亚洲在线另类| 午夜日韩私人大片中国黄页网| 国产粉精品高潮呻吟久久av| 男生把小鸡鸡插到大美女的屁股| 精品人妻少妇嫩草一区二区三区| 免费的床上很黄不遮挡视频| 色综合久久综合欧美综合| 自拍 偷拍 亚洲 欧美| 欧美激情一区二区三区成人| 国产97自拍视频在线观看| 97超碰超碰在线观看| 亚洲av成人噜噜网站| 成人午夜精品一区二区三区| 国产亚洲欧美日韩三级| 成人激情自拍图片视频| 明日花绮罗人妻大乳av| 四川熟女a一区二区三区| 熟女少妇久久中文字幕| 高跟丝袜诱惑后入av| 久久久久久狠狠亚洲综合| 国产免费无码午夜福利蜜臀| 日韩乱码中文字幕有码视频| 国产伦精品一级二级三级| 久久久久久噜噜噜久久久精品| 正在播放99精品视频在线播放| 国产成人亚洲综合av| 国产亲乱的性视频网站| 久久精品国产熟女亚洲av| 网站免费黄色在线播放| 国产免费九九久久精品a级| 青青草原网址在线观看| 色综合久久久久久久久8噜啦噜 | 99综合精品在线观看| 精品视频在线观看91| 99re成人精品免费视频| 欧美女同性恋一区二区三区| 国产综合日韩精品欧美| 国产免费黄色av 网站| 久久成人在线视频播放| 精久久中文字幕人妻最新| 五十路熟女人妻在线网观看| 青青草原精品在线观看视频| 日本伦理色呦呦在线观看| 国产高清在线免费观看不卡av| 欧美不卡一区二区三区视频| 最新国产网友自拍视频在线| 日韩丝袜诱惑网站大全| 中文字幕中文av在线精品| 欧美性欧美三级全透明时装秀| av在线观看亚洲中文| 成人在线观看免费视频播放| 成人在线视频播放 亚洲| 97精品日韩在线视频| 亚洲 人妻 有码 在线| 久久久久久久久极品内射| 黄色一级片久久久免费观看| 亚洲一区二区三区天海翼| 97色老99久久九九爱精品| 亚洲熟女一区二区av| 青青操视频在线观看免费观看| av在线中文字幕资源网| 久久成人在线视频播放| 女女同性女同区二区日韩| 国产自拍av在线观看| 亚洲一区二区三区成人在线| 巨乳人妻中文字幕精品在线| 欧美精品久久久久久久久91| 六年级小女生光滑的小嫩逼| 亚洲乱码国产一区二区| 欧美午夜理论在线观看| 中文字幕av在线观看网址| 带个大鸡巴臭逼的视频。| 日韩美女肥臀毛茸茸的阴穴| 午夜一区视频在线观看| 欧美午夜激情福利国产| 国产一区二区在线直播| 久久国产麻豆免费播放| 日本性感丝袜女秘书诱惑| av在线不卡中文字幕宾馆| jizz视频在线观看| 91偷拍老熟女露脸合集| 亚洲精品中文字幕一二| 成人黄色免费观看网址| 色av蜜臀av粉嫩av| 97超碰人妻福利在线| 91亚洲精品久久久久蜜桃| 91精品久久久久久久久| 成人在线一区二区三区av| 色综合久久88色综合天| 一级成人欧美一区在线观看| 99久久久精品免费看国产| 蜜臀av夜夜澡人人爽人人| 夜精品一区二区无码A片| 最新在线一区二区三区| 草草视频免费在线观看| 超级碰碰在线视频国产| 女女同性女同区二区日韩| 国产精品久久久久九九九九| 午夜日韩私人大片中国黄页网| 国产成年免费观看视频| 无码国模大尺度自拍视频在线看 | 日韩人妻丝袜美腿中文| 欧美黄色一级一区二区三区| 中文字幕在线视频首页| 女人嫩水逼让大鸡巴操免费看 | 久久久21精品久久久| 国内伦理视频在线观看| 国产剧情午夜在线观看| 久久久久人妻一区精品在线观看| 91自拍免费在线视频| 亚洲一a区二a区三a区| 日韩性感美女在线观看| 青青草原国产在线免费观看| 97在线观看的视频资源| 欧美青青一区二区三区| 男人添女人下边视频免费| 国产精品亚洲av三区色| 国产成人自拍视频网址| 亚洲中文字幕一区二区三区av| 欧洲美女一区二区三区| 日韩人妻久久中文字幕| 91大神精品免费在线播放| 日韩av中文字幕另类| 精选国产精品视频在线| 中文字幕久久人妻综合| 青青久久国内视频网站| 性色av蜜臀av人妻无| 日本熟日本熟妇中文在线观看| 99久久麻豆99久久免费| 亚洲精品乱码久久久久久久久| 亚洲成人av区一区二区三区四| 青娱乐成人免费公开视频| 激情伦理一区二区三区| 95国产成人精品视频| 国产日韩制服丝袜第一页| 国产高清三级在线精品福利| 99人妻精品一区二区三区| 色综合久久久久久久久8噜啦噜| 丰满人妻一区二区三区精品av| 大乳美女疯狂榨取精子视频| 国产97自拍视频在线观看| av资源中文在线天堂播放| 91最新黄色免费网站| 你在线上av中文字幕| 性感丝袜美女写真视频| av大全一区二区三区| 中文字幕日韩在线久久| 少妇性生活久久久久久| 欧美日韩激情午夜看片| 超级碰碰在线视频国产| 99国产精品久久全免费| 中文乱码字幕视频观看网站免费| 青青青草青在线视频免费观看了| 欧美激情高潮无遮挡男男| 国产欧美亚洲日本网站| 好吊色欧美一区二区三区四区 | 91最新黄色免费网站| 亚洲人妻中文字幕网站| 男人操女人逼视频免费观看| 亚洲国产自产一区二区c| 97超碰人妻在线观看| 国产爱爱视频在线播放| 国产高清三级在线精品福利| 精品国产乱码久久久久久男人| 精品国产一区二区三区不卡免费| 亚洲乱码国产乱码精品精91 | 免费精品国偷自产在线洗澡| 国产情侣免费观看视频| 精品视频在线观看91| 日本精品一区二区三区精品在线 | 国产欧美日韩综合精品一区| 久久久久精品久久久久久| 丰满人妻熟妇乱又精品视| 日本性感丝袜女秘书诱惑| 丝袜制服诱惑人妻av| 成人国产一区二区在线| 国产三区四区在线视频| 成人h色视频在线观看| av激情韩国在线播放| 两鸡巴日一个骚逼浪的视频| 久久国产麻豆免费播放| 国产91av精品在线观看| 青青草草视频在线播放| 丝袜美腿在线观看一区| 伊人av超碰伊人久久久| 男人天堂中文字幕av| 成人黄色精品视频网站| 欧美一区二区三区中文字幕| 黄色av在线免费播放| 久久香蕉亚洲欧美av精品 | 国产亚洲精品成人av丝袜| 人妻少妇激情综合小视频| 成人亚洲精品在线观看| 国产美女在线观看专区| 亚洲av专区在线观看国产| 日韩激情中文字幕在线| 福利国产在线观看永久免费| 亚洲午夜av久久久精品| 成人av日本在线观看| av岛国一区二区三区久久| 91性色福利在线视频| 色老久久精品偷偷鲁一区| 日韩成人伦理片在线观看| 久久99亚洲精品久久频| 男人和女人上床的真实视频| 亚洲精品国产av久久| 欧美日韩一区三区不卡在线| 亚洲最大黄色av网站| 99久久久精品免费看国产| 国产偷拍自拍熟女视频| 色老久久精品偷偷鲁一区| 超碰97国产在线免费观看| 中文字幕人妻A片免费看| 午夜精品视频一区二区| 青青在线观看国产免费视频| 亚洲性色成人av天堂| 法国熟女乱淫xxoo| 欧美日韩亚洲在线另类| 精品国产三级av在线| 天海翼一区二区三区免费| 97精品综合久久视频| 国产自拍视频在线免费| 911精品在线免费观看| 青青热久免费精品视频| 日韩极品视频在线观看免费| 99久久麻豆99久久免费| 在线观看免费黄小视频| 吖v在线观看欧美一区二区三区| 亚洲三级视频一区二区三区| 国产91av精品在线观看| 少妇极品一区二区三区| 亚洲不伦丝袜人妻在线| 中文字慕人妻一区二区在线视频 | 青青色在线视频观看免费| 搬开女人下面使劲插视频| 日韩欧美精品中文字幕富二代| 日韩丝袜诱惑网站大全| 男人和女人的性生活视频| 中文乱码字幕视频观看网站免费| 成人极品av免费观看| 99人妻精品一区二区三区| 24小时在线免费观看高清视频| 午夜精品久久久在线观看| 青青草原网址在线观看| 亚洲欧美丝袜美腿 综合| 国产av日韩精品久久| 97超碰人妻福利在线| 精品人妻少妇一区二区三级| 日日摸日日碰天天爽歪歪| 亚洲午夜精品久久久久久人妖 | 中文字幕人妻少妇久久| 丝袜制服诱惑人妻av| 日本精品一区二区三区精品在线| 国产视频在线观看视频| 在线欧美三级在线高清观| 91国产自拍在线视频| 夜夜欢性恔真人免费视频| 亚洲自拍一区在线观看| 亚洲三级一区二区三区四区| 国外成人免费激情在线视频| 直接免费观看黄色的网站| 99综合精品在线观看| 美女网站免费非常非常黄的| 国产午夜精品视频免费福利| 午夜嗨起视频在线观看| 俄罗斯大鸡吧操骚逼水多舒服| 美女精品一区二区三区免费观看| 伊人网站免费在线观看| 国模在线一区二区三区| 久久久久久狠狠综合一本| 国产免费无码午夜福利蜜臀| 99爱在线精品视频免费看| seseav在线观看| 国产欧美亚洲日本网站| 77成人在线免费视频| 国产精品一区二区精品视频| 色婷婷国产精品免费视频| 99热爱精品在线观看| 精品国产乱码久久久久夂| 成人av日本在线观看| 精品人妻一区二区三区成人网| 免费av在线网站中文字幕| 久久婷婷香蕉国产精品| 一区二区三区看国产片在线| 青青操视频在线观看免费观看| 丝袜熟女av一区二区三区| 日韩国产在线不卡av| 亚洲欧美精品丝袜中文字幕| 91青青视频在线观看| 精品熟女少妇一区二区| 91黄页网站在线观看| 99er在线免费视频| 欧美精品久久久久久久久91| 在线播放欧美A在线观看| 久久精品久久一区二区 | 老男人xx女人视频试看| 美女在线观看免费在线观看| 国产精品网站调教美女| 蜜臀av国内精品久久久久久| 久久久免费久久久精品| 色婷婷国产精品免费视频| 97超碰在线公开免费| 成人激情自拍图片视频| 免费av在线网站中文字幕| 熟女麻豆一区二区三区四区| 在线观看国产精品av| 人妻丰满熟妇久久久久| 欧美日韩精品成人在线| 国产高清在线免费观看不卡av| 久久久久久久久久久高| 亚洲天堂中文av网站| 午夜97视频在线观看| 国产理论亚洲天堂av| 岛国av久热中文字幕| 午夜日韩私人大片中国黄页网| 青青热久免费精品视频| 另类专区日韩有码中文字幕| 一区二区三区 国产日韩欧美| AV午夜福利一片免费看久久 | 白浆熟女精品国产91| 久久久久久久久极品内射| 高跟丝袜诱惑后入av| 国产原创av在线免费播放| 日韩人妻有码一区二区| 94精品视频在线播放| 国产丝袜熟女人妻在线观看| 91成人资源在线观看| 亚洲熟女一区二区av| 色婷婷国产精品免费视频| 中文字幕精品久久久乱码乱码 | 亚洲三级视频一区二区三区| 蜜月久久99精品久久久久久| 亚洲精品中文字幕一二| 超视在线免费观看视频| 亚洲一区在线人妻视频| 最新国产网友自拍视频在线| 在线观看的资源网97| 成人激情自拍图片视频| 国产精品亚洲av二区三| 精品99在线免费视频| 中文字幕乱码激情av| 日韩 制服 丝袜 中文| 国产精品欧美一区二区久久久| 成人免费视频免费在线观看 | 亚洲国产一区二区久久| 三级成人一区二区三区| 97视频在线免费观看网站| 丝袜美腿在线观看一区| 爽爽爽爽成人观看在线。| 久久精品国产亚洲av四区| 人妻少妇偷人一区二区三区| 男人靠女人靠厉害视频| 人妻少妇亚洲自拍av| 国产女老师的诱惑在线播放观看| 白白色发布在线播放国产| 免费激情视频在线观看| 亚洲综合国产乱码成人| 国产揄拍视频在线观看| 久久99精品久久久久蜜臀| 欧美午夜激情福利国产| 国产免费午夜福利视频| 激情人妻校园春色亚洲欧美| 亚洲精品中文字幕一二| 99九九99久久精品| 超碰97在线公开观看| 欧美一区二区免费在线观看| 成人一区二区三区在线午夜| 黄黄的小视频免费在线播放| 狠狠的干香蕉久久av| 亚洲欧美日韩av在线观看| 免费国产一区二区三区久久久久久| 在线 av 中文字幕| 97人妻中出中文字幕| 日韩中文字幕人妻一区| 国产成人亚洲综合av| 青青青国产免费观看视频| 国产AV躁一二三区免费播放| 能效等级一级二级三级| 国产成人乱色视频网站| 精品一区二区三区四区在线播放| 国产成人在线视频播放| 97久久久久久久久久久| 精品人妻av在线观看| 国产剧情午夜在线观看| 国产无码精品久久久久久久| 巨乳少妇av中文字幕| 国产草草视频在线观看| 伊人av超碰伊人久久久| av人妻一区二区三区| 精品人妻伦一二二区久久| 久久精品国产亚洲av四区| 久久人妻一区二区精选| 久久精品国产v日韩v亚洲 | 91精品国产人妻国产在线| 精品人妻一区二区三区成人网| 日韩极品视频在线观看免费 | 蚂蚁三级成人av在线| 久久人人妻人人做人人爽| 成人国产一区二区在线| 国产在线日韩精品av| 成年人黄视频免费观看网站| 久久久久久久综合精品| 欧美成年一区二区三区| 直接免费观看黄色的网站| 伊人丝袜人妻中文字幕| 中文乱码字幕视频观看网站免费 | 九九久久久久无限久久| 日韩一区二区三区人妻| 国内一区二区三区视频在线播放| 日韩欧美精品中文字幕富二代| 欧美激情在线播放一区| 欧美视频精品综合在线| 国产熟女熟妇一区二区三区av| 国产视频在线观看视频| 久久青青草原在线视频| 久久国产精品av大全| 欧美性欧美三级全透明时装秀| 日韩性感美女在线观看| 91性色福利在线视频| 91超碰在线免费视频| 欧美一区二区三区四区免费| 中文字幕乱码亚洲三区| 亚洲欧美自拍偷拍另类| av中文字幕一二三四| 在线观看国产视频播放| 日韩国产偷拍自拍在线| 国产免费三级三级三级| 中文字幕人妻丝袜成熟乱三区| 国产av自拍资源网址| 国产精品成人中文字幕| 视频一区二区三区 在线| 人妻互换精品一区二区| 青青操视频在线观看免费观看| 绿帽老公让娇妻蒙眼被人操| 老熟女老熟妇一区二区| av性感美女免费在线观看| av资源在线中文天堂| 国产视频自拍在线观看| 色视频在线免费观看视频播放| 久久成人在线视频播放| 最新在线一区二区三区| 大奶少妇白虎高潮流视频| 亚洲成人av免费在线播放| 一区二区三区欧美精选| 日韩极品视频在线观看免费| 男人女人40分钟视频| 亚洲国产精品美女papa| 国产成人在线视频播放| 快速播放国产精品视频| 美女视频吃奶视频在线观看| 国产aV无码片毛片一级韩国 | 在线播放一区二区三区三州| 超级碰碰在线视频国产| 婷婷丁香精品一区二区三区| 美女黄网站永久观看网站不卡| 欧美久久久久久久久久久久久| 性感丝袜短裙美女啪啪啪| 国产99在线视频免费| 日韩欧美精品中文字幕富二代| 日日摸日日碰天天爽歪歪| 日韩少妇一区二区三区四区五区| 男人操女人的逼免费网站| 国产哟av精品色哟哟| 国产免费在线视频观看| 超碰在线97青青草原| 九九激综合五月天国产| 成人黄动漫在线观看网站| 亚洲一区美腿丝袜在线播放| 在线观看的资源网97| 日本熟日本熟妇中文在线观看| av中文在线中文av| 日韩欧美精品中文字幕富二代| 欧美日韩一区三区不卡在线| 国产偷拍自拍熟女视频| 亚洲在线欧美一区二区三区| 国产视频午夜在线播放| 国产午夜精品视频免费福利| 在线观看无码免费你懂的| 搬开女人下面使劲插视频| 青青草原免费体验视频| 国产丝袜另类精品综合| 熟女系列丰满熟妇一区二区三区| 桃色视频在线观看97| 高潮喷水波多野结衣在线观看| 久久精品国产v日韩v亚洲| 91亚洲精品久久久久蜜桃| 亚洲精选清纯唯美自拍偷拍| 亚洲高跟丝袜在线观看| 蜜臀av夜夜澡人人爽人人| 亚洲欧洲日产日韩激情| 成人国产一区二区在线| 自拍偷拍亚洲综合在线| 简述土壤监测方案设计流程| 亚洲丝袜av在线观看| 噜噜mm视频在线观看| 久久综合中文字幕日韩精品| 欧美 日韩 一区二区三区| 成人极品av免费观看| 美女精品一区二区三区免费观看| 国产精品久久久久精品| 蜜桃av精品视频一区二区三区| 视频一区二区三区日韩欧美| 黄色福利视频网址大全| 国产视频自拍在线观看| 九九激综合五月天国产| 99久久在线免费观看| 色偷偷av一区二区三区| 国产有色视频在线网址| 亚洲一区二区三区av网站| 久久99久久久久久久久| 亚洲欧美另类在线一区二区| 欧美一区二区在线观看网站| 免费国产草莓视频在线观看黄| av岛国一区二区三区久久| 国产亚洲欧美日韩中文在线蜜臀| 亚洲无av在线中文字幕男男| 色综合久久88色综合天| 中文字幕视频免费在线| 久久一区二区三区av| 俄罗斯大鸡吧操骚逼水多舒服| 中文乱码字幕视频观看网站免费| 久久久久久狠狠综合一本| 日韩欧美少妇一区二区三区| 可以免费看的黄色的网站| 视频一区二区三区 在线| 午夜偷拍视频免费观看| 丁香婷婷久久久久成人天堂国产| 人妻系列av无码专区免费| 欧美午夜理论在线观看| 久久一区二区三区av| 久久99精品久久久久蜜臀| 国产精品丝袜熟女一二三| 丰满人妻熟妇又伦精品| 2023国产精品自拍视频| 亚洲熟女一区二区av| 欧美日韩国产三级在线| 熟妇人妻av一区二区三| 成人国产麻豆一区二区| 97福利国产在线视频| 91久久精品国产91性色| 成年人黄视频免费观看网站| 人妻在线免费观看二区| 青草成人在线观看视频| 试婚99天视频免费完整版观看| 一边吃扎一边插逼逼视频| 久久久久久久久久久高| 国产成人麻豆精品视频| 国产AV躁一二三区免费播放| 亚洲在线欧美一区二区三区| carpon视频在线观看| 在线91华人精品国产片| 轻轻插青青草视频在线播放| 国产青青草在线观看视频| 午夜mm1314视频| 91成人精品亚洲国产| 69久久久久久人妻白浆| 青青青爽综合在线视频| 丰满人妻熟妇乱又精品视| 国产一区二区蜜臀av| 中文字幕精品乱码久久久久| 日本青草视频在线观看| 免费女女同黄毛片av网站| 天海翼一区二区三区免费| 亚洲sm一区二区三区| 国模午夜写真福利在线| 欧洲一区二区三区在线播放| 人人综合亚洲无线码另类会员 | 黄黄的小视频免费在线播放| 日韩人妻熟女中文字幕的视频| VA乱伦无码视频免费播放| 国产精品久久久久久96| 亚洲av无码一区二区三区免看| 伊人av超碰伊人久久久| 97精品国产高清自在线| 日韩极品视频在线观看免费 | 国产精品亚洲av二区三| 自拍偷自拍亚洲精品10p| 成年人黄色片视频网站| 久久天天躁狠狠躁夜夜av| 成人在线播放亚洲一区| 一本92午夜免费不卡福利片 | 麻豆av 无码精品一区二区| 黄色av在线观看网址| 久久久亚洲裙底偷窥综合| 熟女一区二区三区 在线| 99re成人精品免费视频| 亚洲国产自产一区二区c| 夜夜骚av一区二区三区啊| 国产揄拍视频在线观看| 日韩极品视频在线观看免费| 精品无人区一区二区三区av| 人妻系列av无码专区免费| 欧美整片一区二区三区| 日韩欧美人妻激情一区| 国产熟女熟妇一区二区三区av| 日韩国产在线不卡av| 成人免费在线视频亚洲| 午夜在线观看视频你懂的| 在线免费观看青青草av| 久亚洲国产精品蜜臀尤物| 在线亚洲视频中文字幕| 日本一本久a久久精品综合| 熟女人妻专区中文字幕| 日韩女优精品在线观看| 97自拍视频国产视频| 又色又爽又黄又视频毛片| 俄罗斯大鸡吧操骚逼水多舒服| 国模午夜写真福利在线| 国产精品久久久久久永久牛牛| 欧美性欧美三级全透明时装秀| 啊啊啊啊插进去你好骚视频| 亚洲最大黄色av网站| 人妻精品在线观看视频| 中文字幕视频免费在线| av中文字幕官网天堂| 欧美少妇一区二区三区| 性做久久久久久久毛片| 先锋视频资源在线播放| 国产亚洲欧美日韩三级| 国产午夜精品视频免费福利| 国产AV无码专区AV麻豆| 国产精品露脸对白播放| 中文字幕人妻熟女人妻av| 最近中文字幕免费观看av| 99人妻精品一区二区三区| 24小时在线免费观看高清视频| 国产精品18久久久久久二百| 亚洲欧美自拍偷拍另类| 深夜视频在线观看免费| 亚洲不伦丝袜人妻在线| 美女国产高潮福利片在线看| 日韩一级淫片蜜臀播放口| 精品无人区一区二区三区av| 熟女系列丰满熟妇一区二区三区| 欧美激情视频免费观看| 日韩在线一区二区三区中文字幕| 亚洲三级一区二区三区四区| 简述土壤监测方案设计流程| 久久三级视频在线观看| 法国大屁股骚妇口交视屏| 激情视频网站在线观看| 欧美一区二区在线播放视频| 国产精品露脸对白播放| 5060午夜看片免费| 熟女大胸白嫩自慰流白浆| 亚洲欧美日韩精品麻豆| 91超碰国产在线观看| 亚洲成人制服丝袜av| av岛国一区二区三区久久 | av大全一区二区三区| 日韩熟女精品91中文字幕| 国产精品露脸对白播放| 黄色mv在线免费观看| 在线视频免费观看久久| 日本一卡视频在线观看免费| 国产AV无码专区AV麻豆| 精品国产三级av在线| 欧美激情一区二区二区| 日韩欧美少妇一区二区三区| 乱文丝袜乱文丝袜美腿视频| 91国产激情视频在线观看| 欧洲一区二区三区在线播放| 国产熟女丝袜一区二区三区四区| 青青草原网址在线观看| 国产精品中文av在线播放| 亚洲国产精品黑丝美女| 青青色在线视频观看免费| 深夜视频在线观看免费| 国产自拍免费精品视频| 爆乳美女粉嫩阴蒂被插视频| 免费国产草莓视频在线观看黄 | AV午夜福利一片免费看久久| 黄色免费网址在线播放| 亚洲一区二区欧美激情| 久久亚洲精品色噜噜狠狠| 中文字幕亚洲熟女精品人妻| 日韩欧美精品中文字幕富二代| 亚洲少妇av一区二区三区| 亚洲一区二区三区色视频| 尤物欧美一区二区三区| 欧美日韩精品一级二级三级| 国内网友自拍9色视频| 国产视频免费在线播放| 国产精品96乱子一级视频| 中文字幕乱码在线精品| 女女同性女同区二区日韩| 青青草日韩av在线播放| 成人av综合网中文字幕| 九九激综合五月天国产| 国产精品99久久久精品| 精品国产乱码久久久久久男人| 久久无语av中文字幕| 中文字幕免费av在线| 欧洲美一区二区三区亚洲| 白乳房天天官网性插视频| 青青在线观看国产免费视频| 成人av在线av在线| 国产三区四区在线视频| 国产深夜视频在线观看 | 91亚洲精品久久久久蜜桃| 美女自拍偷拍亚洲一区| 国产成人精品欧美日韩网站| 成人 中文字幕 熟女| 日韩素人mium丝袜| 国产免费在线视频观看| 青青热久免费精品视频| 抽搐高潮痉挛白浆无码av| 中文字幕av网址在线| 美女伸开双腿让男人桶视频| 日韩熟女人妻国产av| 亚洲日本韩国一级二级三级| 成人在线免费播放视频| 欧美一区二区三区四区在线观看| 白白色发布在线播放国产| 一边吃扎一边插逼逼视频| 色婷婷国产精品免费视频| 亚洲午夜av久久久精品| 久久人妻公开中文字幕网| 色婷婷av国产精品欧美| 亚洲在线欧美一区二区三区| 自拍 偷拍 亚洲 欧美| 国产福利精品久久av| 久久久久精品久久久久久| 久久人人爽人人爽人人片669| 中文字幕乱码在线观看| 人妻丰满熟妇久久久久| 大香国产视频中文字幕| 97精品日韩在线视频| 欧美一级色片在线播放| 日韩精品中文字幕人妻| 日韩av中文字幕另类| 黄视频免费看网站在线观看| 最大的黄色亚洲网站在线观看| 青青成人免费在线视频| 国产亚洲精品高清一区| 国产免费九九久久精品a级| 成人24小时免费视频| 国产美女学生在线观看| 青青草原亚洲视频在线观看| 亚洲精品中文字幕午夜| 天天操天天日天天射天天爽| 最好看的中文字幕av| 最近中文字幕免费mv在线直播| 亚洲一级二级三级国产av| 人妻精品在线观看一区二区三区 | 亚洲熟妇色自偷自拍另类图片| 激情五月婷亚洲蜜臀av| 黄色av在线免费播放| AV午夜福利一片免费看久久| 人妻在卧室被老板疯狂进入| 欧美 日韩 一区二区三区| 国产精品永久免费自在线观看| 91在线视频网站总站| 搬开女人下面使劲插视频| 大乳美女疯狂榨取精子视频| av激情韩国在线播放| 人妻一区二区在线免费播放| 青青青青娱乐在线观看| 啊哈怎么被那么多男生操| 国产日韩精品在线欧美| 亚洲中文字幕一区二区三区av| 欧洲乱码在线观看视频| 91国产自拍在线视频| 国产va欧美va精品va综| 国产精品永久免费自在线观看| 99久久精品婷婷久久久久久| 伊人av超碰伊人久久久| 亚洲 自拍 欧美 中文| 成年av网站18不禁| 欧美激情在线播放一区| 人妻av蜜臀一区二不卡| 日韩欧美中文字幕人妻| 欧美黄色一级一区二区三区| 激情视频 超黄 在线免费| 亚洲性色成人av天堂| 黄色av网站手机在线播放| 白乳房天天官网性插视频| 欧美日韩乱码视频在线免费观看| 中文字幕av网址在线| 国产精品丝袜制服在线| 97视频在线免费观看网站| 91最新国产在线播放| 日本欧美一区二区视频| 国产成人乱码一区二区三区在线| 在线国产视频精品视频| 欧洲美女一区二区三区| 免费av在线网站中文字幕| 你在线上av中文字幕| 成人免费视频免费在线观看| 亚洲av成人噜噜网站| 美女观看网站免费不卡视频| 自拍视频在线观看青青网| 在线观看的资源网97| av人妻一区二区三区| 国产欧美亚洲日本网站| 欧美在线观看亚洲精品| 黄色福利视频网址大全| 97久久人妻一区二区| 人妻中文字幕免费av| 国产免费综合视频在线观看| 亚洲中文自拍另类av| 国产av一区二区三区老鸦窝| 中文字幕视频观看在线中文| 日韩制服丝袜在线播放| 欧美成人性做爰77777| 精品国产乱码久久久久夂| 蜜臀av入口一区二区三区| 国产欧美亚洲日本网站| 中文字幕精品久久久乱码乱码| 99精品人妻一区二区三蜜桃| 高潮喷水波多野结衣在线观看| 蜜桃av精品视频一区二区三区| 国产欧美精选自拍视频| 欧美专区一区二区在线| 国产一区二区不卡视频在线| 夜欲av无码精品一区二区| 人妻系列av无码专区免费| 蚂蚁三级成人av在线| 欧美激情在线播放一区| 国产成人自拍视频网址| 中文字幕乱码在线精品| 青青精品视频在线免费观看| 日韩人妻久久中文字幕| 国产精品入口蜜臀人妻| 中文字幕乱码激情av| 人妻一区二区三区精品免费| 中文字幕在线免费视频一区| 成人在线视频播放 亚洲| 国产18精品乱码在线看| 伊人色综合久久天天伊人婷| 国产亲乱的性视频网站| 精品人妻一区二区三区成人网| 久久精品国产亚洲av热黑人| 桃色视频在线观看97| 精品国产91av在线观看| 最新午夜在线观看视频| 人妻熟女一区二区91| 日韩极品视频在线观看免费| 欧美午夜理论在线观看| 日韩精品乱码av在线播放| 国产视频免费在线播放| 午夜精品福利一区二区蜜股av| 亚洲欧美综合国产精品一| 国产一区二区在线直播| 91最新精品视频在线观看| 欧美久久久久久久久久久久久| 青青草原国产视频在线观看| 91精品国产人妻国产在线| 亚洲免费成人精品视频| 亚洲三级黄色在线观看| 伊人网av中文字幕精品在线| 久久婷婷亚洲国产综合蜜臀| 精品无人区一区二区三区av| 久久久久久噜噜噜久久久精品| 成人十八禁av男人的天堂| 中文乱码在线观看视频| 大鸡巴操小嫩逼免费全裸| 97在线视频中文字幕| 极品视频在线免费播放| 中文字幕视频免费在线| 亚洲乱熟女一区二区三区com| 中文字幕人妻系列在线视频| 自拍人妻欧美亚洲第三| 91精品久久久久久久久| av中文字幕一区在线| 欧美激情1区2区3区4区| 夜夜骚av一区二区三区啊| 亚洲av丝袜诱惑在线| 国产高清av一区二区在线观看| 中文字幕在线免费看av| 最新中文字幕av大全| 精品在线观看视频一区| 国产自拍偷拍在线一区| 国产免费午夜福利视频| 男人和女人逼逼的视频| 亚洲一区视频免费在线观看| 久久久精品久久久久久69| 娇小被黑人爆出水黑人复古| 欧美黄色一级一区二区三区| 99爱在线精品视频免费看| 99九九久久国产精品| 大乳美女疯狂榨取精子视频| 亚洲国产精品视频免费看| 久久三级视频在线观看| 性做久久久久久久毛片| 国产91情侣在线视频| 亚洲自拍偷拍 欧美激情| 国产av中文字幕乱码| 绝美人妻一区二区在线观看| 欧美女同性恋一区二区三区| 俄罗斯大鸡吧操骚逼水多舒服| 视频一区二区三区国产在线| 日韩欧美精品中文字幕富二代| 熟女五十路一区二区三区 | 97在线观看视频免费视频| 中文字幕熟妇久久久人妻| 久久99精品久久久久蜜臀| 95国产成人精品视频| 国产日韩精品在线欧美| 久久精品中文字幕乱码视频| 欧美激情视频免费观看| 想神马有神马舞蹈视频| 久久久久亚洲精品乱码按摩| 中文字幕在线乱码观看| 日本熟日本熟妇中文在线观看| 亚洲三级黄色在线观看| 国产自拍免费精品视频| 亚洲在线欧美一区二区三区| 97人人爽人人爽人人人爽| 日本欧美一区二区视频| 国产视频自拍在线观看| 成年人黄视频免费观看网站| 国产护士性爽视频在线观看| 久久99av无色码人妻蜜柚| 免费av网址一区二区| 国产哟av精品色哟哟| 精品视频在线观看91| 日产精品99久久久久久久久| 视频一区二区三区国产在线| 一区二区三区在线网址| 中文字幕久久人妻综合| 亚洲情a成黄在线观看动漫尤物| 国产日韩制服丝袜第一页| 91最新黄色免费网站| 青草视频中文字幕在线观看| av一区中文字幕在线| 18成人黄色在线观看| 人妻又爱又澡人人添人人爽| 国产成人乱码一区二区三区在线| 成人黄动漫在线观看网站| 青青久久国内视频网站| 欧洲美一区二区三区亚洲| 欧美成人性做爰77777| 熟女人妻中文字幕在线看| 成人激情自拍图片视频| 国产无码精品久久久久久久| 国产自拍精品在线视频| 久久国产精品亚洲av| 亚洲精品专区一区二区| 中文字幕乱码人妻久久精品| 爱搞一区二区三区av| 久久激情四射视频一区| 成人动漫视频在线观看免费| 欧美性色黄大片人与善 | 亚洲另类激情综合偷自拍图| 欧美性色欧美a在线视频| 蜜臀av在线一区二区三区四区| 老男人xx女人视频试看| 国产欧美精品免费观看久| 国产精品久久久久久永久牛牛| 中文字幕在线免费看av| 自拍偷拍色亚洲欧美色| 九九久久久久无限久久| 国产原创AV蜜芽尤物一区| 久久久久久久九九九b热| 欧美激情在线播放一区| 亚洲国产精品黑丝美女| 国产亲乱的性视频网站| 国产精品精品久久久18| 久久黃色特三片視頻視頻視視頻 | 欧美成人精品一级在线观看| 97在线视频中文字幕| 亚洲最大黄色av网站| 国产91精品入口人妻| 九九久久久久无限久久| 成人在线视频免费播放| 97国产视频在线免费观看| 94精品视频在线播放| 精品久久久久久久久妇女| 这里都是国产视频精品| 人妻系列少妇极品熟妇| 青草青青青青青青操死你| 国产精品美女自在线观看免费| 性色av蜜臀av人妻无| 99视频一区在线观看| 国产网红主播在线观看视频| 人妻中出中文字幕在线| 午夜精品一区二区三区在视| 欧美成年一区二区三区| 性感丝袜短裙美女啪啪啪| 青青精品视频在线免费观看| 91在线视频网站总站| 国产免费九九久久精品a级| 自拍亚洲一区欧美另类| 日韩一区二区三区在线看片| 日本丝袜美腿在线观看| 高跟丝袜诱惑后入av| av激情韩国在线播放| 成年av网站18不禁| 天天操天天日天天射天天爽| 久久人人爽人人爽人人片669| 国产一区二区在线观播放| 中文字幕日本在线观看视频| 欧美 日韩 成人 三级| 国产网友自拍视频一区| 国产精品髙潮呻吟久久av| 九九久久99最新精品| 午夜av中文字幕在线观看| 噜噜av在线免费观看| av在线中文字幕播放| 久久久亚洲裙底偷窥综合| 中文字幕在线乱码观看| 你在线上av中文字幕| 亚洲国产99精品国自产| 污污污网址免费在线观看| 久久久久久精品久久久久久| 国产日韩精品在线欧美| 国产欧美精品日韩精品视频专区 | 激情av一区av二区| 国内自拍视频在线观看h| 国产欧美精品免费观看久| 大岛优香中文字幕av人妻| 97在线观看的视频资源| 欧美成人动漫在线观看| 中文字幕精品久久久乱码乱码| 国内网友自拍视频在线| 亚洲熟女一区二区av| 99爱在线精品视频免费看| 欧美久久久久久久久久久久久| 成年人免费看国产黄色片| 久久久久久狠狠综合一本| 欧美专区一区二区在线| 区一区二区三在线播放| 亚洲一区二区在线看看| 97精品综合久久视频| 激情福利视频在线观看| 日韩中文字幕avsex| 久久精品国产高潮av| 美女网站免费非常非常黄的| 伊人丝袜人妻中文字幕| 亚洲sm一区二区三区| 国产av成人专区一区| 久久久久久噜噜噜久久久精品| 国产麻豆精品在线视频| 欧美网址一区二区三区| 国产精品永久免费自在线观看| 日韩少妇一区二区三区四区五区| 中文字慕人妻一区二区在线视频| 97人在线看视频在线观看| 一区二区在线观看免费不卡| 人妻熟女欧美一区二区| 成人亚洲精品在线观看| 国产精品一级二级盗摄羞羞| 成人免费三级在线观看| av中文字幕人妻丝袜| 日本性感丝袜女秘书诱惑| 毛片久久久久久久久久久| 欧美视频精品综合在线| 91精品国产人妻国产在线| 国产丝袜另类精品综合| 成年人黄色片视频网站| 美女视频吃奶视频在线观看| 外国大片在线免费观看| 国产成人乱码一区二区三区在线| 久久av成人中文字幕| 神马不卡午夜在线观看| 人妻av蜜臀一区二不卡| 草草视频免费在线观看| 午夜18在线观看视频| 在线91华人精品国产片| 国产免费在线视频观看| 亚洲无码AV在线免费观| 国产一区二区三区在线h| 97超碰在线播放视频| 六年级小女生光滑的小嫩逼| 激情福利视频在线观看| 夜夜骚av一区二区三区啊| 污污黄色免费在线观看| 91精品国产人妻国产在线| 激情人妻校园春色亚洲欧美| 欧美日韩国产三级在线| 国产国拍成人精品视频| 亚洲av成人噜噜网站| 在线观看免费黄小视频| 老男人xx女人视频试看| 国产欧美精品免费观看久| 人妻在卧室被老板疯狂进入| 欧美精品久久久久久久久91| 9999中文字幕在线视频| 亚洲精品中文字幕一二| 欧美一区二区在线播放视频| 最好看的中文字幕av| 98久久久久久久久久| 熟女五十路一区二区三区| 中文字幕熟妇久久久人妻| 熟妇久久久人妻中文字幕| 欧美一区二区免费在线观看| 国产精品欧美一区二区久久久 | 亚洲一级av对白刺激| 国产亚洲成人精品视频| 精品熟妇人妻一区二区三区四区| 黄色十八禁精品无遮挡| 久久热视频在线免费观看| 国产精品久久久久精品日| 国产av日韩精品久久| 国产女人叫床高潮大片免费| 成人黄色免费观看网址| 亚洲自拍一区在线观看| 超级碰碰在线视频国产| 欧美性少妇一区二区三区| 青青河边草观看完整版高清| 色偷偷av一区二区三区| 青青草草视频在线播放| 亚洲国产成人不卡av| 最新免费av在线观看| 欧美在线观看亚洲精品| 蜜月久久99精品久久久久久| 国产99在线视频免费| 青娱乐 青青青操 天天日| 国产精品成人中文字幕| 日韩在线不卡一区在线观看| 97久久久久久久久久久| 日本美女丝袜天天看人体| 快速播放国产精品视频| 国产成人免费在线观看av| av激情韩国在线播放| 日韩国产中文字幕精品| 亚洲av乱码在线观看| 久久天天躁狠狠躁夜夜av| 黄色传媒在线免费观看| 亚洲精品中文字幕一二| 激情伦理一区二区三区| 在线观看国产视频播放| 91色乱码一区二区三| 久久久久久4久久久8| 久久久久久久久极品内射| 精品国产专区91精品| 国产精品美女自在线观看免费| 青青艹视频在线免费观看| 欧洲乱码在线观看视频| 97超碰超碰在线观看| 日本视频在线一区二区三区| 日本一区二区三级在线观看| 亚洲精品国产av久久| 97 在线免费观看视频| 大乳美女疯狂榨取精子视频| 亚洲自拍一区在线观看| 超级碰碰在线视频国产| 98久久久久久久久久| 青青色在线视频观看免费| 我想看男人日女人的逼| 国产乱精品一区二区视频了| 夜夜骚av一区二区三区啊| 大香视频依人在线中文字幕| 99九九99久久精品| 伊人精品久久久久中文字幕| 日韩精品人妻av中文字幕| 欧美一区二区三区四区免费| 91大神精品免费在线播放| 日韩女优精品在线观看| 天海翼一区二区三区免费| 欧美生活一区二区三区| 国产黄色av网站在线| 欧美一级内射视频在线播放| 日本免费一区二区三区中文字幕| 国产高清一级视频在线观看| 成人黄动漫在线观看网站| 亚洲一区二区欧美激情| 黄色十八禁精品无遮挡| 网友自拍人妻在线视频| 国产精品一二av在线| 国产欧美精品免费观看久| 97资源超碰在线中文| 国产av一区二区三区老鸦窝| 高潮喷水波多野结衣在线观看| av天堂中文字幕精品| 巨乳人妻中文字幕精品在线| 欧美精品网站在线视频| 黄色福利视频网址大全| 精品无人区一区二区三区av| 91草草视频在线观看| 国产精品久久久久久码| 欧美黄色一级一区二区三区| 日韩极品视频在线观看免费| 欧美激情高潮无遮挡男男| 精品久久久久久久久妇女| 亚洲av日韩精品久久| 久久老熟女一区二区福利蜜臀| 一区二区三区在线网址| 欧美 亚洲一区二区在线| 欧美精品免费在线播放| 2023国产精品自拍视频| 国产剧情午夜在线观看| 日韩素人mium丝袜| 国产精品美女久久久久久不卡| 国产丝袜另类精品综合| 日本精品一区二区三区精品在线| 久久久亚洲裙底偷窥综合| 啊啊啊啊插进去你好骚视频| 日韩制服丝袜在线播放| 国产福利精品久久av| 男人操女人逼视频免费观看| 男人操女人的逼免费网站| 污污黄色免费在线观看| 亚洲欧洲自拍拍偷第二页| 女人是为抠逼男人的鸡巴操逼| 真人视频在线免费观看| 午夜嗨起视频在线观看| 日韩欧美人妻激情一区| 国产精品久久综合亚洲av| 久久久99精品久久久久久久| av现场直播亚洲乱码| 亚洲一区二区在线看看| 亚洲成人久久精品国产| 久久人妻公开中文字幕网| 国产乱码字幕精品高清人v| 人妻精品在线观看一区二区三区 | 青青操新免费观看视频| 日韩欧美一区二区专区在线观看| 国产乱人视频免费观看| 亚洲天堂中文av网站| 爆乳美女粉嫩阴蒂被插视频| 中文字幕久久人妻综合 | 日韩人妻丝袜美腿中文| 青青青国产免费观看视频| 大香视频依人在线中文字幕 | 国产精品成人自拍视频| 人妻夜夜爽天天爽欧美色院| 国产成人黄色在线观看| 日韩熟女少妇一区二区三区| 97视频在线观看免费播放| 人妻少妇激情综合小视频| 久久精品久久一区二区| 欧美国产日韩另类系列| 韩国性感美女热舞视频| 亚洲成人日韩免费在线播放| 色av色婷婷91人妻久久久| 国产黄色片久久久久久久| 黄色av在线免费播放| 99久久麻豆99久久免费| 国产高清亚洲精品视频| 日本一卡视频在线观看免费| 97 在线免费观看视频| 欧美一区二区在线播放视频| 欧美一区二区在线观看网站| 麻豆av国语对白麻豆| av一区二区三区看片| 精品在线观看视频一区| 欧美日韩一区三区不卡在线 | 国产18精品乱码在线看| 24小时在线免费观看高清视频| 亚洲少妇av一区二区三区 | 久久人人妻人人做人人爽| 明日花绮罗人妻大乳av| 制服丝袜 日韩 国产| 国产精久久久久久一区二区三区| 久久99亚洲精品久久频| 正在播放99精品视频在线播放| 精品国产乱码久久久久久男人| 亚洲 综合 欧美 日韩| av中文在线中文av| 亚洲一区美腿丝袜在线播放 | 欧美亚洲另类丝袜在线| 成人国产麻豆一区二区| 亚洲不伦丝袜人妻在线| 白白色发布在线播放国产| 亚洲三级一区二区三区四区| 精品久久久人妻中文字幕| 国内揄拍国内精品人妻迷| 成人国产精品av在线| 国内伦理视频在线观看| 国产69精品久久久久久妇| 911精品在线免费观看| 97国产视频在线观看| 国产无码精品久久久久久久| seseav在线观看| 人妻中出中文字幕在线| 青青草原亚洲视频在线观看| 欧美一区二区国产一区| 精色av中文字幕在线| 绝美人妻一区二区在线观看| 超碰人妻免费一区二区| 国产精品亚洲在线播放| 精品日本一区二区三区四区| 精品人妻伦一二二区久久| 久久乐国产精品亚洲综合| 国产偷拍自拍熟女视频| carpon视频在线观看| 在线观看不卡一区二区三区| 国产自拍免费精品视频| 精品无人区麻豆乱码久久久| 国产一区二区三区在线h| 国产高清一级视频在线观看| 中文字幕久久久2029| 在线观看不卡一区二区三区 | 亚洲人妻av一区二区| 99九九99久久精品| 午夜97视频在线观看| 久久久久久久九九九b热| 9999中文字幕在线视频| 亚洲sm一区二区三区| 午夜精品视频一区二区| 亚洲丝袜av在线观看| 国产91精品入口人妻| 亚洲黄色分享大全探花| 亚洲国产成人精品久久久久| 美女在线观看免费在线观看| 无码国模大尺度自拍视频在线看 | 青青艹视频在线免费观看| 欧美一区二区在线播放视频| 猫咪av成人永久网站网址| 99爱精品视频在线视频| 国产精品色哟哟在线观看视频| 久久综合中文字幕日韩精品| 97在线观看视频免费视频| 国产精品三级av及在线观看| 亚洲三级黄色在线观看| 深夜在线视频在线观看| 女人日男人30分钟视频| 97色老99久久九九爱精品| 亚洲熟女区一区二区三| 日韩成人伦理片在线观看| 国产视频二区在线观看| 日韩 制服 丝袜 中文| 国内一区二区三区视频在线播放| 中文字幕综合av一区二区三区| 国产欧美日韩精品一区二区三区| 日本丝袜美腿在线观看|