日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

ES6学习笔记(十六)async函数

發布時間:2024/10/12 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ES6学习笔记(十六)async函数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1.含義

ES2017 標準引入了 async 函數,使得異步操作變得更加方便。

async 函數是什么?一句話,它就是 Generator 函數的語法糖,號稱異步的終極解決方案。

前文有一個 Generator 函數,依次讀取兩個文件。

1 const fs = require('fs'); 2 3 const readFile = function (fileName) { 4 return new Promise(function (resolve, reject) { 5 fs.readFile(fileName, function(error, data) { 6 if (error) return reject(error); 7 resolve(data); 8 }); 9 }); 10 }; 11 12 const gen = function* () { 13 const f1 = yield readFile('/etc/fstab'); 14 const f2 = yield readFile('/etc/shells'); 15 console.log(f1.toString()); 16 console.log(f2.toString()); 17 };

上面代碼的函數gen可以寫成async函數,就是下面這樣。

const asyncReadFile = async function () {const f1 = await readFile('/etc/fstab');const f2 = await readFile('/etc/shells');console.log(f1.toString());console.log(f2.toString()); };

一比較就會發現,async函數就是將 Generator 函數的星號(*)替換成async,將yield替換成await,僅此而已。

async函數對 Generator 函數的改進,體現在以下四點。

(1)內置執行器。

Generator 函數的執行必須靠執行器,所以才有了co模塊,而async函數自帶執行器。也就是說,async函數的執行,與普通函數一模一樣,只要一行。

asyncReadFile();

上面的代碼調用了asyncReadFile函數,然后它就會自動執行,輸出最后結果。這完全不像 Generator 函數,需要調用next方法,或者用co模塊,才能真正執行,得到最后結果。

(2)更好的語義。

asyncawait,比起星號和yield,語義更清楚了。async表示函數里有異步操作,await表示緊跟在后面的表達式需要等待結果。

(3)更廣的適用性。

co模塊約定,yield命令后面只能是 Thunk 函數或 Promise 對象,而async函數的await命令后面,可以是 Promise 對象和原始類型的值(數值、字符串和布爾值,但這時會自動轉成立即 resolved 的 Promise 對象)。

(4)返回值是 Promise。

async函數的返回值是 Promise 對象,這比 Generator 函數的返回值是 Iterator 對象方便多了。你可以用then方法指定下一步的操作。

進一步說,async函數完全可以看作多個異步操作,包裝成的一個 Promise 對象,而await命令就是內部then命令的語法糖。

2.基本用法

async函數返回一個 Promise 對象,可以使用then方法添加回調函數。當函數執行的時候,一旦遇到await就會先返回,等到異步操作完成,再接著執行函數體內后面的語句。

async function getStockPriceByName(name) {const symbol = await getStockSymbol(name);const stockPrice = await getStockPrice(symbol);return stockPrice; }getStockPriceByName('goog').then(function (result) {console.log(result); });

上面代碼是一個獲取股票報價的函數,函數前面的async關鍵字,表明該函數內部有異步操作。調用該函數時,會立即返回一個Promise對象。

1 function timeout(ms) { 2 return new Promise((resolve) => { 3 setTimeout(resolve, ms); 4 }); 5 } 6 7 async function asyncPrint(value, ms) { 8 await timeout(ms); 9 console.log(value); 10 } 11 12 asyncPrint('hello world', 50);

上面代碼指定 50 毫秒以后,輸出hello world。

由于async函數返回的是 Promise 對象,可以作為await命令的參數。所以,上面的例子也可以寫成下面的形式。

1 async function timeout(ms) { 2 await new Promise((resolve) => { 3 setTimeout(resolve, ms); 4 }); 5 } 6 7 async function asyncPrint(value, ms) { 8 await timeout(ms); 9 console.log(value); 10 } 11 12 asyncPrint('hello world', 50);

async 函數有多種使用形式。

1 // 函數聲明 2 async function foo() {} 3 4 // 函數表達式 5 const foo = async function () {}; 6 7 // 對象的方法 8 let obj = { async foo() {} }; 9 obj.foo().then(...) 10 11 // Class 的方法 12 class Storage { 13 constructor() { 14 this.cachePromise = caches.open('avatars'); 15 } 16 17 async getAvatar(name) { 18 const cache = await this.cachePromise; 19 return cache.match(`/avatars/${name}.jpg`); 20 } 21 } 22 23 const storage = new Storage(); 24 storage.getAvatar('jake').then(…); 25 26 // 箭頭函數 27 const foo = async () => {};

3.語法

async函數的語法規則總體上比較簡單,難點是錯誤處理機制。

返回 Promise 對象?

async函數返回一個 Promise 對象。

async函數內部return語句返回的值,會成為then方法回調函數的參數。

async function f() {return 'hello world'; }f().then(v => console.log(v)) // "hello world"

上面代碼中,函數f內部return命令返回的值,會被then方法回調函數接收到。

async函數內部拋出錯誤,會導致返回的 Promise 對象變為reject狀態。拋出的錯誤對象會被catch方法回調函數接收到。

async function f() {throw new Error('出錯了'); }f().then(v => console.log(v),e => console.log(e) ) // Error: 出錯了

Promise 對象的狀態變化

async函數返回的 Promise 對象,必須等到內部所有await命令后面的 Promise 對象執行完,才會發生狀態改變,除非遇到return語句或者拋出錯誤。也就是說,只有async函數內部的異步操作執行完,才會執行then方法指定的回調函數。

async function getTitle(url) {let response = await fetch(url);let html = await response.text();return html.match(/<title>([\s\S]+)<\/title>/i)[1]; } getTitle('https://tc39.github.io/ecma262/').then(console.log) // "ECMAScript 2017 Language Specification"

上面代碼中,函數getTitle內部有三個操作:抓取網頁、取出文本、匹配頁面標題。只有這三個操作全部完成,才會執行then方法里面的console.log。

await 命令

正常情況下,await命令后面是一個 Promise 對象,返回該對象的結果。如果不是 Promise 對象,就直接返回對應的值。

async function f() {// 等同于// return 123;return await 123; }f().then(v => console.log(v)) // 123

上面代碼中,await命令的參數是數值123,這時等同于return 123。

另一種情況是,await命令后面是一個thenable對象(即定義then方法的對象),那么await會將其等同于 Promise 對象。

1 class Sleep { 2 constructor(timeout) { 3 this.timeout = timeout; 4 } 5 then(resolve, reject) { 6 const startTime = Date.now(); 7 setTimeout( 8 () => resolve(Date.now() - startTime), 9 this.timeout 10 ); 11 } 12 } 13 14 (async () => { 15 const actualTime = await new Sleep(1000); 16 console.log(actualTime); 17 })();

上面代碼中,await命令后面是一個Sleep對象的實例。這個實例不是 Promise 對象,但是因為定義了then方法,await會將其視為Promise處理。

await命令后面的 Promise 對象如果變為reject狀態,則reject的參數會被catch方法的回調函數接收到。

async function f() {await Promise.reject('出錯了'); }f() .then(v => console.log(v)) .catch(e => console.log(e)) // 出錯了

注意,上面代碼中,await語句前面沒有return,但是reject方法的參數依然傳入了catch方法的回調函數。這里如果在await前面加上return,效果是一樣的。

任何一個await語句后面的 Promise 對象變為reject狀態,那么整個async函數都會中斷執行。

async function f() {await Promise.reject('出錯了');await Promise.resolve('hello world'); // 不會執行 }

上面代碼中,第二個await語句是不會執行的,因為第一個await語句狀態變成了reject。

有時,我們希望即使前一個異步操作失敗,也不要中斷后面的異步操作。這時可以將第一個await放在try...catch結構里面,這樣不管這個異步操作是否成功,第二個await都會執行。

async function f() {try {await Promise.reject('出錯了');} catch(e) {}return await Promise.resolve('hello world'); }f() .then(v => console.log(v)) // hello world

另一種方法是await后面的 Promise 對象再跟一個catch方法,處理前面可能出現的錯誤。

async function f() {await Promise.reject('出錯了').catch(e => console.log(e));return await Promise.resolve('hello world'); }f() .then(v => console.log(v)) // 出錯了 // hello world

錯誤處理

如果await后面的異步操作出錯,那么等同于async函數返回的 Promise 對象被reject。

async function f() {await new Promise(function (resolve, reject) {throw new Error('出錯了');}); }f() .then(v => console.log(v)) .catch(e => console.log(e)) // Error:出錯了

上面代碼中,async函數f執行后,await后面的 Promise 對象會拋出一個錯誤對象,導致catch方法的回調函數被調用,它的參數就是拋出的錯誤對象。具體的執行機制,可以參考后文的“async 函數的實現原理”。

防止出錯的方法,也是將其放在try...catch代碼塊之中。

async function f() {try {await new Promise(function (resolve, reject) {throw new Error('出錯了');});} catch(e) {}return await('hello world'); }

如果有多個await命令,可以統一放在try...catch結構中。

1 async function main() { 2 try { 3 const val1 = await firstStep(); 4 const val2 = await secondStep(val1); 5 const val3 = await thirdStep(val1, val2); 6 7 console.log('Final: ', val3); 8 } 9 catch (err) { 10 console.error(err); 11 } 12 }

下面的例子使用try...catch結構,實現多次重復嘗試。

1 const superagent = require('superagent'); 2 const NUM_RETRIES = 3; 3 4 async function test() { 5 let i; 6 for (i = 0; i < NUM_RETRIES; ++i) { 7 try { 8 await superagent.get('http://google.com/this-throws-an-error'); 9 break; 10 } catch(err) {} 11 } 12 console.log(i); // 3 13 } 14 15 test();

上面代碼中,如果await操作成功,就會使用break語句退出循環;如果失敗,會被catch語句捕捉,然后進入下一輪循環。這個操作很神奇啊。

使用注意點?

第一點,前面已經說過,await命令后面的Promise對象,運行結果可能是rejected,所以最好把await命令放在try...catch代碼塊中。

1 async function myFunction() { 2 try { 3 await somethingThatReturnsAPromise(); 4 } catch (err) { 5 console.log(err); 6 } 7 } 8 9 // 另一種寫法 10 11 async function myFunction() { 12 await somethingThatReturnsAPromise() 13 .catch(function (err) { 14 console.log(err); 15 }); 16 }

第二點,多個await命令后面的異步操作,如果不存在繼發關系,最好讓它們同時觸發。

let foo = await getFoo(); let bar = await getBar();

上面代碼中,getFoo和getBar是兩個獨立的異步操作(即互不依賴),被寫成繼發關系。這樣比較耗時,因為只有getFoo完成以后,才會執行getBar,完全可以讓它們同時觸發。

// 寫法一 let [foo, bar] = await Promise.all([getFoo(), getBar()]);// 寫法二 let fooPromise = getFoo(); let barPromise = getBar(); let foo = await fooPromise; let bar = await barPromise;

上面兩種寫法,getFoo和getBar都是同時觸發,這樣就會縮短程序的執行時間。

第三點await命令只能用在async函數之中,如果用在普通函數,就會報錯。

async function dbFuc(db) {let docs = [{}, {}, {}];// 報錯docs.forEach(function (doc) {await db.post(doc);}); }

上面代碼會報錯,因為await用在普通函數之中了。但是,如果將forEach方法的參數改成async函數,也有問題。

function dbFuc(db) { //這里不需要 asynclet docs = [{}, {}, {}];// 可能得到錯誤結果docs.forEach(async function (doc) {await db.post(doc);}); }

上面代碼可能不會正常工作,原因是這時三個db.post操作將是并發執行,也就是同時執行,而不是繼發執行。正確的寫法是采用for循環。

async function dbFuc(db) {let docs = [{}, {}, {}];for (let doc of docs) {await db.post(doc);} }

如果確實希望多個請求并發執行,可以使用Promise.all方法。當三個請求都會resolved時,下面兩種寫法效果相同。

1 async function dbFuc(db) { 2 let docs = [{}, {}, {}]; 3 let promises = docs.map((doc) => db.post(doc)); 4 5 let results = await Promise.all(promises); 6 console.log(results); 7 } 8 9 // 或者使用下面的寫法 10 11 async function dbFuc(db) { 12 let docs = [{}, {}, {}]; 13 let promises = docs.map((doc) => db.post(doc)); 14 15 let results = []; 16 for (let promise of promises) { 17 results.push(await promise); 18 } 19 console.log(results); 20 }

目前,esm模塊加載器支持頂層await,即await命令可以不放在 async 函數里面,直接使用。

// async 函數的寫法 const start = async () => {const res = await fetch('google.com');return res.text(); };start().then(console.log);// 頂層 await 的寫法 const res = await fetch('google.com'); console.log(await res.text());

上面代碼中,第二種寫法的腳本必須使用esm加載器,才會生效。

第四點,async 函數可以保留運行堆棧。

const a = () => {b().then(() => c()); };

上面代碼中,函數a內部運行了一個異步任務b()。當b()運行的時候,函數a()不會中斷,而是繼續執行。等到b()運行結束,可能a()早就運行結束了,b()所在的上下文環境已經消失了。如果b()或c()報錯,錯誤堆棧將不包括a()。

現在將這個例子改成async函數。

const a = async () => {await b();c(); };

上面代碼中,b()運行的時候,a()是暫停執行,上下文環境都保存著。一旦b()或c()報錯,錯誤堆棧將包括a()。

4.async 函數的實現原理

async 函數的實現原理,就是將 Generator 函數和自動執行器,包裝在一個函數里

async function fn(args) {// ... }// 等同于function fn(args) {return spawn(function* () {// ... }); }

所有的async函數都可以寫成上面的第二種形式,其中的spawn函數就是自動執行器。

下面給出spawn函數的實現,基本就是前文自動執行器的翻版。

1 function spawn(genF) { 2 return new Promise(function(resolve, reject) { 3 const gen = genF(); 4 function step(nextF) { 5 let next; 6 try { 7 next = nextF(); 8 } catch(e) { 9 return reject(e); 10 } 11 if(next.done) { 12 return resolve(next.value); 13 } 14 Promise.resolve(next.value).then(function(v) { 15 step(function() { return gen.next(v); }); 16 }, function(e) { 17 step(function() { return gen.throw(e); }); 18 }); 19 } 20 step(function() { return gen.next(undefined); }); 21 }); 22 }

5.與其他異步處理方法的比較

我們通過一個例子,來看 async 函數與 PromiseGenerator 函數的比較

假定某個 DOM 元素上面,部署了一系列的動畫,前一個動畫結束,才能開始后一個。如果當中有一個動畫出錯,就不再往下執行,返回上一個成功執行的動畫的返回值。

首先是 Promise 的寫法。

1 function chainAnimationsPromise(elem, animations) { 2 3 // 變量ret用來保存上一個動畫的返回值 4 let ret = null; 5 6 // 新建一個空的Promise 7 let p = Promise.resolve(); 8 9 // 使用then方法,添加所有動畫 10 for(let anim of animations) { 11 p = p.then(function(val) { 12 ret = val; 13 return anim(elem); 14 }); 15 } 16 17 // 返回一個部署了錯誤捕捉機制的Promise 18 return p.catch(function(e) { 19 /* 忽略錯誤,繼續執行 */ 20 }).then(function() { 21 return ret; 22 }); 23 24 }

雖然 Promise 的寫法比回調函數的寫法大大改進,但是一眼看上去,代碼完全都是 Promise 的 API(then、catch等等),操作本身的語義反而不容易看出來。

接著是 Generator 函數的寫法。

1 function chainAnimationsGenerator(elem, animations) { 2 3 return spawn(function*() { 4 let ret = null; 5 try { 6 for(let anim of animations) { 7 ret = yield anim(elem); 8 } 9 } catch(e) { 10 /* 忽略錯誤,繼續執行 */ 11 } 12 return ret; 13 }); 14 15 }

上面代碼使用 Generator 函數遍歷了每個動畫,語義比 Promise 寫法更清晰,用戶定義的操作全部都出現在spawn函數的內部。這個寫法的問題在于,必須有一個任務運行器,自動執行 Generator 函數,上面代碼的spawn函數就是自動執行器,它返回一個 Promise 對象,而且必須保證yield語句后面的表達式,必須返回一個 Promise。

最后是 async 函數的寫法。

1 async function chainAnimationsAsync(elem, animations) { 2 let ret = null; 3 try { 4 for(let anim of animations) { 5 ret = await anim(elem); 6 } 7 } catch(e) { 8 /* 忽略錯誤,繼續執行 */ 9 } 10 return ret; 11 }

可以看到 Async 函數的實現最簡潔,最符合語義,幾乎沒有語義不相關的代碼。它將 Generator 寫法中的自動執行器,改在語言層面提供,不暴露給用戶,因此代碼量最少。如果使用 Generator 寫法,自動執行器需要用戶自己提供。

6.實例:按順序完成異步操作

實際開發中,經常遇到一組異步操作,需要按照順序完成。比如,依次遠程讀取一組 URL,然后按照讀取的順序輸出結果。

Promise 的寫法如下。

1 function logInOrder(urls) { 2 // 遠程讀取所有URL 3 const textPromises = urls.map(url => { 4 return fetch(url).then(response => response.text()); 5 }); 6 7 // 按次序輸出 8 textPromises.reduce((chain, textPromise) => { 9 return chain.then(() => textPromise) 10 .then(text => console.log(text)); 11 }, Promise.resolve()); 12 }

上面代碼使用fetch方法,同時遠程讀取一組 URL。每個fetch操作都返回一個 Promise 對象,放入textPromises數組。然后,reduce方法依次處理每個 Promise 對象,然后使用then,將所有 Promise 對象連起來,因此就可以依次輸出結果。

這種寫法不太直觀,可讀性比較差。下面是 async 函數實現。

async function logInOrder(urls) {for (const url of urls) {const response = await fetch(url);console.log(await response.text());} }

上面代碼確實大大簡化,問題是所有遠程操作都是繼發。只有前一個 URL 返回結果,才會去讀取下一個 URL,這樣做效率很差,非常浪費時間。我們需要的是并發發出遠程請求。

1 async function logInOrder(urls) { 2 // 并發讀取遠程URL 3 const textPromises = urls.map(async url => { 4 const response = await fetch(url); 5 return response.text(); 6 }); 7 8 // 按次序輸出 9 for (const textPromise of textPromises) { 10 console.log(await textPromise); 11 } 12 }

上面代碼中,雖然map方法的參數是async函數,但它是并發執行的,因為只有async函數內部是繼發執行,外部不受影響。后面的for..of循環內部使用了await,因此實現了按順序輸出。

7.異步遍歷器

《遍歷器》一章說過,Iterator 接口是一種數據遍歷的協議,只要調用遍歷器對象的next方法,就會得到一個對象,表示當前遍歷指針所在的那個位置的信息。next方法返回的對象的結構是{value, done},其中value表示當前的數據的值,done是一個布爾值,表示遍歷是否結束。

這里隱含著一個規定,next方法必須是同步的,只要調用就必須立刻返回值。也就是說,一旦執行next方法,就必須同步地得到value和done這兩個屬性。如果遍歷指針正好指向同步操作,當然沒有問題,但對于異步操作,就不太合適了。目前的解決方法是,Generator 函數里面的異步操作,返回一個 Thunk 函數或者 Promise 對象,即value屬性是一個 Thunk 函數或者 Promise 對象,等待以后返回真正的值,而done屬性則還是同步產生的。

ES2018?引入了“異步遍歷器”(Async Iterator),為異步操作提供原生的遍歷器接口,即value和done這兩個屬性都是異步產生。

異步遍歷的接口

異步遍歷器的最大的語法特點,就是調用遍歷器的next方法,返回的是一個 Promise 對象。

asyncIterator.next().then(({ value, done }) => /* ... */);

上面代碼中,asyncIterator是一個異步遍歷器,調用next方法以后,返回一個 Promise 對象。因此,可以使用then方法指定,這個 Promise 對象的狀態變為resolve以后的回調函數。回調函數的參數,則是一個具有value和done兩個屬性的對象,這個跟同步遍歷器是一樣的。

我們知道,一個對象的同步遍歷器的接口,部署在Symbol.iterator屬性上面。同樣地,對象的異步遍歷器接口,部署在Symbol.asyncIterator屬性上面。不管是什么樣的對象,只要它的Symbol.asyncIterator屬性有值,就表示應該對它進行異步遍歷。

下面是一個異步遍歷器的例子。

1 const asyncIterable = createAsyncIterable(['a', 'b']); 2 const asyncIterator = asyncIterable[Symbol.asyncIterator](); 3 4 asyncIterator 5 .next() 6 .then(iterResult1 => { 7 console.log(iterResult1); // { value: 'a', done: false } 8 return asyncIterator.next(); 9 }) 10 .then(iterResult2 => { 11 console.log(iterResult2); // { value: 'b', done: false } 12 return asyncIterator.next(); 13 }) 14 .then(iterResult3 => { 15 console.log(iterResult3); // { value: undefined, done: true } 16 });

了解一下,異步遍歷器不再深究。

for await...of

前面介紹過,for...of循環用于遍歷同步的 Iterator 接口。新引入的for await...of循環,則是用于遍歷異步的 Iterator 接口。

async function f() {for await (const x of createAsyncIterable(['a', 'b'])) {console.log(x);} } // a // b

異步 Generator 函數

?就像 Generator 函數返回一個同步遍歷器對象一樣,異步 Generator 函數的作用,是返回一個異步遍歷器對象。

yield* 語句

yield*語句也可以跟一個異步遍歷器。

async function* gen1() {yield 'a';yield 'b';return 2; }async function* gen2() {// result 最終會等于 2const result = yield* gen1(); }

上面代碼中,gen2函數里面的result變量,最后的值是2。

與同步 Generator 函數一樣,for await...of循環會展開yield*。

沒有最好的方法,只有最適合的方法。

轉載于:https://www.cnblogs.com/jixiaohua/p/10674686.html

總結

以上是生活随笔為你收集整理的ES6学习笔记(十六)async函数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

成人资源在线观看 | 最新动作电影 | 日韩免费在线一区 | 婷婷色综合网 | 日日爱夜夜爱 | 久久久久一区二区三区 | 国产一级高清视频 | 亚洲精品女人久久久 | 亚洲在线激情 | 亚洲精品一区二区在线观看 | 日韩天天操 | 18国产精品福利片久久婷 | 在线播放亚洲 | 国产美女免费视频 | 波多野结衣一区二区三区中文字幕 | 91最新网址在线观看 | 久草在线免费在线观看 | 亚州精品天堂中文字幕 | 中文字幕在线免费看 | 毛片基地黄久久久久久天堂 | 黄色一级性片 | 日韩欧美网站 | 91精品国产欧美一区二区 | 在线观看黄网站 | 婷婷九月丁香 | 亚洲成av人影院 | 日本精品视频免费观看 | 欧美va天堂va视频va在线 | 一级黄色电影网站 | 久久久人 | 玖玖玖精品 | 激情视频免费在线观看 | 偷拍福利视频一区二区三区 | 国产系列精品av | 在线观看免费高清视频大全追剧 | 亚洲黄色成人 | 久久精品中文字幕一区二区三区 | 人人爽人人插 | 一级电影免费在线观看 | 国产美女黄网站免费 | 亚洲一区二区麻豆 | 91视频下载 | 超碰97国产| japanesexxx乱女另类 | 国产日韩欧美综合在线 | 国产黄色一级片 | 国产视频综合在线 | www.久久99| 国产色视频网站2 | 中文字幕电影一区 | 五月情婷婷 | 91热| 97超碰人人模人人人爽人人爱 | 99热精品在线观看 | 久草在线最新免费 | 色a在线观看 | 91精品亚洲影视在线观看 | 国产在线最新 | 国产精品四虎 | 高清av免费观看 | 成人在线免费看视频 | 国产一区欧美二区 | 亚洲在线黄色 | 欧美国产日韩一区二区三区 | 中文字幕网站 | 欧美成人a在线 | 激情久久伊人 | 精品亚洲免费 | 久久久视频在线 | 亚洲成人精品在线观看 | 激情视频国产 | 中日韩欧美精彩视频 | 精品国产99 | 欧美精品小视频 | av中文在线 | 伊人网av | www.com.日本一级 | 欧美资源在线观看 | 波多野结衣电影一区 | 99久久这里有精品 | 亚洲国产成人在线播放 | 国产在线观看高清视频 | 国产免费一区二区三区网站免费 | 激情久久久久久久久久久久久久久久 | 久草在线官网 | www.久久成人 | 亚洲日韩中文字幕在线播放 | 黄色三级在线看 | 91在线麻豆 | 精品久久久久久亚洲 | 国产亚洲精品久久久久久无几年桃 | 久久久久综合视频 | 啪啪av在线| 国产视频 久久久 | 日韩在线三级 | 亚洲无毛专区 | 久久在线播放 | 中文字幕日韩一区二区三区不卡 | 美女网色 | 成人黄色大片 | 一区二区三区精品久久久 | 国产精品久久av | 国产日韩精品一区二区在线观看播放 | zzijzzij亚洲成熟少妇 | 91麻豆视频网站 | 激情视频在线高清看 | 日韩两性视频 | 久草爱| 在线免费观看羞羞视频 | 毛片在线播放网址 | 国产专区免费 | 国产婷婷vvvv激情久 | 成人黄色av免费在线观看 | 日韩中文字幕电影 | 黄色在线观看www | 麻豆传媒电影在线观看 | 97人人看 | 日韩黄色中文字幕 | 欧美人交a欧美精品 | 爱色婷婷 | 日韩性片 | 欧美日韩高清免费 | 国产成人精品综合 | 久99久精品视频免费观看 | 91成人区 | 欧美乱大交 | 久久精品视频在线免费观看 | 成人黄色免费在线观看 | 久久精品资源 | 亚洲高清国产视频 | av一级久久| www黄| 日韩精品1区2区 | 999亚洲国产996395 | 亚洲国产欧美在线人成大黄瓜 | 国产精品一区二区久久精品 | 亚洲aaa级 | 久久国产精品久久精品国产演员表 | 99精品观看 | 香蕉视频久久 | 欧美在线视频日韩 | 欧美日韩高清在线 | 国产又粗又猛又黄又爽 | 国产黄大片 | 国产韩国日本高清视频 | 蜜桃传媒一区二区 | 久久久久免费精品国产 | 91资源在线视频 | 国产精品麻豆欧美日韩ww | 免费在线观看日韩欧美 | 亚洲dvd | 国产黑丝一区二区三区 | 国产一区二区视频在线播放 | 美州a亚洲一视本频v色道 | 久久精品久久久精品美女 | 爱爱av网| 欧美一区二区视频97 | 99国内精品 | www久久精品| 久久久久久久网站 | 亚洲欧美视频一区二区三区 | 日本在线视频网址 | 黄色小说网站在线 | 久色网 | 欧美巨乳波霸 | 超碰人人在 | 亚洲电影久久久 | 日韩毛片在线免费观看 | 激情av一区二区 | 九色最新网址 | 中文字幕欲求不满 | 欧美激情精品 | 久久久精品久久日韩一区综合 | 黄色毛片电影 | 激情五月在线视频 | 欧美 激情 国产 91 在线 | 在线中文字幕网站 | 中文字幕一区二区三区在线观看 | 亚洲精品国产综合99久久夜夜嗨 | 国产黄a三级 | 国产精品黑丝在线观看 | 激情丁香在线 | 国产欧美精品一区二区三区四区 | 欧美午夜剧场 | 91av小视频 | 中文字幕在线观看视频网站 | 免费观看日韩av | 99精品视频在线观看视频 | 国产一二三精品 | www.com在线观看 | 99热这里只有精品8 久久综合毛片 | 黄色一级免费网站 | 亚洲精品美女久久 | 99视频精品全部免费 在线 | 国产一区免费观看 | www视频在线播放 | 久久综合九色99 | 精品国产伦一区二区三区观看方式 | 精品亚洲午夜久久久久91 | 国内精品久久久久久久久久久久 | 激情久久一区二区三区 | 毛片网在线 | 亚洲人成在线观看 | 久久任你操 | 亚洲一区二区高潮无套美女 | 精品视频免费久久久看 | 69视频永久免费观看 | 美女久久久久久久久久久 | 色婷婷成人网 | 麻豆成人在线观看 | 在线免费性生活片 | 免费日韩视频 | 丰满少妇在线观看 | 天堂在线一区 | 免费黄色激情视频 | 一级欧美一级日韩 | 制服丝袜亚洲 | 蜜臀av在线一区二区三区 | 国产超碰97 | 亚洲一区久久 | 国产午夜精品av一区二区 | 国产一区二区手机在线观看 | 国产精品爽爽久久久久久蜜臀 | 九九免费精品 | 国产九九九精品视频 | a成人v | 一区二区三区在线观看免费 | 精品国产伦一区二区三区免费 | 久久激情五月婷婷 | 中文字幕在线观看视频一区二区三区 | 日韩理论片 | 色综合久久久久久中文网 | 中文字幕亚洲在线观看 | 91成人短视频在线观看 | 人人干人人搞 | 一区二区三区在线电影 | 永久免费毛片 | 911久久| av成人黄色 | 日批视频在线播放 | 丁香五香天综合情 | 日韩精品久久久久久久电影竹菊 | 天天搞夜夜骑 | 亚洲涩涩涩 | 怡红院成人在线 | 日韩欧美在线一区二区 | 超碰在线人人 | av大片免费在线观看 | 亚洲精品66| av免费播放 | 国产一区二区电影在线观看 | 久久精品站| av大片免费在线观看 | 91九色九色 | 五月色综合 | 在线观看黄网站 | 国产91av视频在线观看 | 亚洲电影久久久 | 高清精品在线 | 国产一区二区免费 | 操操操综合 | 国语对白少妇爽91 | 免费a级毛片在线看 | 在线观看视频一区二区三区 | 天天射色综合 | 精品国偷自产在线 | 热久久99这里有精品 | 伊人久久影视 | 免费看的国产视频网站 | a黄色一级片 | 国产精品video爽爽爽爽 | 日日爽夜夜爽 | 亚洲综合在线五月天 | 国产一级黄| 日韩av影视在线 | 日韩女同一区二区三区在线观看 | 国产欧美精品xxxx另类 | 国产综合91| 国产精品永久久久久久久久久 | 日韩av电影免费在线观看 | 国产精久久 | 韩日精品中文字幕 | 日韩有码专区 | 久久五月天综合 | 亚洲精品美女在线 | 久久久国产精品成人免费 | 日韩av三区 | 亚洲黄色一级电影 | 91黄色免费看 | 日韩精品久久一区二区 | 日韩网| 欧美了一区在线观看 | 国产不卡片 | 精品国产a | 免费日韩 精品中文字幕视频在线 | 日日操日日操 | 亚洲一区二区三区精品在线观看 | 亚洲高清网站 | 日韩欧美国产激情在线播放 | 国产精品一区二区三区四区在线观看 | 97视频免费看 | 国产精品久久久久久久久久免费看 | 美女国内精品自产拍在线播放 | 911精品视频 | 亚洲成人黄色网址 | 天天射狠狠干 | 激情婷婷av | 香蕉久草 | 亚洲在线免费视频 | 久久久久久蜜av免费网站 | av片在线观看免费 | 久草久热 | 亚洲精品国产精品99久久 | 午夜精品一区二区三区视频免费看 | 日韩av免费观看网站 | 国产精品高清一区二区三区 | 看毛片的网址 | 日韩av免费观看网站 | 日本在线观看一区二区三区 | 色诱亚洲精品久久久久久 | 91亚洲欧美激情 | 中文字幕精品三级久久久 | 91视频免费观看 | 爱爱av网| 国产成人一区二区啪在线观看 | 狠狠网站 | 久综合网 | 色中文字幕在线观看 | 99久久精品免费视频 | 久久国产精品一二三区 | 国产又粗又猛又色又黄视频 | 福利一区二区三区四区 | 久久久久久久99 | 亚洲欧美日本国产 | 五月天久久久久 | 国产成人久久久久 | 久久精品视频网址 | 色资源网免费观看视频 | 国产精品精品视频 | 国产精品成人免费精品自在线观看 | 日韩免费视频线观看 | 婷婷久久国产 | 精品久久久99 | 天堂网在线视频 | 激情综合色综合久久 | 日韩精品中文字幕在线 | 久久婷婷精品 | 国产一区 在线播放 | 欧美精品被| 欧美一级久久 | 操操操操网 | 精品国产视频一区 | 免费av小说 | 热久久影视 | 精品欧美一区二区在线观看 | 久久av一区二区三区亚洲 | 精品视频在线观看 | 色综合色综合久久综合频道88 | 丁香五月亚洲综合在线 | 国产精品一区二区白浆 | 最新的av网站 | 国内视频在线 | 91传媒激情理伦片 | 国产999精品视频 | 日韩高清一 | 日日夜夜天天 | 99色在线视频 | 久久精品久久精品久久 | 视频在线99| 久久久久久麻豆 | 日日夜夜精品视频天天综合网 | 国产免费久久久久 | 午夜精品一区二区三区可下载 | 精品亚洲成人 | 午夜视频在线观看一区二区三区 | 四虎影视精品成人 | 午夜精品久久久久久99热明星 | 久久高清毛片 | 热re99久久精品国产66热 | 日韩在线观看网址 | 在线观看中文字幕一区 | 免费a v在线 | 黄色福利网站 | 在线观看香蕉视频 | 国产成人久久精品亚洲 | bbbb操bbbb| 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 操老逼免费视频 | 国产视频日韩视频欧美视频 | 久久久久久片 | 日本99干网 | 久久影院中文字幕 | 香蕉视频亚洲 | 欧美日韩在线网站 | 久久精品二区 | 天天激情天天干 | 欧美一级片免费 | 一区二区三区高清在线观看 | 国产色在线观看 | 国产精品久久久久久久久免费看 | 最近中文字幕高清字幕在线视频 | 欧美国产日韩一区二区三区 | 69视频国产 | 国产精品午夜久久久久久99热 | 人人擦 | 欧美日韩国产精品一区二区 | 天天干,天天射,天天操,天天摸 | 在线免费试看 | 国产精品99久久久久人中文网介绍 | 国产欧美精品一区二区三区四区 | 日韩专区在线 | 中文超碰字幕 | 精品一二区| 中文字幕乱视频 | 日本3级在线观看 | 亚洲视频播放 | 久久草网 | 日韩三级在线观看 | 亚洲 欧美 变态 国产 另类 | 色夜视频 | 久久精品一区二区三区四区 | 天天操天 | 91视频啊啊啊 | 亚洲免费公开视频 | 97人人射| 中文字幕高清视频 | 婷婷深爱 | 久久看片| 91福利小视频 | 超碰人人在线 | 天天视频色 | 九色视频网址 | www91在线观看 | 欧美日韩二区三区 | 韩国精品福利一区二区三区 | 天堂资源在线观看视频 | 岛国av在线不卡 | 国模视频一区二区三区 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 91中文在线视频 | 草久在线播放 | 国产剧情亚洲 | 国产精品精品国产婷婷这里av | 91久久精品一区二区三区 | 在线天堂中文www视软件 | 中国一区二区视频 | 亚洲精品福利在线 | 免费在线国产 | 久久精品成人欧美大片古装 | 中文字幕 国产专区 | 人人澡澡人人 | 国产在线国偷精品产拍免费yy | 18久久久| 久久99亚洲网美利坚合众国 | 天天艹天天爽 | 欧美日韩大片在线观看 | 在线观看日韩视频 | 亚洲精品高清在线 | 国产精品美女免费视频 | 色婷婷国产精品 | 色av男人的天堂免费在线 | 日韩黄视频 | 五月婷婷av在线 | 国产在线看一区 | 免费av网站在线看 | 99视频在线免费观看 | 免费看黄的 | www99精品 | 欧洲精品视频一区 | 美女免费黄视频网站 | 国产日韩在线播放 | 久久精品日产第一区二区三区乱码 | 久草在线费播放视频 | 亚洲专区路线二 | 91看片网址 | 狠狠狠色丁香婷婷综合久久五月 | 国产成人三级在线 | 婷婷.com| 奇米7777狠狠狠琪琪视频 | 夜夜操狠狠干 | 亚洲成色 | 韩日色视频 | 97人人网 | 国产成人一区三区 | 一区二区三区四区在线 | 日韩视频一区二区在线 | 欧美一区二区三区四区夜夜大片 | 欧美日韩91| 综合久久久久久 | www.av小说| 99欧美视频 | 午夜久久视频 | 欧美亚洲成人xxx | 国产精品不卡视频 | 亚洲日本中文字幕在线观看 | 96精品视频 | 国产高清视频在线免费观看 | 久久男人中文字幕资源站 | 亚洲女在线| 久久婷婷一区 | 婷婷久久网 | 热久久国产 | 又黄又爽免费视频 | 国产精品免费久久 | 午夜精品电影 | 国产原创av片 | 96亚洲精品久久久蜜桃 | 天堂在线v | 在线91视频| 亚洲视频高清 | 成人免费在线观看电影 | 五月色丁香| 久久久久福利视频 | av在线一二三区 | 国产电影黄色av | 黄色av大片 | 欧美韩日精品 | 美女天天操 | 国产精品成人一区二区三区吃奶 | 九九免费在线观看视频 | 在线观看涩涩 | 九九久久久久久久久激情 | 草久视频在线观看 | 亚洲综合在线播放 | 亚洲精品网站在线 | 国产高清不卡 | 日韩艹 | 天天干天天射天天插 | 81精品国产乱码久久久久久 | 色综合久久久久综合体桃花网 | 好看av在线| 日韩av一区二区三区四区 | 超级碰视频 | 在线观看视频免费播放 | 国产一级高清视频 | 91麻豆传媒 | 日韩中文字幕一区 | 激情www | 免费久久网 | 亚洲欧美成人 | 狠狠成人 | 天天干人人 | 久久久精品网站 | 久久久久国产一区二区三区 | 91麻豆精品国产午夜天堂 | 中文字幕久久精品一区 | 欧美 亚洲 另类 激情 另类 | www成人av| 日韩成人精品在线观看 | 免费观看第二部31集 | 久久精品三级 | 日韩动漫免费观看高清完整版在线观看 | 欧美日韩色婷婷 | 美女视频黄免费的久久 | 亚洲成年片| 免费国产ww| 91丝袜美腿 | 欧美综合国产 | 国产精品毛片一区 | 三级在线视频播放 | 日日夜夜天天综合 | 日日精品 | 中文字幕4 | 欧美日本不卡高清 | 日韩理论在线观看 | 免费在线一区二区 | 国产成人精品在线 | 久久99国产精品免费网站 | 国产一级大片在线观看 | 青青草久草在线 | 91精品在线免费视频 | 最近日本中文字幕 | 99久久婷婷国产精品综合 | 中文字幕亚洲高清 | 五月婷婷综合在线视频 | 一级久久久 | 成人午夜久久 | 精品国产伦一区二区三区观看体验 | 国产亚洲精品久久久久久大师 | 色在线视频 | 成人在线你懂得 | 国产免费黄视频在线观看 | 国产精品久久久久久a | 欧美一级视频免费看 | 91麻豆国产福利在线观看 | 五月天亚洲综合 | 91精品国产91 | 爱爱av网站 | 午夜影院一级片 | 久久久久免费精品视频 | 特级黄色视频毛片 | 婷婷激情欧美 | 国产精品99视频 | 日本大尺码专区mv | 在线视频 影院 | 国产裸体视频网站 | 四虎伊人 | 一区二区三区日韩精品 | 亚洲精品美女免费 | 日韩午夜电影网 | 国产美女视频 | 久久黄色免费 | 婷婷久久网 | 天天干,天天射,天天操,天天摸 | 麻豆视频免费在线播放 | 亚洲精品视频在 | 日本在线精品视频 | 久久久久久久久久免费视频 | www久久| 国产精品网站一区二区三区 | 亚洲精品午夜国产va久久成人 | 97成人资源站| 国产在线观看av | 国产黄色免费 | 国产精品久久久久久久毛片 | 亚洲最大在线视频 | 天天色天天射综合网 | 伊人久久一区 | 免费黄色激情视频 | 国产精品免费观看网站 | 欧美一级免费 | 韩国av三级 | 久久精品3| 中国美女一级看片 | 国产精品18久久久久久久久 | 免费欧美高清视频 | 日韩激情中文字幕 | 日韩免费视频 | 97国产在线视频 | 亚洲成人av在线电影 | 国产精品毛片一区视频 | 成人网看片 | 国产精品一区二区吃奶在线观看 | 久久九九影院 | 国产韩国日本高清视频 | 亚洲狠狠婷婷综合久久久 | 欧美国产高清 | 99在线精品观看 | 91手机视频在线 | 99综合视频 | 成人av高清在线 | 国产精品欧美一区二区三区不卡 | 2022中文字幕在线观看 | 99热免费在线 | www视频在线播放 | 极品美女被弄高潮视频网站 | 激情综合网五月 | 午夜av在线播放 | 中文字幕丝袜美腿 | 国产精品一区二区三区久久 | 九色视频网站 | 亚洲乱码精品久久久 | 中文不卡视频在线 | 免费不卡中文字幕视频 | 99视频一区 | 黄色日本免费 | 日韩欧美在线影院 | 天天射天天舔天天干 | 国产精品久久久久久久久软件 | 日韩在线播放视频 | 日韩精品你懂的 | 精品久久久久久久 | 成人午夜电影免费在线观看 | 看片网站黄 | 黄色在线观看网站 | 丁香婷婷激情啪啪 | 日韩精品三区四区 | 黄色片网站av | 蜜臀精品久久久久久蜜臀 | 久久国产精品99久久久久久丝袜 | 精品99999| 天天舔天天射天天操 | 国产精品视频最多的网站 | 夜添久久精品亚洲国产精品 | 国产小视频91 | 91麻豆精品国产91久久久使用方法 | 97看片网| 精品久久国产一区 | 丁香激情网 | 黄色大全免费网站 | 日本精品视频网站 | 99久在线精品99re8热视频 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 国产中文字幕在线 | 五月婷婷六月丁香激情 | 在线视频在线观看 | 午夜精品视频免费在线观看 | 日本黄色a级大片 | 最近日本韩国中文字幕 | 日韩免费观看高清 | 最近日韩中文字幕中文 | 免费黄色在线网站 | 国产a视频免费观看 | 久久超碰在线 | 黄色特级片 | 久久在线| 人人爱人人做人人爽 | 日日爽天天爽 | 色网站在线免费观看 | 91精彩在线视频 | av解说在线观看 | 韩国中文三级 | 久久精品这里都是精品 | 2019天天干夜夜操 | 欧美在线一二 | 黄色电影在线免费观看 | 日韩视频免费观看高清完整版在线 | 一本一本久久a久久精品综合妖精 | 夜夜天天干 | 国产高清中文字幕 | 成 人 免费 黄 色 视频 | 亚洲黄色在线播放 | 黄色免费av | 欧美日韩高清在线观看 | www.久久久 | 欧美一区二区三区四区夜夜大片 | 午夜天使 | 亚洲永久精品一区 | 久久xx视频 | 久久国产色 | 日韩视频免费观看高清完整版在线 | 狠狠躁夜夜躁人人爽视频 | 激情久久伊人 | 国产视频精选 | 99精品福利 | 日韩激情视频 | 天天色天天操天天爽 | a黄色影院 | 91九色最新 | 亚洲午夜精| 日韩欧美精品一区二区 | 国产麻豆视频网站 | 国产露脸91国语对白 | 日韩av不卡播放 | 国产香蕉97碰碰久久人人 | 免费影视大全推荐 | 久久久久久久久亚洲精品 | 91av视频网 | 日日夜夜天天久久 | 国产精品mv在线观看 | 免费色黄| 黄色国产高清 | 国产高清中文字幕 | 中文字幕日韩有码 | 久久理论电影网 | 日韩一区二区免费视频 | 在线视频免费观看 | 在线观看深夜视频 | 在线精品视频在线观看高清 | 麻豆影视网站 | 99久久婷婷国产 | 伊人成人激情 | 视频国产在线观看18 | av成人动漫在线观看 | 国内精品久久久久影院一蜜桃 | 天堂中文在线播放 | 国产精品理论片在线播放 | 五月婷婷六月丁香在线观看 | 久久电影中文字幕视频 | 久草久草在线 | 中文国产字幕在线观看 | 丁香激情婷婷 | 五月婷婷免费 | 久久久久久久久久久久亚洲 | 激情五月婷婷激情 | 五月婷婷影院 | 国产中文字幕一区二区 | 中文字幕免费 | 免费看的毛片 | 五月天激情开心 | 成人资源在线播放 | 人人cao| 999电影免费在线观看2020 | 日韩网站在线看片你懂的 | 五月婷婷综合在线观看 | 欧洲精品视频一区二区 | 色综合欧洲| 99视频精品全部免费 在线 | 亚洲日日日 | 久久精品欧美一区二区三区麻豆 | 久久综合久色欧美综合狠狠 | 91视频麻豆视频 | 久草在线精品观看 | 日韩大片在线播放 | 五月花丁香婷婷 | 久久天天躁狠狠躁亚洲综合公司 | 久久亚洲私人国产精品va | 色婷婷av一区二 | 天天在线免费视频 | 久久a免费视频 | 日韩影片在线观看 | 欧美亚洲一区二区在线 | 黄色成人在线 | 欧美日韩另类在线观看 | 国产成人一区二区三区 | 精品视频在线播放 | 五月天久久 | 天天摸天天操天天舔 | 99精品免费在线观看 | 国产黄色精品在线 | 69精品人人人人 | 97av视频| 成人在线免费小视频 | 国产黄色精品在线观看 | 在线电影91 | 在线一级片 | 黄色成人小视频 | 国产精品亚洲综合久久 | 久久久久久久综合色一本 | 丁香狠狠 | 天天操天天吃 | 日韩在线视频观看免费 | 久久精品视频在线观看 | 亚洲最新毛片 | 超碰在线日本 | 国精产品满18岁在线 | 久久99热精品这里久久精品 | 精品国产_亚洲人成在线 | 久久久av电影| 亚洲国产成人高清精品 | 欧美最猛性xxxxx免费 | 国产免费不卡 | 夜夜嗨av色一区二区不卡 | 亚洲精品乱码久久久久久 | 不卡的av电影在线观看 | 日韩在线视频播放 | 国产亚洲欧美日韩高清 | 99视频免费看 | 91av电影| 国产精品国产精品 | 欧美色黄 | 婷婷久久综合九色综合 | 中文在线a在线 | 日韩中文字幕在线观看 | 亚洲精品成人av在线 | 美女视频黄色免费 | 91精品视频在线观看免费 | 最近中文字幕国语免费高清6 | 国内精品久久久久久久 | 一级全黄毛片 | 精品久久久久久亚洲综合网 | 99精品在线观看 | www.国产在线视频 | 黄色福利视频网站 | 中文字幕资源网 国产 | 成人一区二区在线观看 | 狠狠干中文字幕 | 久久综合狠狠狠色97 | 久久理论电影 | 亚洲一区视频在线播放 | 日韩v在线| 日韩av成人 | 久草com | 国产成人av网站 | 免费黄色激情视频 | 午夜电影av | 在线观看免费高清视频大全追剧 | 99re在线视频观看 | 久久精品视频免费观看 | 日韩精品视频免费在线观看 | 亚洲黄在线观看 | 九九热只有精品 | 国产精品麻豆一区二区三区 | 91探花在线| 四虎成人免费影院 | 国产色视频网站 | 日日干天天射 | 日本中文在线 | 国产精品女教师 | 国产原创av片 | 中文字幕一区二区三区在线视频 | 国产一区二区影院 | 精品国产激情 | 成人性生交大片免费观看网站 | 欧美日韩国产伦理 | 成人在线免费视频观看 | 中文字幕一区av | 日韩免费观看一区二区 | 久久久久久免费毛片精品 | 国产精品美女免费看 | 日本色小说视频 | 99九九99九九九视频精品 | 成人国产在线 | 美州a亚洲一视本频v色道 | 久草国产在线观看 | 亚洲精品在线网站 | av观看网站| 韩国三级在线一区 | 国产精品美乳一区二区免费 | 欧美色噜噜 | 曰韩在线 | 91丨九色丨国产丨porny精品 | 国产九九精品视频 | 黄色网址a | 美女黄频 | 狠狠狠色丁香婷婷综合久久五月 | 亚洲日本韩国一区二区 | 区一区二在线 | 天天天天干| 在线免费av观看 | 国产高清av在线播放 | 亚洲三区在线 | 久草视频在线新免费 | 九九视频精品在线 | 国产99精品在线观看 | 天天艹天天爽 | 91一区在线观看 | 天天综合网天天综合色 | 国产成人一区二区啪在线观看 | 久久成人国产精品一区二区 | 欧美尹人 | 91精品一区二区三区久久久久久 | 国产韩国日本高清视频 | 一级黄色在线免费观看 | 中文字幕免费不卡视频 | 欧美日韩精 | 日韩电影中文字幕 | 久久免费视频5 | 日韩精品第一区 | 丁香在线 | 中文字幕色站 | 热99久久精品 | 久久久久久草 | 国产高h视频 | 日日干夜夜骑 | 91av在线精品 | 黄色www| 九草视频在线观看 | 欧美一级免费 | 黄色大全免费网站 | 69国产盗摄一区二区三区五区 | av大全免费在线观看 | 国产一级视屏 | 成年人在线播放视频 | 不卡在线一区 | 日韩在线视频免费观看 | 日韩国产欧美在线播放 | 91资源在线观看 | 欧美久草在线 | 中文字幕日韩电影 | 日本精品一区二区三区在线播放视频 | 国产免费不卡 | 亚洲精品视频在线播放 | 成人在线播放av | 国产精品自产拍在线观看蜜 | 欧美日韩高清一区二区 国产亚洲免费看 | 国色天香av| 久久不射电影院 | 国产精品网站一区二区三区 | 日韩电影在线一区 | 亚洲爱视频 | 久久久久免费视频 | 可以免费观看的av片 | 国产 亚洲 欧美 在线 | 久久久久久久久久久久国产精品 | 999久久久免费精品国产 | 久久精品欧美一区 | 色姑娘综合天天 | 绯色av一区 | 综合黄色网 | 久久久久99精品成人片三人毛片 | 91天天视频 | 国产资源精品在线观看 | 久久一区二区三区日韩 | 国产精品一区二区三区免费看 | 91在线观看视频 | 国产精品久久久久久久久久白浆 | 国产精品短视频 | 亚洲精品99 | 在线小视频你懂的 | 天天天天色综合 | 99精品国产视频 | 国产成人精品一区一区一区 | 亚洲成人黄色在线 | 国产在线精品一区二区 | 中文字幕a在线 | 久久精品96 | 国产精品毛片久久久久久久久久99999999 | 久久精品视频在线观看免费 | 欧美激情视频免费看 | 国产精品高清在线观看 | 1区2区视频 | 蜜桃av久久久亚洲精品 | 免费黄色网止 | 激情婷婷在线观看 | av丁香花| 色婷婷精品大在线视频 | 欧美在线一二 | 成人av在线直播 | 中文字幕在线观看完整版 | 香蕉视频导航 | 国产精品在线看 | 国产精品一区二区中文字幕 | 国产美女黄网站免费 | 国产成人免费观看久久久 | 天天操天天操天天爽 | 日本久久久精品视频 | 69精品视频在线观看 |