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

聊一聊函數(shù)之美

開發(fā) 前端
函數(shù)在任何編程語言中都占據(jù)著主導(dǎo)地位。關(guān)于memoize的思考來源于reack的Hook文檔中,memoize的特性就是「 利用函數(shù)的特性做緩存 」。

 [[380969]]

函數(shù)在任何編程語言中都占據(jù)著主導(dǎo)地位。

而在js中,函數(shù)是另類的存在,本質(zhì)上是特殊的Object,它可以設(shè)置屬性:

  1. const fn = () => { }; 
  2. fn.foo = "foo"
  3. console.log(fn.foo); // 'foo' 

今天分享的是函數(shù)的一些操作:

  • 函數(shù)的緩沖功能memoize
  • 函數(shù)柯里化curry
  • 截取參數(shù)處理arg
  • 防抖節(jié)流
  • 延遲函數(shù)執(zhí)行delay
  • 延遲函數(shù)調(diào)用defer
  • 異步函數(shù)調(diào)用compose
  • 函數(shù)只被調(diào)用一次once
  • 判斷函數(shù)是否可以執(zhí)行
  • 檢查對象屬性checkProp
  • 鏈?zhǔn)秸{(diào)用函數(shù)

函數(shù)的緩沖功能memoize

關(guān)于memoize的思考來源于reack的Hook文檔中,memoize的特性就是「 利用函數(shù)的特性做緩存 」。

不知道你做算法的時候,是否考慮過遞歸是怎么緩存結(jié)果,層層儲存的。

如下的斐波那契,每一次計算的結(jié)果緩存在哪里呢?

  1. const fibonacci = (n) => { 
  2.     return n < 2 ? n : fibonacci(n - 1) + fibonacci(n - 2); 
  3. }; 

我們可以簡單模擬一下memoize的實現(xiàn):

  1. const memoize = function (fn) { 
  2.   const cache = {}; 
  3.   return function () { 
  4.     const key = JSON.stringify(arguments); 
  5.     var value = cache[key]; 
  6.     if (!value) { 
  7.       // 為了了解過程加入的log,正式場合應(yīng)該去掉 
  8.       console.log('新值,執(zhí)行中...');  
  9.       // 放在一個數(shù)組中,方便應(yīng)對undefined,null等異常情況 
  10.       value = [fn.apply(this, arguments)];   
  11.       cache[key] = value; 
  12.     } else { 
  13.       console.log('來自緩存');   
  14.     } 
  15.     return value[0]; 
  16.   } 

測試一下:

  1. const memoizeFibonacci = memoize(fibonacci); 
  2.  
  3. const log = console.log; 
  4. log(memoizeFibonacci(45)); 
  5. // 新值,執(zhí)行中...;    1134903170  // 等待時間比較長 
  6. log(memoizeFibonacci(45)); 
  7. // 來自緩存;    1134903170 
  8. log(memoizeFibonacci(45)); 
  9. // 來自緩存;    1134903170 
  10. log(memoizeFibonacci(45)); 
  11. // 來自緩存;    1134903170 
  12. log(memoizeFibonacci(45)); 

函數(shù)柯里化curry

柯里化的概念就是「 把接受多個參數(shù)的函數(shù)變換成接受一個單一參數(shù)的函數(shù) 」。

  1. const curry = (fn, arity = fn.length, ...args) => 
  2.   arity <= args.length ? fn(...args) : curry.bind(null, fn, arity, ...args); 
  3.  
  4. curry(Math.pow)(2)(10); // 1024 
  5. curry(Math.min, 3)(10)(50)(2); // 2 

這個bind用得非常好,借助它積累每次傳進來的參數(shù),等到參數(shù)足夠時,再調(diào)用。

有了柯里化,還有反柯里化,它的概念是「 把多個接受多個參數(shù)的函數(shù)層層鋪平 」。

  1. const uncurry = (fn, n = 1) => (...args) => { 
  2.   const next = acc => args => args.reduce((x, y) => x(y), acc); 
  3.   if (n > args.length) throw new RangeError('Arguments too few!'); 
  4.   return next(fn)(args.slice(0, n)); 
  5. }; 
  6.  
  7. const add = x => y => z => x + y + z; 
  8. const uncurriedAdd = uncurry(add, 3); 
  9. uncurriedAdd(1, 2, 3); // 6 

截取函數(shù)參數(shù)ary

「 截取指定函數(shù)參數(shù)做操作 」;ary的第二個參數(shù)接收一個索引參數(shù),表示只截取得到n的位置。

  1. // ary 截取指定參數(shù)處理 
  2. const ary = (fn, n) => (args) => fn(args.slice(0, n)); 
  3.  
  4. // 如果處理的數(shù)據(jù)是字符串 
  5. const checkPe = (arg) => { 
  6.   if (arg && arg.indexOf('pe') > -1) { 
  7.     return arg.indexOf('pe'
  8.   } 
  9.   return -1 
  10. const getPe = ary(checkPe, 5); 
  11. const numsPe = ['wpe''wwperr''wwepe'].map(x => getPe(x)); 
  12.  
  13. console.log(numsPe, 'numsPe'
  14. // [1, 2, 3] 

如果是數(shù)組的話,需要使用擴展運算符。

  1. // 如果處理的數(shù)據(jù)是數(shù)組 
  2. const ary = (fn, n) => (...args) => fn(...args.slice(0, n)); 
  3.  
  4. const firstTwoMax = ary(Math.max, 3); 
  5. const nums = [[2, 6, 9, 'a'], [6, 4, 8], [10]].map(x => firstTwoMax(...x)); 
  6.  
  7. console.log(nums, 'nums'
  8. // [9, 8, 10] 

防抖節(jié)流

關(guān)于防抖和節(jié)流的區(qū)別可以參考我之前的文章《電梯與地鐵之說》。

  1. const debounce = (fn, ms = 0) => { 
  2.   let timeoutId; 
  3.   return function(...args) { 
  4.     clearTimeout(timeoutId); 
  5.     timeoutId = setTimeout(() => fn.apply(this, args), ms); 
  6.   }; 
  7. }; 
  8.  
  9. window.addEventListener( 
  10.   'resize'
  11.   debounce(() => { 
  12.     console.log(window.innerWidth); 
  13.     console.log(window.innerHeight); 
  14.   }, 250) 

傳入高頻次調(diào)用的函數(shù)和時間間隔,返回一個已防抖的函數(shù)。

節(jié)流會稀釋函數(shù)的執(zhí)行頻率。在wait秒內(nèi)只執(zhí)行一次。

  1. const throttle = (fn, wait) => { 
  2.   let inThrottle, lastFn, lastTime; 
  3.   return function() { 
  4.     const context = this, 
  5.       args = arguments; 
  6.     if (!inThrottle) { 
  7.       fn.apply(context, args); 
  8.       lastTime = Date.now(); 
  9.       inThrottle = true
  10.     } else { 
  11.       clearTimeout(lastFn); 
  12.       lastFn = setTimeout(function() { 
  13.         if (Date.now() - lastTime >= wait) { 
  14.           fn.apply(context, args); 
  15.           lastTime = Date.now(); 
  16.         } 
  17.       }, Math.max(wait - (Date.now() - lastTime), 0)); 
  18.     } 
  19.   }; 
  20. }; 
  21.  
  22. window.addEventListener( 
  23.   'resize'
  24.   throttle(function(evt) { 
  25.     console.log(window.innerWidth); 
  26.     console.log(window.innerHeight); 
  27.   }, 250) 
  28. ); // Will log the window dimensions at most every 250ms 

延遲函數(shù)執(zhí)行delay

delay字面意思:「 延遲執(zhí)行 」。

  1. const delay = (fn, wait, ...args) => setTimeout(fn, wait, ...args); 
  2.  
  3. delay( 
  4.   function (text) { 
  5.     console.log(text); 
  6.   }, 
  7.   1000, 
  8.   'later' 
  9. ); // Logs 'later' after one second

延遲函數(shù)調(diào)用defer

defer字面意思:「 延遲調(diào)用 」。

可適用于推遲 cpu 密集型計算,以免阻塞渲染引擎工作。使用setTimeout(超時時間為1ms)將函數(shù)參數(shù)添加到瀏覽器事件隊列末尾。

  1. const defer = (fn, ...args) => setTimeout(fn, 1, ...args); 
  2.  
  3. // Example A: 
  4. defer(console.log, 'a'), console.log('b'); // logs 'b' then 'a' 

 

異步函數(shù)compose

compose函數(shù)是「 從右向左去實現(xiàn)的數(shù)據(jù)執(zhí)行流 」。它的真正意義在于邏輯分層。利用reduce方法實現(xiàn)函數(shù)的“洋蔥”包裹。

 

  1. const compose = (...fns) => fns.reduce((f, g) => (...args) => f(g(...args))); 
  2.  
  3. const substract3 = x => x - 3; 
  4. const add5 = x => x + 5; 
  5. const multiply = (x, y) => x * y; 
  6. const multiplyAndAdd5AndSubstract3 = compose( 
  7.   substract3, 
  8.   add5, 
  9.   multiply 
  10. ); 
  11. multiplyAndAdd5AndSubstract3(5, 2); // 12 

 

要想實現(xiàn)從左向右執(zhí)行也非常簡單,把f和g的位置互調(diào)一下。

函數(shù)只被調(diào)用一次once

因為 JavaScript 是單線程執(zhí)行環(huán)境,不需要考慮并發(fā)環(huán)境,直接一個內(nèi)部變量存到閉包中,每次調(diào)用前判斷,并在第一次調(diào)用時,修改其值,讓后續(xù)調(diào)用全部失效。

 

  1. const once = (fn) => { 
  2.   let called = false
  3.   return function (...args) { 
  4.     if (called) return
  5.     called = true
  6.     return fn.apply(this, args); 
  7.   }; 
  8. }; 
  9.  
  10. const startApp = function (event) { 
  11.   console.log(this, event); // document.body, MouseEvent 
  12. }; 
  13. document.body.addEventListener("click", once(startApp)); 

 

判斷函數(shù)是否可以執(zhí)行

第一個參數(shù)為函數(shù)是否可以執(zhí)行的判斷條件,第二個參數(shù)為執(zhí)行的函數(shù)。

 

  1. const when = (pred, whenTrue) => (x) => (pred(x) ? whenTrue(x) : x); 
  2.  
  3. const doubleEvenNumbers = when
  4.   (x) => x % 2 === 0, 
  5.   (x) => x * 2 
  6. ); 
  7. doubleEvenNumbers(2); // 4 
  8. doubleEvenNumbers(1); // 1 

 

檢查對象屬性

「 判斷某個對象是否具備要求 」。用!!強制轉(zhuǎn)化為布爾類型。

  1. const checkProp = (predicate, prop) => (obj) => !!predicate(obj[prop]); 
  2.  
  3. const lengthIs4 = checkProp((l) => l === 4, "length"); 
  4. lengthIs4([]); // false 
  5. lengthIs4([1, 2, 3, 4]); // true 
  6.  
  7. const sizeIs4 = checkProp((l) => l === 4, "size"); 
  8. sizeIs4(new Set([1, 2, 3, 4])); // true 
  9.  
  10. const session = { obj: { active: true, disabled: false } }; 
  11. const validUserSession = checkProp((u) => u.active && !u.disabled, "obj"); 
  12.  
  13. validUserSession(session); // true 

鏈?zhǔn)秸{(diào)用

將函數(shù)數(shù)組轉(zhuǎn)換為有決策權(quán)的鏈?zhǔn)胶瘮?shù)調(diào)用。

  1. const chainAsync = (fns) => { 
  2.   let curr = 0; 
  3.   const last = fns[fns.length - 1]; 
  4.   const next = () => { 
  5.     const fn = fns[curr++]; 
  6.     fn === last ? fn() : fn(next); 
  7.   }; 
  8.   next(); 
  9. }; 
  10.  
  11. chainAsync([ 
  12.   (next) => { 
  13.     console.log("0 seconds"); 
  14.     setTimeout(next, 1000); 
  15.   }, 
  16.   (next) => { 
  17.     console.log("1 second"); 
  18.     setTimeout(next, 1000); 
  19.   }, 
  20.   () => { 
  21.     console.log("2 second"); 
  22.   }, 
  23. ]); 

 本文轉(zhuǎn)載自微信公眾號「驚天碼盜」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系驚天碼盜公眾號。

 

責(zé)任編輯:武曉燕 來源: 驚天碼盜
相關(guān)推薦

2020-11-10 07:46:58

函數(shù)printf 數(shù)據(jù)

2024-04-29 14:58:48

Python內(nèi)置函數(shù)

2020-10-23 07:00:00

C++函數(shù)

2017-10-21 23:02:49

微服務(wù)軟件架構(gòu)

2021-01-28 22:31:33

分組密碼算法

2020-05-22 08:16:07

PONGPONXG-PON

2023-09-22 17:36:37

2018-06-07 13:17:12

契約測試單元測試API測試

2023-07-06 13:56:14

微軟Skype

2021-01-29 08:32:21

數(shù)據(jù)結(jié)構(gòu)數(shù)組

2022-11-01 08:46:20

責(zé)任鏈模式對象

2022-08-08 08:25:21

Javajar 文件

2020-10-15 06:56:51

MySQL排序

2019-02-13 14:15:59

Linux版本Fedora

2018-11-29 09:13:47

CPU中斷控制器

2023-05-15 08:38:58

模板方法模式

2021-08-04 09:32:05

Typescript 技巧Partial

2021-01-01 09:01:05

前端組件化設(shè)計

2022-11-26 00:00:06

裝飾者模式Component

2020-06-28 09:30:37

Linux內(nèi)存操作系統(tǒng)
點贊
收藏

51CTO技術(shù)棧公眾號

亚洲一区二区三区不卡国产欧美| 美女精品一区| 日韩三级av在线播放| 女人被男人躁得好爽免费视频| 欧洲av在线播放| 男人的天堂成人在线| 日韩在线播放视频| 亚洲高清无码久久| 日本一区二区三区视频在线| 亚洲人成影院在线观看| 国产亚洲二区| 亚洲图片视频小说| 1024成人| 日韩在线免费av| 扒开伸进免费视频| 久久人体av| 欧美日韩精品在线播放| 51xx午夜影福利| 黄色视屏网站在线免费观看| 国产精品一二三在| 国产精品久久久久福利| 国产精品第一页在线观看| jizzjizz欧美69巨大| 精品成人在线观看| 51自拍视频在线观看| 欧美亚洲大片| 欧美日韩国产区| 糖心vlog在线免费观看| 黄色在线视频观看网站| proumb性欧美在线观看| 99re在线国产| 97超碰国产在线| 久久综合婷婷| 热久久这里只有| 日韩无码精品一区二区三区| 中国成人一区| 日韩中文字幕在线免费观看| 日本一级免费视频| 亚洲精品无吗| 亚洲国产高清福利视频| 手机在线成人免费视频| 黄色成人免费网| 五月婷婷久久综合| 成人毛片100部免费看| 快射av在线播放一区| 国产欧美日韩在线看| 噜噜噜噜噜久久久久久91| 国产18精品乱码免费看| 国产成人高清在线| 成人av片网址| 亚洲经典一区二区三区| 国产精品综合一区二区| 91在线视频九色| 亚洲视频一区在线播放| 美女视频黄久久| 国产精品视频免费观看www| 波多野结衣毛片| 日本不卡高清视频| 国产精品一二三在线| 夜夜躁日日躁狠狠久久av| 天堂午夜影视日韩欧美一区二区| 青青青国产精品一区二区| 亚洲黄色小说图片| 久久视频一区| 国产精品三级网站| 国产精品无码在线播放 | 久久久伊人欧美| 欧美日韩三级在线观看| 在线欧美一区| 日本电影亚洲天堂| 性色av一区二区三区四区| 蜜桃精品视频在线| 亚洲aaaaaa| 你懂的网站在线| 久久久久国产一区二区三区四区| 欧美一区2区三区4区公司二百| 国产午夜视频在线观看| 国产日韩欧美不卡在线| 一区国产精品| 日本大片在线播放| 欧美日韩中文字幕在线| 国产精品天天av精麻传媒| 福利视频一区| 欧美成人精品二区三区99精品| 国产免费一区二区三区最新6| 日韩极品少妇| www.日韩不卡电影av| 久久综合加勒比| 久久精品亚洲| 亚洲永久在线观看| 婷婷在线免费视频| 国产欧美日韩另类视频免费观看| 黄色高清视频网站| 高清精品在线| 欧美日韩精品一区二区三区四区| 伊人成人免费视频| 日韩精选在线| 久久精品成人一区二区三区 | 黄色在线成人| 国产va免费精品高清在线观看| 亚洲中文一区二区三区| 成人午夜视频免费看| 日韩国产一区久久| 黄页网站在线观看免费| 欧洲一区在线电影| 波多野结衣视频播放| 日韩一区二区三区免费播放| 亚州精品天堂中文字幕| 中文字幕乱码中文字幕| av资源站一区| 久久天天东北熟女毛茸茸| 亚洲性色av| 日韩精品在线网站| av手机在线播放| 亚洲理伦在线| 99视频免费观看蜜桃视频| 福利成人在线观看| 精品福利一区二区| 激情小说欧美色图| 色综合天天爱| 国产精品第一区| 免费激情视频网站| 亚洲精品日韩一| 91极品视频在线观看| 亚洲精品无吗| 97成人在线视频| 东京干手机福利视频| 亚洲天堂免费在线观看视频| 色国产在线视频| 国产一区毛片| 1769国产精品| 天堂av资源在线| 一区二区三区高清| 手机在线国产视频| 久久精品国产68国产精品亚洲| 日本国产精品视频| 午夜福利视频一区二区| 五月婷婷激情综合| av漫画在线观看| 欧美~级网站不卡| 91在线无精精品一区二区| 一广人看www在线观看免费视频| 日本韩国精品在线| 精品无码一区二区三区| 免费永久网站黄欧美| 国产一区二区无遮挡| 国产免费拔擦拔擦8x在线播放| 日韩欧美www| 久久黄色小视频| 成人国产精品视频| 国产美女在线一区| 爱高潮www亚洲精品| 欧美激情中文网| 免费av网站在线播放| 亚洲777理论| 日本黄色免费观看| 国产精品色网| 日本视频一区在线观看| av在线播放一区| 日韩在线免费av| av中文字幕免费| 亚洲国产精品麻豆| 美女又爽又黄视频毛茸茸| 国产免费成人| 相泽南亚洲一区二区在线播放| 欧美伊人亚洲伊人色综合动图| 日韩综合视频在线观看| 精品国自产拍在线观看| 亚洲.国产.中文慕字在线| 精品夜夜澡人妻无码av| 天堂午夜影视日韩欧美一区二区| 婷婷久久伊人| 日韩欧洲国产| 国产91精品久久久久久| 岛国在线视频| 日韩三级中文字幕| 国产成人在线观看网站| 国产无人区一区二区三区| 久久人人爽av| 激情久久婷婷| 日韩动漫在线观看| 欧美中文高清| 欧美中文字幕第一页| 中文字幕日本在线| 日韩一级片在线观看| 久久国产视频播放| 国产精品久久久久久久久果冻传媒| 国产乱叫456| 在线播放不卡| 午夜精品福利一区二区| 亚洲日本va午夜在线电影| 日产精品99久久久久久| 免费在线毛片网站| 日韩国产精品一区| 国产精品一区二区免费视频| 午夜婷婷国产麻豆精品| 天堂av免费在线| 99免费精品在线观看| 天天干天天玩天天操| 亚洲成人在线| 超碰成人在线免费观看| 日韩在线影视| 不卡一卡2卡3卡4卡精品在| 天天综合网天天| 欧美激情乱人伦| 成年网站在线| 亚洲精品mp4| av免费在线不卡| 欧美一a一片一级一片| 日本熟女一区二区| 亚洲欧美二区三区| a天堂中文字幕| av不卡在线观看| 欧美xxxxxbbbbb| 人人狠狠综合久久亚洲| 国产中文字幕视频在线观看| 亚洲一区色图| 亚洲激情啪啪| 免费成人av| 国产精品一区二区三区不卡| 国产成人久久精品一区二区三区| 欧洲美女免费图片一区| 91色在线看| 欧美日本高清视频| 麻豆网站视频在线观看| 永久免费精品影视网站| 免费看男男www网站入口在线 | 欧美日韩午夜视频在线观看| 欧美成人免费观看视频| 中文字幕一区二区三区精华液| 亚洲一级中文字幕| 99视频在线精品| 女性生殖扒开酷刑vk| 国产成人一区在线| aaa一级黄色片| 久久99久久99| 亚洲va在线va天堂va偷拍| 日韩成人一级片| 丁香婷婷激情网| 久久婷婷av| 日韩亚洲在线视频| 六月天综合网| 国产成人久久婷婷精品流白浆| 国产视频一区免费看| 久操网在线观看| 亚洲一级网站| www污在线观看| 亚洲高清资源| cao在线观看| 国产欧美丝祙| 久久久久人妻精品一区三寸| 免费一区视频| 亚洲黄色av网址| 久久精品国产99国产| 57pao国产成永久免费视频| 麻豆成人免费电影| 色噜噜狠狠一区二区三区狼国成人| 久久精品72免费观看| 亚洲精品国产久| 国产成都精品91一区二区三| 中文字幕一区二区三区人妻在线视频| 高清在线观看日韩| v天堂中文在线| 久久精品一区八戒影视| 超薄肉色丝袜一二三| 亚洲天堂成人网| 久久久久久欧美精品se一二三四 | 国语对白做受69按摩| 欧美性猛交xxxx乱大交退制版| 中文字幕在线日亚洲9| 宅男在线国产精品| 丰满岳乱妇国产精品一区| 日韩精品在线观| 国产日产精品久久久久久婷婷| 日韩在线小视频| 四虎亚洲成人| 57pao国产成人免费| www.一区| 99re视频在线播放| 曰本一区二区三区视频| 在线免费观看一区二区三区| 黄色欧美日韩| av五月天在线| 国产.精品.日韩.另类.中文.在线.播放 | 涩涩视频在线播放| 国产精品视频精品| 大桥未久女教师av一区二区| 日韩久久久久久久久久久久久| 综合日韩在线| 黄色一级一级片| 国产精品一区二区三区乱码| 亚洲熟女乱综合一区二区三区| 日本一区二区久久| 麻豆亚洲av熟女国产一区二| 色拍拍在线精品视频8848| 国产麻豆一精品一男同| 日韩精品中文字幕视频在线| 蜜桃视频网站在线| 欧美性一区二区三区| 精品国产亚洲一区二区在线观看| 久久久www免费人成黑人精品| 97欧美在线视频| 你真棒插曲来救救我在线观看| 日韩国产欧美在线视频| 欧美熟妇另类久久久久久多毛| 91在线视频观看| 国产盗摄x88av| 欧洲生活片亚洲生活在线观看| www日本在线| 精品久久久av| 99久久er| 欧美成人第一区| 国产真实久久| 亚洲黄色av片| 欧美极品少妇xxxxⅹ高跟鞋| 日韩女同强女同hd| 欧美一级片在线| 在线免费av网站| 日本午夜精品理论片a级appf发布| 99re热精品视频| 免费观看中文字幕| 男男视频亚洲欧美| 自拍偷拍中文字幕| 午夜私人影院久久久久| 精品国产亚洲av麻豆| 日韩中文字幕在线视频播放| 第84页国产精品| 久久草.com| 91久久久久| 成人在线观看一区二区| 亚洲日本va午夜在线影院| 中文字幕在线观看免费| 国产一区二区动漫| 日韩久久一区二区三区| 蜜桃导航-精品导航| 中文久久精品| 免费成人蒂法网站| 欧美日韩美女在线| 深夜视频在线免费| 欧美亚洲国产日韩2020| 国产精品成人自拍| 五十路熟女丰满大屁股| 白白色 亚洲乱淫| 日韩成人av毛片| 欧美精品一区二区蜜臀亚洲| 搞黄网站在线看| 国产亚洲精品美女久久久m| 亚洲激情不卡| 一起草在线视频| 精品国产91久久久久久| 青青免费在线视频| 国产999精品久久久| 奇米色欧美一区二区三区| 99草草国产熟女视频在线| 欧美国产精品久久| 一级爱爱免费视频| 久久影视电视剧免费网站清宫辞电视| 亚洲精品成a人ⅴ香蕉片| 亚洲综合激情五月| 国产乱国产乱300精品| 青娱乐91视频| 亚洲精品mp4| 欧美艳星kaydenkross| 日本中文不卡| 久久99精品国产麻豆婷婷洗澡| 九九精品视频免费| 欧美成人一区二区三区片免费| 都市激情久久综合| 久久久久久久免费| 免费成人在线观看视频| 日本午夜在线观看| 亚洲国产91色在线| 天天免费亚洲黑人免费| 亚洲欧洲日韩精品| 国产精品18久久久| 丰满少妇乱子伦精品看片| 亚洲人成亚洲人成在线观看| 欧美成人高清视频在线观看| 2022中文字幕| 久久精品视频网| 国产精品欧美久久久久天天影视| 欧美激情国内偷拍| 国产不卡av一区二区| 亚洲天堂伊人网| 欧美日韩激情网| 美女隐私在线观看| 国内视频一区| 久久精品国产99国产精品| 国产第一页第二页| 一区二区福利视频| 国产精品男女| 三级a在线观看| 一区二区三区波多野结衣在线观看 | 日韩成人一区二区三区在线观看| 乱h高h女3p含苞待放| 亚洲精品成人久久久| 高清在线一区| 久久久一本二本三本| 国产精品乱码一区二区三区软件| 好男人www在线视频|