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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

方法 手写promise_JS探索-手写Promise

發布時間:2024/9/27 javascript 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 方法 手写promise_JS探索-手写Promise 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

無意間在知乎上刷到Monad這個概念,去了解了一下,前端的Promise就是一種Monad模式,所以試著學習一下手寫一個Promise.

本文內容主要參考于

只會用?一起來手寫一個合乎規范的Promise?www.jianshu.com

Promise是什么

所謂Promise,簡單說就是一個容器,里面保存著某個未來才會結束的事件(通常是一個異步操作)的結果。從語法上說,Promise 是一個對象,從它可以獲取異步操作的消息。Promise 提供統一的 API,各種異步操作都可以用同樣的方法進行處理。

Promise是處理異步編碼的一個解決方案,在Promise出現以前,異步代碼的編寫都是通過回調函數來處理的,回調函數本身沒有任何問題,只是當多次異步回調有邏輯關系時就會變得復雜:

const fs = require('fs'); fs.readFile('1.txt', (err,data) => {fs.readFile('2.txt', (err,data) => {fs.readFile('3.txt', (err,data) => {//可能還有后續代碼});}); });

上面讀取了3個文件,它們是層層遞進的關系,可以看到多個異步代碼套在一起不是縱向發展的,而是橫向,不論是從語法上還是從排錯上都不好,于是Promise的出現可以解決這一痛點。
上述代碼如果改寫成Promise版是這樣:

const util = require('util'); const fs = require('fs'); const readFile = util.promisify(fs.readFile);readFile('1.txt').then(data => {return readFile('2.txt');}).then(data => {return readFile('3.txt');}).then(data => {//...});

可以看到,代碼是從上至下縱向發展了,更加符合人們的邏輯。

下面手寫一個Promise,按照Promises/A+規范,可以參照規范原文:

Promises/A+?promisesaplus.com

手寫實現Promise是一道前端經典的面試題,比如美團的面試就是必考題,Promise的邏輯還是比較復雜的,考慮的邏輯也比較多,下面總結手寫Promise的關鍵點,和怎樣使用代碼來實現它。

Promise代碼基本結構

實例化Promise對象時傳入一個函數作為執行器,有兩個參數(resolve和reject)分別將結果變為成功態和失敗態。我們可以寫出基本結構

function Promise(executor) {this.state = 'pending'; //狀態this.value = undefined; //成功結果this.reason = undefined; //失敗原因function resolve(value) {}function reject(reason) {} }module.exports = Promise;

其中state屬性保存了Promise對象的狀態,規范中指明,一個Promise對象只有三種狀態:等待態(pending)成功態(resolved)和失敗態(rejected)。
當一個Promise對象執行成功了要有一個結果,它使用value屬性保存;也有可能由于某種原因失敗了,這個失敗原因放在reason屬性中保存。

then方法定義在原型上

每一個Promise實例都有一個then方法,它用來處理異步返回的結果,它是定義在原型上的方法,我們先寫一個空方法做好準備:

Promise.prototype.then = function (onFulfilled, onRejected) { };

當實例化Promise時會立即執行

當我們自己實例化一個Promise時,其執行器函數(executor)會立即執行,這是一定的:

let p = new Promise((resolve, reject) => {console.log('執行了'); }); //運行結果:執行了

因此,當實例化Promise時,構造函數中就要馬上調用傳入的executor函數執行

function Promise(executor) {var _this = this;this.state = 'pending';this.value = undefined;this.reason = undefined;executor(resolve, reject); //馬上執行function resolve(value) {}function reject(reason) {} }

已經是成功態或是失敗態不可再更新狀態

規范中規定,當Promise對象已經由pending狀態改變為了成功態(resolved)或是失敗態(rejected)就不能再次更改狀態了。因此我們在更新狀態時要判斷,如果當前狀態是pending(等待態)才可更新:

function resolve(value) {//當狀態為pending時再做更新if (_this.state === 'pending') {_this.value = value;//保存成功結果_this.state = 'resolved';}}function reject(reason) {//當狀態為pending時再做更新if (_this.state === 'pending') {_this.reason = reason;//保存失敗原因_this.state = 'rejected';}}

以上可以看到,在resolve和reject函數中分別加入了判斷,只有當前狀態是pending才可進行操作,同時將成功的結果和失敗的原因都保存到對應的屬性上。之后將state屬性置為更新后的狀態。

then方法的基本實現

當Promise的狀態發生了改變,不論是成功或是失敗都會調用then方法,所以,then方法的實現也很簡單,根據state狀態來調用不同的回調函數即可:

Promise.prototype.then = function (onFulfilled, onRejected) {if (this.state === 'resolved') {//判斷參數類型,是函數執行之if (typeof onFulfilled === 'function') {onFulfilled(this.value);}}if (this.state === 'rejected') {if (typeof onRejected === 'function') {onRejected(this.reason);}} };

需要一點注意,規范中說明了,onFulfilled 和 onRejected 都是可選參數,也就是說可以傳也可以不傳。傳入的回調函數也不是一個函數類型,那怎么辦?規范中說忽略它就好了。因此需要判斷一下回調函數的類型,如果明確是個函數再執行它。

讓Promise支持異步

代碼寫到這里似乎基本功能都實現了,可是還有一個很大的問題,目前此Promise還不支持異步代碼,如果Promise中封裝的是異步操作,then方法無能為力:

let p = new Promise((resolve, reject) => {setTimeout(() => {resolve(1);}, 500); });p.then(data => console.log(data)); //沒有任何結果

運行以上代碼發現沒有任何結果,本意是等500毫秒后執行then方法,哪里有問題呢?原因是setTimeout函數使得resolve是異步執行的,有延遲,當調用then方法的時候,此時此刻的狀態還是等待態(pending),因此then方法即沒有調用onFulfilled也沒有調用onRejected。
這個問題如何解決?我們可以參照發布訂閱模式,在執行then方法時如果還在等待態(pending),就把回調函數臨時寄存到一個數組里,當狀態發生改變時依次從數組中取出執行就好了,清楚這個思路我們實現它,首先在類上新增兩個Array類型的數組,用于存放回調函數:

function Promise(executor) {var _this = this;this.state = 'pending';this.value = undefined;this.reason = undefined;this.onFulfilledFunc = [];//保存成功回調this.onRejectedFunc = [];//保存失敗回調//其它代碼略... }

這樣當then方法執行時,若狀態還在等待態(pending),將回調函數依次放入數組中:

Promise.prototype.then = function (onFulfilled, onRejected) {//等待態,此時異步代碼還沒有走完if (this.state === 'pending') {if (typeof onFulfilled === 'function') {this.onFulfilledFunc.push(onFulfilled);//保存回調}if (typeof onRejected === 'function') {this.onRejectedFunc.push(onRejected);//保存回調}}//其它代碼略... };

寄存好了回調,接下來就是當狀態改變時執行就好了:

function resolve(value) {if (_this.state === 'pending') {_this.value = value;//依次執行成功回調_this.onFulfilledFunc.forEach(fn => fn(value));_this.state = 'resolved';}}function reject(reason) {if (_this.state === 'pending') {_this.reason = reason;//依次執行失敗回調_this.onRejectedFunc.forEach(fn => fn(reason));_this.state = 'rejected';}}

至此,Promise已經支持了異步操作,setTimeout延遲后也可正確執行then方法返回結果。

鏈式調用

Promise處理異步代碼最強大的地方就是支持鏈式調用,這塊也是最復雜的,我們先梳理一下規范中是怎么定義的:

  • 每個then方法都返回一個新的Promise對象(原理的核心)
  • 如果then方法中顯示地返回了一個Promise對象就以此對象為準,返回它的結果
  • 如果then方法中返回的是一個普通值(如Number、String等)就使用此值包裝成一個新的Promise對象返回。
  • 如果then方法中沒有return語句,就視為返回一個用Undefined包裝的Promise對象
  • 若then方法中出現異常,則調用失敗態方法(reject)跳轉到下一個then的onRejected
  • 如果then方法沒有傳入任何回調,則繼續向下傳遞(值的傳遞特性)。
  • 規范中說的很抽像,我們可以把不好理解的點使用代碼演示一下。
    其中第3項,如果返回是個普通值就使用它包裝成Promise,我們用代碼來演示:

    let p =new Promise((resolve,reject)=>{resolve(1); });p.then(data=>{return 2; //返回一個普通值 }).then(data=>{console.log(data); //輸出2 });

    可見,當then返回了一個普通的值時,下一個then的成功態回調中即可取到上一個then的返回結果,說明了上一個then正是使用2來包裝成的Promise,這符合規范中說的。
    第4項,如果then方法中沒有return語句,就視為返回一個用Undefined包裝的Promise對象

    let p = new Promise((resolve, reject) => {resolve(1); });p.then(data => {//沒有return語句 }).then(data => {console.log(data); //undefined });

    可以看到,當沒有返回任何值時不會報錯,沒有任何語句時實際上就是return undefined;即將undefined包裝成Promise對象傳給下一個then的成功態。
    第6項,如果then方法沒有傳入任何回調,則繼續向下傳遞,這是什么意思呢?這就是Promise中值的穿透,還是用代碼演示一下:

    let p = new Promise((resolve, reject) => {resolve(1); });p.then(data => 2) .then() .then() .then(data => {console.log(data); //2 });

    以上代碼,在第一個then方法之后連續調用了兩個空的then方法 ,沒有傳入任何回調函數,也沒有返回值,此時Promise會將值一值向下傳遞,直到你接收處理它,這就是所謂的值的穿透。
    現在可以明白鏈式調用的原理,不論是何種情況then方法都會返回一個Promise對象,這樣才會有下個then方法。
    搞清楚了這些點,我們就可以動手實現then方法的鏈式調用,一起來完善它:

    Promise.prototype.then = function (onFulfilled, onRejected) {var promise2 = new Promise((resolve, reject) => {//代碼略...})return promise2; };

    首先,不論何種情況then都返回Promise對象,我們就實例化一個新promise2并返回。
    接下來就處理根據上一個then方法的返回值來生成新Promise對象,由于這塊邏輯較復雜且有很多處調用,我們抽離出一個方法來操作,這也是規范中說明的:

    /*** 解析then返回值與新Promise對象* @param {Object} promise2 新的Promise對象 * @param {*} x 上一個then的返回值* @param {Function} resolve promise2的resolve* @param {Function} reject promise2的reject*/ function resolvePromise(promise2, x, resolve, reject) {//... }

    resolvePromise方法用來封裝鏈式調用產生的結果,下面我們分別一個個情況的寫出它的邏輯,首先規范中說明,如果promise2和 x 指向同一對象,就使用TypeError作為原因轉為失敗。原文如下:

    If promise and x refer to the same object, reject promise with a TypeError as the reason.

    這是什么意思?其實就是循環引用,當then的返回值與新生成的Promise對象為同一個(引用地址相同),則會拋出TypeError錯誤:

    let promise2 = p.then(data => {return promise2; });

    運行結果:

    TypeError: Chaining cycle detected for promise #<Promise>

    很顯然,如果返回了自己的Promise對象,狀態永遠為等待態(pending),再也無法成為resolved或是rejected,程序會死掉,因此首先要處理它:

    function resolvePromise(promise2, x, resolve, reject) {if (promise2 === x) {reject(new TypeError('Promise發生了循環引用'));} }

    接下來就是分各種情況處理。當x就是一個Promise,那么就執行它,成功即成功,失敗即失敗。若x是一個對象或是函數,再進一步處理它,否則就是一個普通值:

    function resolvePromise(promise2, x, resolve, reject) {if (promise2 === x) {reject(new TypeError('Promise發生了循環引用'));}if (x !== null && (typeof x === 'object' || typeof x === 'function')) {//可能是個對象或是函數} else {//否則是個普通值resolve(x);} }

    此時規范中說明,若是個對象,則嘗試將對象上的then方法取出來,此時如果報錯,那就將promise2轉為失敗態。原文:

    If retrieving the property x.then results in a thrown exception e, reject promise with e as the reason. //代碼略...if (x !== null && (typeof x === 'object' || typeof x === 'function')) {//可能是個對象或是函數try {let then = x.then;//取出then方法引用} catch (e) {reject(e);}} else {//否則是個普通值resolve(x);} }

    多說幾句,為什么取對象上的屬性有報錯的可能?Promise有很多實現(bluebird,Q等),Promises/A+只是一個規范,大家都按此規范來實現Promise才有可能通用,因此所有出錯的可能都要考慮到,假設另一個人實現的Promise對象使用Object.defineProperty()惡意的在取值時拋錯,我們可以防止代碼出現Bug。
    此時,如果對象中有then,且then是函數類型,就可以認為是一個Promise對象,之后,使用x作為this來調用then方法。

    //其他代碼略... if (x !== null && (typeof x === 'object' || typeof x === 'function')) {//可能是個對象或是函數try {let then = x.then; if (typeof then === 'function') {//then是function,那么執行Promisethen.call(x, (y) => {resolve(y);}, (r) => {reject(r);});} else {resolve(x);}} catch (e) {reject(e);}} else {//否則是個普通值resolve(x); }

    這樣鏈式寫法就基本完成了。但是還有一種極端的情況,如果Promise對象轉為成功態或是失敗時傳入的還是一個Promise對象,此時應該繼續執行,直到最后的Promise執行完。

    p.then(data => {return new Promise((resolve,reject)=>{//resolve傳入的還是Promiseresolve(new Promise((resolve,reject)=>{resolve(2);}));}); })

    此時就要使用遞歸操作了

    很簡單,把調用resolve改寫成遞歸執行resolvePromise方法即可,這樣直到解析Promise成一個普通值才會終止,即完成此規范:

    //其他代碼略... if (x !== null && (typeof x === 'object' || typeof x === 'function')) {//可能是個對象或是函數try {let then = x.then; if (typeof then === 'function') {let y = then.call(x, (y) => {//遞歸調用,傳入y若是Promise對象,繼續循環resolvePromise(promise2, y, resolve, reject);}, (r) => {reject(r);});} else {resolve(x);}} catch (e) {reject(e);}} else {//是個普通值,最終結束遞歸resolve(x); }

    到此,鏈式調用的代碼已全部完畢。在相應的地方調用resolvePromise方法即可。

    最后的最后

    其實,寫到此處Promise的真正源碼已經寫完了,但是距離100分還差一分,是什么呢?

    規范中說明,Promise的then方法是異步執行的。

    ES6的原生Promise對象已經實現了這一點,但是我們自己的代碼是同步執行,不相信可以試一下,那么如何將同步代碼變成異步執行呢?可以使用setTimeout函數來模擬一下:

    setTimeout(()=>{//此入的代碼會異步執行 },0);

    利用此技巧,將代碼then執行處的所有地方使用setTimeout變為異步即可,舉個栗子:

    setTimeout(() => {try {let x = onFulfilled(value);resolvePromise(promise2, x, resolve, reject);} catch (e) {reject(e);} },0);

    好了,現在已經是滿分的Promise源碼了。

    附上完整代碼

    function Promise(executor) { let self = this this.status = 'pending' //當前狀態 this.value = undefined //存儲成功的值 this.reason = undefined //存儲失敗的原因 this.onResolvedCallbacks = []//存儲成功的回調 this.onRejectedCallbacks = []//存儲失敗的回調 function resolve(value) {if (self.status == 'pending') {self.status = 'resolved'self.value = valueself.onResolvedCallbacks.forEach(fn => fn());} } function reject(error) {if (self.status == 'pending') {self.status = 'rejected'self.reason = errorself.onRejectedCallbacks.forEach(fn => fn())} } try {executor(resolve, reject) } catch (error) {reject(error) } } Promise.prototype.then = function (infulfilled, inrejected) { let self = this let promise2 infulfilled = typeof infulfilled === 'function' ? infulfilled : function (val) {return val } inrejected = typeof inrejected === 'function' ? inrejected : function (err) {throw err } if (this.status == 'resolved') {promise2 = new Promise(function (resolve, reject) {//x可能是一個promise,也可能是個普通值setTimeout(function () {try {let x = infulfilled(self.value)resolvePromise(promise2, x, resolve, reject)} catch (err) {reject(err)}});}) } if (this.status == 'rejected') {promise2 = new Promise(function (resolve, reject) {//x可能是一個promise,也可能是個普通值setTimeout(function () {try {let x = inrejected(self.reason)resolvePromise(promise2, x, resolve, reject)} catch (err) {reject(err)}});}) } if (this.status == 'pending') {promise2 = new Promise(function (resolve, reject) {self.onResolvedCallbacks.push(function () {//x可能是一個promise,也可能是個普通值setTimeout(function () {try {let x = infulfilled(self.value)resolvePromise(promise2, x, resolve, reject)} catch (err) {reject(err)}});})self.onRejectedCallbacks.push(function () {//x可能是一個promise,也可能是個普通值setTimeout(function () {try {let x = inrejected(self.reason)resolvePromise(promise2, x, resolve, reject)} catch (err) {reject(err)}});})}) } return promise2 } function resolvePromise(p2, x, resolve, reject) { if (p2 === x && x != undefined) {reject(new TypeError('類型錯誤')) } //可能是promise,看下對象中是否有then方法,如果有~那就是個promise if (x !== null && (typeof x === 'object' || typeof x === 'function')) {try {//為了防止出現 {then:11}這種情況,需要判斷then是不是一個函數let then = x.thenif (typeof then === 'function') {then.call(x, function (y) {//y 可能還是一個promise,那就再去解析,知道返回一個普通值為止resolvePromise(p2, y, resolve, reject)}, function (err) {reject(err)})} else {//如果then不是function 那可能是對象或常量resolve(x)}} catch (e) {reject(e)} } else {//說明是一個普通值resolve(x) } }

    總結

    以上是生活随笔為你收集整理的方法 手写promise_JS探索-手写Promise的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    亚洲综合五月天 | 色干干 | 欧美精品中文在线免费观看 | 亚洲视频专区在线 | 婷婷 中文字幕 | 久久久久久久久艹 | 国产91亚洲精品 | 深爱激情综合 | 精品欧美在线视频 | 四虎永久精品在线 | 国产伦精品一区二区三区无广告 | 亚洲精品国内 | 久久国产精品99国产精 | 天天曰天天爽 | 99爱这里只有精品 | av一级片网站 | 婷婷久久亚洲 | 午夜在线资源 | 亚洲第一久久久 | 中文字幕美女免费在线 | 91精品在线免费观看 | 国产成人精品亚洲精品 | 丰满少妇高潮在线观看 | 黄色一及电影 | 久久精品日产第一区二区三区乱码 | 丁香在线| 免费网站观看www在线观看 | 91cn国产在线| 国产 成人 久久 | 国产又粗又硬又爽视频 | 天天操天天能 | 一区二区三区 亚洲 | 狠狠干干 | 色在线亚洲 | 欧美有色 | 日本一区二区高清不卡 | 亚洲国产精品一区二区尤物区 | 亚洲另类交 | 韩国av在线播放 | 中文字幕在线观看网址 | 狠狠干干 | 国产精品色婷婷视频 | 青青草在久久免费久久免费 | 婷婷六月天综合 | 国产一区二区播放 | 中文字幕在线观 | 在线a视频免费观看 | 色九九视频 | 成人免费视频在线观看 | 久久九九视频 | av先锋影音少妇 | 国产一区二区精品久久91 | 又黄又爽又色无遮挡免费 | 国产一级片网站 | 青青草久草在线 | 五月激情丁香图片 | 久久超碰免费 | 成人午夜在线观看 | 欧美韩日精品 | 欧美一级黄色网 | 97在线精品国自产拍中文 | 91豆花在线 | 香蕉久草 | 日韩欧美国产视频 | 国产一区国产精品 | 欧美一级大片在线观看 | 欧美另类高潮 | 国产二级视频 | 福利在线看片 | 亚洲在线视频播放 | 国产一区二区三区午夜 | 日本高清免费中文字幕 | 国产xxxxx在线观看 | 久久国产精品系列 | av网址最新 | 欧美精品三级 | 97免费在线观看 | 热久久电影 | 91香蕉嫩草| 国产精品久久久久久久久久三级 | 00av视频 | 亚洲波多野结衣 | 亚洲第一中文字幕 | 免费高清国产 | 日本三级在线观看中文字 | 91精品在线播放 | 亚洲精品乱码久久 | 亚洲va韩国va欧美va精四季 | 最新国产精品久久精品 | www.天天射 | 亚洲成av | 国产成视频在线观看 | 亚洲国产成人精品在线 | 久久免费视频在线观看30 | 国产一级免费在线观看 | 久久国产精品久久w女人spa | 国产精品麻豆果冻传媒在线播放 | 午夜视频在线网站 | 久草免费新视频 | 欧美精品一区在线 | 免费 在线 中文 日本 | 性色av一区二区三区在线观看 | 国产精品99久久免费黑人 | 夜夜视频欧洲 | 久久国产精品影视 | 麻豆传媒视频在线播放 | 亚洲欧洲成人精品av97 | 国产精品手机看片 | 日韩电影精品 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 国产亚洲精品福利 | 精品国产电影一区二区 | 午夜性生活片 | 亚洲最大激情中文字幕 | 综合黄色网 | 香蕉一区 | 欧美一区二区三区在线播放 | a视频在线观看 | 久草在线免费资源站 | 黄色毛片视频免费观看中文 | 久热只有精品 | 天天狠狠操| 在线观看激情av | 久久久久日本精品一区二区三区 | 日日夜夜添 | 成年人电影免费在线观看 | 日本久久成人中文字幕电影 | 81精品国产乱码久久久久久 | 欧美精品国产综合久久 | 国产日韩欧美网站 | 9999国产精品| 国产精品一区二区三区四 | 五月婷婷六月丁香在线观看 | 99欧美 | 碰超在线观看 | 国产日女人 | 国产一级二级在线播放 | 天天射天天干天天插 | 国产精品美女免费视频 | 人成电影网 | 久久观看 | 免费黄色在线 | 国产精品毛片久久久久久久久久99999999 | 九九视频在线观看视频6 | 精品视频中文字幕 | 久久久精品网站 | 在线免费观看黄网站 | 国产黄色免费在线观看 | 国产一级片观看 | 欧美色婷 | 成人国产一区二区 | 在线一二区 | 天堂在线成人 | 中文字幕888 | 久久精品国产第一区二区三区 | 欧美极品少妇xbxb性爽爽视频 | 91禁看片 | 国产黄网站在线观看 | 干 操 插| 亚洲精品乱码久久久久久久久久 | 国产在线精品国自产拍影院 | 国产一级视频在线 | 精品国产精品一区二区夜夜嗨 | 九九交易行官网 | 在线观看成人av | 国产视频精品在线 | 黄色毛片在线观看 | 超碰人人草 | 亚洲国产一区在线观看 | 久久影视精品 | 国产一区二区日本 | 国产成人黄色av | 中文字幕日本特黄aa毛片 | 日韩国产高清在线 | 91av网址| 在线看岛国av | 欧美亚洲精品在线观看 | 亚洲狠狠婷婷综合久久久 | 国产九九九视频 | 国产亚洲精品女人久久久久久 | 97国产电影 | 中文字幕丝袜一区二区 | 天天插天天狠天天透 | 99精品久久久久久久久久综合 | 欧美日韩综合在线 | 中文字幕在| 国产高清免费在线播放 | 免费日韩精品 | 亚洲日本韩国一区二区 | 久久美女电影 | 伊人久久av | 免费视频黄 | 97人人爽人人 | 日韩午夜在线观看 | 黄污视频网站大全 | 最新av电影网站 | 国产精品99久久久久久久久久久久 | 国产精品午夜久久久久久99热 | 91av社区 | 久操视频在线播放 | 青青河边草免费观看完整版高清 | 日日日爽爽爽 | 婷婷草| a v在线观看 | 91资源在线观看 | 97成人在线观看视频 | 97国产在线观看 | 欧美精品在线一区二区 | 国产精品成人免费 | 九九久久国产 | 国产精品免费麻豆入口 | 成人一级影视 | 国产视频二区三区 | a亚洲视频| 日韩欧美一区二区三区在线观看 | 成人免费一区二区三区在线观看 | 精品久久久精品 | 精品久久久久久一区二区里番 | 国产精品国内免费一区二区三区 | 精品国产乱码久久久久久1区二区 | 精品亚洲一区二区三区 | 人人草网站 | www天天干| 日韩在线观看中文字幕 | 91麻豆精品国产91久久久久 | 97在线免费| 涩涩色亚洲一区 | 黄污网 | 日韩在线播放欧美字幕 | 91桃色国产在线播放 | 国产三级精品三级在线观看 | 极品久久久久久久 | 不卡的av| 亚洲h在线播放在线观看h | 九月婷婷色 | 色多多视频在线 | 精品人人人人 | 亚洲精品在线免费观看视频 | 日韩高清国产精品 | 天天做天天射 | av在线免费观看不卡 | 亚洲无吗av | 丁香婷婷综合网 | 精品国产久 | 国产成年免费视频 | 亚洲精品美女 | 亚洲最大av在线播放 | 中文字幕 第二区 | 黄网站色| 在线观看视频一区二区三区 | 97超碰.com | 人人揉人人揉人人揉人人揉97 | 99视频这里只有 | 欧美超碰在线 | 天天舔天天搞 | 91av影视| 亚洲国产中文字幕在线观看 | 粉嫩av一区二区三区免费 | 五月天.com| 午夜国产福利视频 | 福利一区二区三区四区 | 国产精品免费久久久久影院仙踪林 | 91黄色在线视频 | 欧美日韩中文字幕在线视频 | 成人一区二区在线观看 | 精品在线视频播放 | 美女久久网站 | 久久婷婷五月综合色丁香 | 国产精品99在线观看 | 国产精品男女啪啪 | 中文字幕av在线 | 国产一级片一区二区三区 | 日批视频 | 日韩欧美v| 91精品在线播放 | 日日干夜夜骑 | 狠狠婷婷 | 亚洲区视频在线 | 国产香蕉久久精品综合网 | 欧美日韩裸体免费视频 | 午夜在线国产 | 91日韩免费 | 天天操导航 | 色婷婷电影网 | 国产一卡久久电影永久 | 国产精品一区二区三区电影 | 欧美99精品| 综合天天 | 久久精品爱视频 | 免费美女av| 91激情在线视频 | avav片| 人人爱人人添 | 国产视频中文字幕 | 在线观看一级视频 | 97视频在线观看视频免费视频 | 国产亚洲欧洲 | 西西www4444大胆在线 | 久久99这里只有精品 | 久久视频一区二区 | 免费福利视频网 | 亚洲精品动漫久久久久 | 香蕉久草 | 夜夜高潮夜夜爽国产伦精品 | 国产精品福利无圣光在线一区 | 五月天丁香视频 | 欧美一级片在线 | 四虎伊人 | 黄在线| 成人在线视频你懂的 | 草久久久久久 | 在线观看免费视频你懂的 | 日韩av网站在线播放 | 在线观看v片 | 久久黄网站 | av在线免费播放网站 | 新版资源中文在线观看 | 日本黄色免费在线 | 久久色视频 | 亚洲精品男人天堂 | 亚洲精品午夜视频 | 激情五月婷婷激情 | 日韩在线观看 | 亚州av网站 | 亚洲成熟女人毛片在线 | 久草国产视频 | 亚洲最大免费成人网 | 久草网在线 | 免费福利视频网站 | 久久这里有精品 | 国产一区二区免费 | 91精品国自产拍天天拍 | 97视频免费观看 | 日韩在线不卡视频 | 亚洲成人免费在线观看 | 开心色插 | 99久精品 | 国产视频手机在线 | 国产一区欧美一区 | 波多野结衣在线视频免费观看 | 色婷婷视频网 | 欧美a影视 | 视频一区二区三区视频 | 久久精品一区二区三区四区 | 亚洲精品福利在线观看 | 久久久久久久国产精品视频 | av观看久久久 | 99精品影视 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 欧美另类一二三四区 | 亚洲精品视频在线观看视频 | 久草视频在线资源站 | 色播五月激情五月 | 91久久丝袜国产露脸动漫 | 国产精品资源在线 | 国产亚洲情侣一区二区无 | 在线视频观看国产 | 亚洲成人av在线电影 | 97色狠狠 | 久久精品久久久精品美女 | 久久短视频 | 国产午夜在线观看 | 在线视频成人 | 色欧美88888久久久久久影院 | 99电影456麻豆 | 久久久免费看视频 | 91精品国产欧美一区二区 | 亚洲精品男女 | 中文字幕免费观看 | 亚洲第一中文网 | 久草在线费播放视频 | 色综合色综合久久综合频道88 | www.91国产 | 黄色大片日本 | 国产精品av在线免费观看 | 999成人国产 | 久久精品香蕉视频 | 色鬼综合网| 黄色成人小视频 | 在线免费精品视频 | 国产福利午夜 | 亚洲美女在线一区 | 成人在线电影观看 | 欧美精品在线视频 | 中文字幕婷婷 | 毛片a级片 | freejavvideo日本免费 | 一区中文字幕 | 麻豆一区在线观看 | 在线 你懂 | 日日碰狠狠添天天爽超碰97久久 | 亚洲成人av片在线观看 | 日韩电影在线观看一区二区 | 91精品啪 | 91免费高清视频 | 93久久精品日日躁夜夜躁欧美 | 欧美日韩国产一区二区在线观看 | 91伊人影院 | 日韩精品一区在线观看 | 亚洲高清资源 | 中文字幕免费一区二区 | 久久不射影院 | 国产精品毛片一区二区在线 | 91成人网在线观看 | av在线免费观看不卡 | 丁香花在线视频观看免费 | 亚洲精品动漫久久久久 | 全久久久久久久久久久电影 | 欧美日韩高清在线一区 | 成人国产精品入口 | 精品日韩在线一区 | 免费看黄的 | 黄色成人av| 国产午夜精品免费一区二区三区视频 | 午夜久久久久久久久久久 | 中国精品少妇 | 国产精品网址在线观看 | 丰满少妇在线观看网站 | 久久9999久久| 国产亚洲免费观看 | 1024手机在线看 | 亚洲国产精品久久久久久 | 中文字幕日韩一区二区三区不卡 | 91久久久久久国产精品 | 人人干网 | 五月激情姐姐 | 免费看污的网站 | 日本 在线 视频 中文 有码 | 欧美aa级| 日批视频国产 | 亚洲乱亚洲乱妇 | 国产大片黄色 | 在线观看中文字幕av | 在线a人v观看视频 | 国产精品 日韩 | 国产97碰免费视频 | 成人国产精品电影 | 97色婷婷人人爽人人 | 91精品视频免费在线观看 | 成人免费观看网站 | 最新99热 | 精品一区二区6 | 91精品网站| 亚洲国产成人精品电影在线观看 | 青青河边草免费直播 | 欧美一级免费在线 | 99在线视频精品 | 精品久久久久久久久久岛国gif | 一级成人免费 | av 在线观看 | 精品影院 | 久久精品国产精品亚洲 | 欧美激情精品一区 | 国产福利午夜 | 久久久鲁 | 亚洲成a人片在线观看网站口工 | 激情在线网 | 国产精品igao视频网网址 | 一区二区三区在线视频观看58 | 日韩av一区二区在线影视 | 97超碰人人模人人人爽人人爱 | 午夜影院一区 | 中文字幕影片免费在线观看 | 久久综合网色—综合色88 | 亚洲国产天堂av | 在线观看一| 在线观看香蕉视频 | 在线观看日韩中文字幕 | 国产一级在线观看视频 | 欧美日韩破处 | 中文字幕乱码在线播放 | 黄污网 | 精品久久国产精品 | 最新超碰在线 | 在线日韩中文字幕 | 成年人免费在线观看网站 | 久草资源在线 | 精品国产99国产精品 | 日本韩国欧美在线观看 | 麻豆一区在线观看 | 91九色精品国产 | 天天爽天天射 | 免费久久网站 | 久久国产一区二区三区 | 91精品中文字幕 | 国产亚洲精品美女 | 成年人在线看视频 | av免费电影在线观看 | 月下香电影 | 成人国产网站 | 人人爽人人插 | 国产一区在线精品 | 国产黄色片一级三级 | 色在线网站| 色天天天 | 91久久一区二区 | 伊人电影在线观看 | 天堂va在线高清一区 | 中文字幕亚洲欧美日韩 | 激情自拍av | 四虎在线免费观看 | 香蕉91视频 | 日韩二区精品 | 久久影视一区二区 | 在线观看免费av网 | 国产精品久久99综合免费观看尤物 | 午夜av色| 视频国产精品 | 五月婷婷激情综合网 | 91麻豆网 | 日韩在线观看视频免费 | 免费在线观看91 | 成人av网页| 国产精品免费久久久久 | 色婷婷天天干 | 成人黄色资源 | 久久国产免费看 | 看黄色91 | 国产精品9999 | 天天操夜| 五月天丁香亚洲 | 国产精品久久av | 免费在线看成人av | 四虎国产免费 | 日韩成人免费在线观看 | 一级特黄aaa大片在线观看 | 狠狠色丁香久久婷婷综合五月 | 免费福利视频导航 | 日日夜夜天天人人 | 国产精品系列在线播放 | 麻花豆传媒一二三产区 | 亚洲精品视频免费在线观看 | www.色婷婷.com | 九色在线 | 黄p网站在线观看 | 亚洲国产天堂av | www.色com | 91中文字幕网 | 国产精品视频最多的网站 | 久久黄色免费观看 | 婷婷色资源 | 热久久影视 | 99免费视频 | 91污在线观看| 色全色在线资源网 | 五月天色网站 | av片一区二区 | 六月丁香六月婷婷 | 国产福利一区二区三区视频 | 午夜精品一二区 | 极品美女被弄高潮视频网站 | 久草视频手机在线 | 新版资源中文在线观看 | 九九久久成人 | 久久刺激视频 | 成人在线黄色 | 久久久婷| 在线观看免费日韩 | www.婷婷色| 国产精品久久久久影院日本 | 亚洲综合色丁香婷婷六月图片 | 粉嫩aⅴ一区二区三区 | 青青河边草免费直播 | 久久福利综合 | 中文在线免费一区三区 | 成人国产精品av | 国产三级精品三级在线观看 | 成人黄色av网站 | 日本中文一区二区 | 欧美精品久久人人躁人人爽 | 中文字幕亚洲欧美日韩2019 | av成人免费在线看 | 伊人天天综合 | 国产a视频免费观看 | 草久在线观看视频 | 91中文在线视频 | 久久精品99精品国产香蕉 | 五月天婷婷在线播放 | 国产日产欧美在线观看 | 中文字幕免费高 | 日日夜精品 | 婷婷综合五月天 | 国产综合小视频 | 国产一级片播放 | 成人毛片网 | mm1313亚洲精品国产 | 国产精品h在线观看 | 亚洲专区一二三 | 97免费中文视频在线观看 | 欧美成人在线网站 | 日韩中文字幕国产精品 | 久久久久综合 | 欧美日韩在线观看不卡 | 手机av在线网站 | 国产精品不卡视频 | 99视频国产在线 | 午夜三级在线 | 久久激情五月婷婷 | 精品久久久久久综合 | 国产亚州av | 国产一区在线视频 | 国产精品美女久久久久久久 | 国产精品mm | 中文字幕专区高清在线观看 | 在线亚洲欧美日韩 | 99免费在线观看视频 | 在线视频app| 中文字幕视频 | 欧美日韩国产在线 | 99热超碰在线 | 九九亚洲视频 | 中文字幕在线观看一区二区三区 | 国产一区二区三区久久久 | 精品久久91| h文在线观看免费 | 成人免费一区二区三区在线观看 | 国产视频 亚洲精品 | 成人午夜电影在线播放 | 中文在线字幕免费观 | 特级a毛片| 精品久久久久久国产91 | 久久久久亚洲精品中文字幕 | 精品国产一区二区三区蜜臀 | 日韩av成人在线观看 | 麻豆国产精品永久免费视频 | 天天做天天爱夜夜爽 | 欧美精品乱码久久久久久按摩 | 天天色天天射天天干 | av一级片在线观看 | 日韩久久午夜一级啪啪 | 国产亚洲综合在线 | 人人澡人人添人人爽一区二区 | 久久成人午夜 | 国产真实精品久久二三区 | 久久精品99 | 国产成人免费在线观看 | 久久久精品午夜 | 久久一级电影 | 国产区精品视频 | 天堂av在线7 | 久久高清视频免费 | 色网站在线观看 | 麻豆94tv免费版 | 中文字幕国产精品 | 国产视频亚洲 | 婷婷深爱激情 | 美腿丝袜av| 色婷婷综合五月 | 亚洲a在线观看 | 亚洲精品免费视频 | 开心综合网 | 亚洲欧洲av在线 | 精品99在线视频 | 国产精品一区二区三区免费视频 | 97看片网| 日韩中文字幕在线 | 蜜臀久久99静品久久久久久 | 夜色成人网| 亚洲热久久 | 91网页版免费观看 | 国产97免费 | 国产精品视频资源 | 国产小视频免费在线观看 | 五月婷婷久久综合 | 最近免费中文字幕 | 激情婷婷在线观看 | 国产日韩精品一区二区在线观看播放 | 天天综合在线观看 | 日本性生活免费看 | 亚洲精品国产精品国自产 | 日韩精品视频免费看 | www亚洲精品| 日本在线观看一区二区三区 | 国产视频精品久久 | 中文字幕的| 国产小视频福利在线 | 亚洲欧洲精品一区二区精品久久久 | 二区三区在线视频 | 青青河边草免费视频 | caobi视频| 欧美一性一交一乱 | 三级毛片视频 | 午夜黄色一级片 | 在线观看黄av | 亚洲欧美日韩精品一区二区 | 亚洲资源在线网 | 一级免费看视频 | 久久视频在线看 | 亚洲成人精品在线 | 久久综合免费视频影院 | 黄色毛片视频免费 | 国产人成精品一区二区三 | 久久精品毛片基地 | 毛片永久新网址首页 | 成人av免费电影 | 久久久午夜精品理论片中文字幕 | 国产一级在线免费观看 | 国产精品大尺度 | 丁香婷婷激情五月 | 99久久精品国 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 国产高清不卡 | 午夜电影久久久 | 91免费的视频在线播放 | 日韩一级黄色片 | 波多野结衣一区二区三区中文字幕 | 91.麻豆视频 | 亚洲人久久 | 又黄又爽的视频在线观看网站 | 久久精品九色 | 丁香婷婷色综合亚洲电影 | 另类老妇性bbwbbw高清 | 欧美久久久久久久久久久久久 | 天天色天天综合网 | 日韩欧美一区二区三区在线 | 国产白浆在线观看 | 天天操天天操天天 | 欧美有色 | 成人免费色 | 麻豆国产电影 | .国产精品成人自产拍在线观看6 | 日本精品小视频 | 91大神精品视频在线观看 | 国产一区二区三区黄 | 丁香影院在线 | 成人av在线影视 | 午夜影视一区 | 欧美伦理一区 | 麻豆视频在线观看 | 在线播放91| 黄网在线免费观看 | 麻豆综合网 | 欧美日韩精品在线视频 | 久久久久国产精品视频 | 免费视频久久久 | 韩日色视频 | 91精品国产亚洲 | 91高清完整版在线观看 | 国产九色视频在线观看 | 日韩资源在线观看 | 91视频传媒 | 欧美经典久久 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 成人黄大片视频在线观看 | 999久久| 九九九九热精品免费视频点播观看 | 在线不卡的av | 黄色的网站免费看 | 97精品在线视频 | 在线播放日韩av | 天天拍天天色 | 亚洲jizzjizz日本少妇 | 日韩av一区二区三区 | 亚洲一区二区三区四区在线视频 | 日日躁你夜夜躁你av蜜 | 日韩网页 | 成人黄色电影在线播放 | 午夜久久电影网 | 欧美色黄 | 天天射天天干天天操 | 在线观看视频97 | 特级毛片在线免费观看 | av在线播放不卡 | 国产视频1区2区3区 久久夜视频 | 久草在线最新视频 | 欧美性久久久久久 | 亚洲国产精品99久久久久久久久 | 亚洲欧美日韩国产一区二区三区 | 69精品久久 | 麻豆一区在线观看 | 国产精品丝袜在线 | 爱色婷婷 | 在线香蕉视频 | 欧美另类sm图片 | 精品在线观看一区二区 | 五月天伊人 | 999久久久久| 国产69熟 | 很污的网站 | 国产精品一区二区在线播放 | 久久国产精品99久久久久久丝袜 | 免费午夜在线视频 | 日韩视| 曰韩精品| 国产精品11 | 91欧美在线 | 国产美女在线免费观看 | 国产91综合一区在线观看 | 日韩一区二区三区在线观看 | 四虎影视成人精品国库在线观看 | 国产精品高潮呻吟久久久久 | 久久精品国产精品 | 激情影院在线观看 | 日韩在线观看第一页 | 国产亚洲精品久久久久久电影 | 日韩在线视频观看 | 色天堂在线视频 | 蜜桃av观看 | 国产精品都在这里 | 久久国产乱 | 日韩av一区二区在线 | 国内精品久久久久 | 国产原创在线观看 | 91看成人| 久久久久女人精品毛片九一 | 成人欧美一区二区三区在线观看 | 日韩在线视频免费播放 | 久久精品国产一区二区电影 | 久久久久久久久久久久久9999 | 久久综合九色综合欧美就去吻 | 亚洲黄色免费在线看 | 久久久久亚洲精品国产 | 日韩xxxbbb | 色综合久久网 | 中文字幕亚洲在线观看 | 免费观看性生交 | 国产剧情一区 | 国产1级毛片 | 色综合中文字幕 | 久久久久久久99 | 91在线91| 国产精品一区二区三区久久 | 在线观看视频一区二区三区 | 在线电影91 | 毛片一区二区 | 6080yy精品一区二区三区 | av丝袜美腿 | 五月天婷亚洲天综合网鲁鲁鲁 | 97在线观看免费观看 | 91在线九色 | 欧美日韩啪啪 | 精品国产一区二区三区蜜臀 | 国产精品久久婷婷六月丁香 | 久久国产精品99精国产 | 一区二区三区韩国免费中文网站 | 欧美精品一区二区在线播放 | av片一区| 国产又粗又猛又黄又爽的视频 | 伊人六月 | 中文字幕在线免费观看 | 欧美日韩国产一区二区三区在线观看 | 日韩最新av在线 | 中文字幕第一页在线视频 | 亚洲精品久 | 97超级碰碰 | 亚洲精品理论 | 99免费在线播放99久久免费 | 成人免费观看在线视频 | 成人动漫视频在线 | 色婷婷国产精品一区在线观看 | 亚洲免费在线看 | 偷拍精品一区二区三区 | 日本护士三级少妇三级999 | 久久精品视频免费播放 | 色在线网| 五月激情亚洲 | 国产电影黄色av | 欧美 日韩 国产 成人 在线 | 国产亚洲精品久久久久久电影 | 亚洲一区二区视频在线播放 | 丁香激情五月婷婷 | 超碰在线国产 | 在线激情影院一区 | 成人在线观看免费 | 97视频网址 | 天天综合天天做天天综合 | 中文字幕在线观看网站 | 精品视频久久 | 九九热在线精品 | 激情视频免费观看 | 玖玖爱免费视频 | 麻豆视频国产 | 久久电影国产免费久久电影 | 婷婷网站天天婷婷网站 | 在线午夜 | 久久久国产精品视频 | 国产亚洲91 | 综合久久婷婷 | 国产成本人视频在线观看 | 在线观看av不卡 | 狠狠躁18三区二区一区ai明星 | 成人黄色在线 | .精品久久久麻豆国产精品 亚洲va欧美 | 国产成人精品一二三区 | 国产成人三级在线 | 手机av片 | 27xxoo无遮挡动态视频 | 成人免费xxx在线观看 | 在线观看中文字幕一区二区 | 在线看片中文字幕 | 免费在线观看av的网站 | 亚洲国内精品视频 | 中文字幕日韩一区二区三区不卡 | 天天操天天色天天射 | 日本婷婷色 | 欧美成人69av | 久久视频这里有久久精品视频11 | 婷婷深爱激情 | 欧美天堂影院 | 精品伦理一区二区三区 | 成年人在线观看 | 在线观看免费一区 | 免费观看v片在线观看 | 久久综合一本 | 香蕉网在线观看 | 国精产品一二三线999 | 欧美成人999 | 久久精品99北条麻妃 | 国产精品久久久久婷婷二区次 | 久久黄色网址 | 久久公开免费视频 | 叶爱av在线 | 午夜精品导航 | 免费在线国产视频 | 日韩精品一区二区三区电影 | 免费精品久久久 | 日韩免费电影一区二区三区 | 日韩精品一区二区在线观看视频 | 久久久久久久久久电影 | 欧美a性| 久久视频免费在线观看 | 色播五月婷婷 | 国产精品2018| 日日爽天天 | 69国产精品视频 | 婷婷精品国产欧美精品亚洲人人爽 | 美女精品| 色av婷婷 | 亚洲一区二区三区四区在线视频 | 综合色亚洲 | 久久优 | av丝袜美腿 | 三级视频日韩 | 国产亚洲片 | 亚洲精品视频一二三 | 国产区高清在线 | 中文字幕欧美日韩va免费视频 | 亚洲国产精久久久久久久 | 99久久毛片 | 黄色福利| 国产精品一区二区中文字幕 | 日韩三级不卡 | 天天想夜夜操 | 米奇狠狠狠888 | 麻豆精品在线 | 国产精品国产三级国产aⅴ9色 | 狠狠婷婷 | 五月综合久久 | 久久久国产精品人人片99精片欧美一 | 国产精品国产三级国产 | 午夜精品一区二区三区视频免费看 | 曰韩精品 | 天天曰夜夜爽 | 少妇搡bbbb搡bbb搡aa | 欧美一区二区三区在线视频观看 | 人人爽人人爽 | 一本一本久久aa综合精品 | 6080yy精品一区二区三区 | 91精品久久久久久久久久入口 | 操久久网| 国产手机视频在线 | 久久毛片高清国产 | 久久久久国产一区二区三区 | 日本精品视频一区二区 | 91精品一区国产高清在线gif | 97精产国品一二三产区在线 | 久久精品一区二区三 | 国产精品视频永久免费播放 | 美女久久久 | 五月天激情综合网 | 国产日韩欧美在线看 | 99色国产 | 欧美一级片在线免费观看 | 亚洲国产网址 | 在线国产欧美 | 久久视频99 | 久久伊人精品一区二区三区 | 国产专区在线 | 午夜国产福利在线 | 欧美激情视频一区 | 视频国产 | 91在线视频免费91 | 在线观看日韩av | 奇米777777 | 久久99亚洲热视 | 国内精品亚洲 | 久草在在线视频 | 国内精品久久久精品电影院 | 国产永久免费高清在线观看视频 | 色综合国产 | 日韩免费一区二区在线观看 | 婷婷久久丁香 | 成年人黄色免费看 | 最近最新最好看中文视频 | 国产专区在线播放 | 成人污视频在线观看 | 国产一区视频免费在线观看 | 2023国产精品自产拍在线观看 |