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

JavaScript 高級單行代碼詳解

開發 前端
今天我們一起來了解一下關于JavaScript 的高級單行代碼的詳細解析。

1. 通過鍵對對象數組進行分組

我們定義了一個名為 groupBy 的函數,它以一個對象數組和一個鍵作為參數。該函數的目的是將數組中的對象按指定的鍵進行分組。

const groupBy = (arr, key) =>
arr.reduce(
(acc, obj) => ({ ...acc, [obj[key]]: [...(acc[obj[key]] || []), obj] }),
{}
)


const people = [
{ name: "Alice", age: 21 },
{ name: "Bob", age: 22 },
{ name: "Charlie", age: 21 },
{ name: "David", age: 23 },
{ name: "Eve", age: 22 }
]


console.log(groupBy(people, "age"))


/* Output:
{
21: [
{ name: "Alice", age: 21 },
{ name: "Charlie", age: 21 }
],
22: [
{ name: "Bob", age: 22 },
{ name: "Eve", age: 22 }
],
23: [{ name: "David", age: 23 }]
}
*/

acc 參數是累加分組對象的累加器。obj 參數表示數組中的每個對象。

在 reduce() 方法內部,使用擴展運算符 (...acc) 返回一個新對象。這將創建 accumulator 對象的淺表副本,以便可以在不更改原始對象的情況下對其進行修改。

新對象的屬性設置為與 key 參數的值相匹配的鍵。該屬性的值是一個包含被迭代對象的數組。

(acc[obj[key]] || []) 表達式檢查該屬性是否存在于累加器對象中。如果不存在,則返回一個空數組。展開運算符用于將數組與正在迭代的當前對象連接起來。

最后,groupBy() 函數返回包含分組對象的累加器對象。

2. 返回數組的中位數

我們實現了一個名為 median 的函數,它將一個數字數組作為輸入,按升序對其進行排序,并返回排序后的數組的中值。

當數組的元素個數為奇數時,排序數組的中值就是中間的元素。當數組元素個數為偶數時,中值取中間兩個元素的平均值。

const median = (arr) => {
const sorted = arr.sort()
const middle = Math.floor(sorted.length / 2)
return sorted.length % 2 === 0
? (sorted[middle - 1] + sorted[middle]) / 2
: sorted[middle]
}


const oddArr = [3, 1, 4, 2, 5]
console.log(median(oddArr)) // 3


const evenArr = [1, 2, 5, 6]
console.log(median(evenArr)) // 3.5

第一個例子,輸入數組[3, 1, 4, 2, 5]被排序為[1, 2, 3, 4, 5],中間元素為3。因此,輸入數組的中值 是 3。

在第二個例子中,輸入數組[1,2,5,6]被排序為[1,2,5,6],中間兩個元素為2和5。因此,輸入數組的中值為 (2 + 5) / 2 = 3.5。

3.返回數組的模式

數組的眾數是數組中出現頻率最高的值。如果有多個值具有相同的最高頻率,則所有這些值都被視為眾數。

const mode = (arr) => {
const counts = arr.reduce(
(acc, curr) => ({ ...acc, [curr]: (acc[curr] || 0) + 1 }),
{}
)


const maxCount = Math.max(...Object.values(counts))


return Object.keys(counts)
.filter((key) => counts[key] === maxCount)
.map(Number)
}


const arr1 = [1, 2, 3, 2, 4, 2, 5]
console.log(mode(arr1)) // [2]


const arr2 = [1, 2, 3, 2, 4, 4, 5]
console.log(mode(arr2)) // [2, 4]

在第一個示例中,輸入數組 [1, 2, 3, 2, 4, 2, 5] 的計數為 { 1: 1, 2: 3, 3: 1, 4: 1, 5: 1 }。最高計數為 3,出現值 2。因此,輸入數組的模式為 [2]。

在第二個示例中,輸入數組 [1, 2, 3, 2, 4, 4, 5] 的計數為 { 1: 1, 2: 2, 3: 1, 4: 2, 5: 1 }。最高計數為 2,出現在值 2 和 4 中。因此,輸入數組的模式為 [2, 4]。

4. 使用擴展運算符和 Array.from 創建一個長度為 n 的數組

使用擴展運算符和 Array.from() 創建一個長度為 n 的新數組。生成的數組包含從 0 到 n-1 的升序排列的數字。

const n = 5
const arr = [...Array.from({ length: n }, (_, index) => index)]


console.log(arr) // [ 0, 1, 2, 3, 4 ]

在此示例中,n 設置為 5,因此,生成的數組 arr 的長度為 5。數組的值是使用函數 (_, index) => index 生成的,該函數返回數組的當前索引。因此,結果數組將為 [0, 1, 2, 3, 4]。

5. 使用解構獲取數組的最后一個元素

此函數的目的是使用解構獲取數組的最后一個元素。

const last = (arr) => [...arr].pop()


const people = [
{ name: "Alice", age: 21 },
{ name: "Bob", age: 22 },
{ name: "Charlie", age: 21 },
{ name: "David", age: 23 },
{ name: "Eve", age: 22 }
]


console.log(last(people)) // { name: "Eve", age: 22 }

在 last() 函數內部,展開運算符 (...) 用于創建原始數組的副本。這是必需的,因為 pop() 方法會修改原始數組并返回刪除的元素。

然后,對數組的副本調用 pop() 方法,刪除并返回數組的最后一個元素。由于在調用 pop() 方法之前復制了數組,因此不會修改原始數組。

last() 函數返回數組的最后一個元素。

6. 使用布爾構造函數檢查變量是否為真

我們函數的目的是使用布爾構造函數檢查變量是否為真。

布爾構造函數是 JavaScript 中的一個內置函數,可將值轉換為布爾值。如果該值為 truthy,則布爾構造函數返回 true。如果該值為 falsy,則布爾構造函數返回 false。

const isTruthy = (val) => Boolean(val)


console.log(isTruthy(false)) // false
console.log(isTruthy(0)) // false
console.log(isTruthy(-0)) // false
console.log(isTruthy(0n)) // false
console.log(isTruthy("")) // false
console.log(isTruthy(null)) // false
console.log(isTruthy(undefined)) // false
console.log(isTruthy(NaN)) // false


console.log(isTruthy(true)) // true
console.log(isTruthy({})) // true
console.log(isTruthy([])) // true
console.log(isTruthy(42)) // true
console.log(isTruthy("0")) // true
console.log(isTruthy("false")) // true
console.log(isTruthy(new Date())) // true
console.log(isTruthy(Infinity)) // true

7. 從數組中刪除虛假值

布爾構造函數用作 filter() 方法的回調函數。如果值為真,則布爾構造函數返回真,如果值為假,則返回假。因此,filter() 方法從原始數組中刪除所有虛假值。

const compact = (arr) => arr.filter(Boolean)


const falsyArr = [false, 0, -0, 0n, "", null, undefined, NaN]
const mixArr = [true, false, {}, 0, [], "", "0", null, "false", undefined, 42]


console.log(compact(falsyArr)) // []
console.log(compact(mixArr)) // [ true, {}, [], '0', 'false', 42 ]

在 compact() 函數內部,使用布爾構造函數作為回調函數對 arr 參數調用 filter() 方法。這將返回一個新數組,其中僅包含原始數組的真值。

compact() 函數返回新數組。

當執行 console.log() 語句時,compact(falsyArr) 的輸出是一個空數組,因為 falsyArr 數組中的所有值都是假的。compact(mixArr) 的輸出是一個數組,它只包含 mixArr 數組的真實值,即 true、一個空對象 {}、一個空數組 []、字符串“0”、字符串“false”,以及 數字 42。所有虛假值(false、0、""、null、undefined 和 NaN)都已從 mixArr 數組中刪除。

8. 將字符串數組轉換為數字

函數的目的是將字符串數組轉換為數字數組。Number 構造函數用作 map() 方法的回調函數。Number 構造函數將字符串轉換為數字。

const toNumbers = (arr) => arr.map(Number)


const strArr = ["1", "2", "3", "4", "5"]


console.log(toNumbers(strArr)) // [ 1, 2, 3, 4, 5 ]

在 toNumbers() 函數內部,使用 Number 構造函數作為回調函數對 arr 參數調用 map() 方法。這將返回一個包含轉換值的新數組。

9. 返回一個鍵值翻轉的對象

此函數的目的是返回一個新對象,其中翻轉了原始對象的鍵和值。

Object.entries() 方法用于從原始對象創建鍵值對數組。然后使用 map() 方法迭代數組中的每個鍵值對,并返回一個新的翻轉鍵值對數組。最后,使用 Object.fromEntries() 方法從翻轉的鍵值對數組中創建一個新對象。

const flip = (obj) =>
Object.fromEntries(Object.entries(obj).map(([key, value]) => [value, key]))


const myDog = {
firstName: "oscar",
lastName: "king",
age: 3
}


console.log(flip(myDog)) // { 3: 'age', oscar: 'firstName', king: 'lastName' }

在 flip() 函數內部,對 obj 參數調用 Object.entries() 方法以創建鍵值對數組。然后,在鍵值對數組上調用 map() 方法。對于每個鍵值對,map() 方法解構鍵和值變量,并返回一個新數組,其中值作為第一個元素,鍵作為第二個元素。這將創建一個翻轉的鍵值對數組。

最后,在翻轉的鍵值對數組上調用 Object.fromEntries() 方法以使用翻轉的鍵值對創建一個新對象。

flip() 函數返回新對象。

執行 console.log() 語句時,輸出是一個新對象,其中翻轉了原始 myDog 對象的鍵和值。firstName 鍵及其值“oscar”已翻轉為“oscar”鍵及其值“firstName”。lastName 鍵及其值“king”已翻轉為“king”鍵及其值“lastName”。age 鍵及其值 3 已翻轉為 3 鍵及其值“age”。

10. 返回一個只有特定鍵的對象

此函數的目的是返回一個新對象,該對象僅包含原始對象中指定的鍵及其對應的值。

const pick = (obj, keys) =>
Object.fromEntries(
Object.entries(obj).filter(([key]) => keys.includes(key))
)


const myDog = {
firstName: "oscar",
lastName: "king",
age: 3
}


console.log(pick(myDog, [])) // {}
console.log(pick(myDog, ["firstName"])) // { firstName: 'oscar' }
console.log(pick(myDog, ["firstName", "lastName"])) // { firstName: 'oscar', lastName: 'king' }

在 pick() 函數內部,對 obj 參數調用 Object.entries() 方法以創建鍵值對數組。然后,在鍵值對數組上調用 filter() 方法。對于每個鍵值對,filter() 方法解構鍵變量,如果鍵數組包含鍵則返回 true。這將創建一個過濾后的鍵值對數組。

最后,在過濾后的鍵值對數組上調用 Object.fromEntries() 方法來創建一個僅包含指定鍵及其對應值的新對象。pick() 函數返回新對象。

11. 返回一個只有唯一值的對象

此函數 uniqueValues 將一個對象作為參數并返回一個新對象,該對象僅包含來自輸入對象的唯一值。

const uniqueValues = (obj) =>
Object.fromEntries(
Object.entries(obj).filter(
([key, value], index, entries) =>
entries.findIndex(([k, v]) => v === value) === index
)
)


const myDog = {
id: 3,
firstName: "oscar",
lastName: "oscar",
age: 3
}


console.log(uniqueValues(myDog)) // { id: 3, firstName: 'oscar' }

它首先在輸入對象上調用 Object.entries() 方法以獲取鍵值對數組。然后,它使用 filter() 方法過濾條目數組,并僅返回值唯一的條目。

要檢查一個值是否唯一,它在原始條目數組上使用 findIndex() 方法。它查找與當前過濾的條目具有相同值的第一個條目的索引。如果當前條目的索引等于第一個匹配條目的索引,則意味著該值是唯一的,應該包含在結果對象中。

最后,它使用 Object.fromEntries() 方法將過濾后的條目數組轉換回對象。

在示例代碼中,使用具有某些重復值的對象 myDog 調用 uniqueValues 函數。該函數返回一個僅包含唯一值并刪除重復值的新對象。生成的對象具有 id:3 和 firstName:'oscar'。

責任編輯:華軒 來源: web前端開發
相關推薦

2022-11-28 23:44:26

JavaScript技巧程序員

2022-10-20 15:16:23

JavaScript數組技能

2023-02-15 16:19:59

JavaScript技巧API

2024-10-09 14:45:41

2023-10-10 16:20:38

JavaScript代碼技巧

2022-12-19 15:23:51

JavaScrip開發語言

2023-05-30 15:11:16

JavaScrip開發功能

2023-08-27 16:19:09

JavaScript編程語言

2025-02-25 11:12:53

2025-04-07 07:30:00

JavaScript前端

2023-06-14 15:51:48

JavaScript

2022-09-02 23:08:04

JavaScript技巧開發

2022-10-09 18:52:11

JavaScript開發數組

2024-09-04 14:00:16

2022-10-08 07:54:24

JavaScriptAPI代碼

2024-07-26 00:00:05

JavaScript單行技巧

2022-12-28 17:20:03

JavaScript解決方案

2024-11-14 08:35:50

JavaScript管道操作符

2021-04-21 07:53:12

JavaScript單行程序

2021-04-19 11:30:06

Java開發程序
點贊
收藏

51CTO技術棧公眾號

黄频视频在线观看| 久久综合久中文字幕青草 | 天天久久综合| 8x8x8国产精品| 欧美激情亚洲天堂| 色视频在线观看| 久久一区二区三区超碰国产精品| 中文字幕亚洲一区在线观看 | 9l国产精品久久久久麻豆| 26uuu国产精品视频| 99久久精品免费视频| 色999久久久精品人人澡69 | 久久亚洲国产精品| 中文字幕5566| **国产精品| 无码av免费一区二区三区试看 | 日韩欧美国产网站| 波多野结衣激情| 亚洲av成人精品毛片| 久久99久久精品| 91成品人片a无限观看| 亚洲一级理论片| 欧美a一欧美| 欧美日韩一区二区三区高清| 男人添女人下部高潮视频在观看 | 精品少妇v888av| av在线网站观看| jazzjazz国产精品久久| 欧美日韩国产中文| 国产精品免费入口| 精精国产xxxx视频在线中文版| 国产日韩欧美高清| 精品不卡一区二区三区| 一区二区国产欧美| 久久精品麻豆| 91成人免费观看网站| 中文字幕手机在线观看| 日韩影院二区| 亚洲女人天堂av| 亚洲视频 中文字幕| 中文幕av一区二区三区佐山爱| 日本韩国欧美在线| 国产激情一区二区三区在线观看 | av在线亚洲男人的天堂| 国产精品久久久久7777婷婷| 91视频免费在观看| 人人网欧美视频| 日韩午夜小视频| 亚洲最大天堂网| 日韩在线观看不卡| 一本到三区不卡视频| 亚洲不卡中文字幕无码| 福利成人导航| 亚洲一区自拍偷拍| www.夜夜爱| 成人在线app| ㊣最新国产の精品bt伙计久久| 日韩欧美99| 青春草在线观看| 不卡一区二区三区四区| 高清av免费一区中文字幕| 精品人妻一区二区三区蜜桃 | wwwav在线播放| 国产一区二区三区蝌蚪| 成人黄色网免费| 一区二区三区精彩视频| 国模大尺度一区二区三区| 成人午夜一级二级三级| 国产免费的av| 国产精品538一区二区在线| 1卡2卡3卡精品视频| 国产精品污视频| 国产麻豆精品一区二区| 亚洲综合在线播放| 免费a级片在线观看| 99视频精品在线| 日本成人看片网址| 日本中文字幕伦在线观看| 亚洲私人黄色宅男| 国产精品视频二| 男人的天堂免费在线视频| 日韩欧美黄色动漫| 牛夜精品久久久久久久| 亚洲三级电影| 精品国产乱码久久| 国产全是老熟女太爽了| 日韩一区二区三区免费播放| 久久久久www| 久久精品国产亚洲av无码娇色| 一本久道久久久| 国产999在线观看| 91中文字幕在线播放| 国产乱子伦视频一区二区三区 | 亚洲欧洲成人自拍| 成人av在线不卡| 午夜欧美巨大性欧美巨大| 欧美中文字幕亚洲一区二区va在线 | 成人激情av| 精品av中文字幕在线毛片| 中文字幕亚洲欧美在线不卡| 国产成人永久免费视频| 都市激情综合| 91麻豆精品国产综合久久久久久| 五月开心播播网| 97精品国产| 国内精品400部情侣激情| 自拍偷拍精品视频| 懂色av一区二区三区免费观看 | 邻居大乳一区二区三区| ㊣最新国产の精品bt伙计久久| 无码人妻精品一区二区三区在线| 久久国内精品| 亚洲精品久久久一区二区三区| 日韩精品电影一区二区三区| 1024成人| 成人免费午夜电影| 免费在线黄色电影| 亚洲自拍偷拍麻豆| 91精品无人成人www| 久久丝袜视频| 久色乳综合思思在线视频| 自拍偷拍欧美亚洲| 国产麻豆9l精品三级站| 亚洲mv在线看| 蜜桃麻豆av在线| 欧美一区二区三区电影| 一级片久久久久| 国产精品久久久久9999高清| 99视频在线播放| 午夜激情视频在线| 91黄色小视频| 野花社区视频在线观看| 在线精品福利| 3d精品h动漫啪啪一区二区| 在线免费观看黄色网址| 日韩欧美精品中文字幕| 国产精品一级黄片| 精品91视频| 成人区精品一区二区| 日本暖暖在线视频| 精品视频999| www.久久国产| 免播放器亚洲| 乱一区二区三区在线播放| 美女日批视频在线观看| 日韩欧美国产一区二区三区| 强制高潮抽搐sm调教高h| 蜜臀av国产精品久久久久| 日韩jizzz| 91精品国产66| 在线视频欧美日韩精品| 人人妻人人爽人人澡人人精品| 91麻豆产精品久久久久久| 国产欧美精品aaaaaa片| 天堂精品久久久久| 欧美xxxx做受欧美| 国产色视频在线| 亚洲精品日韩一| 亚洲综合中文网| 很黄很黄激情成人| 国产九区一区在线| h片视频在线观看| 亚洲精品动漫100p| 精品国产午夜福利| 久久精品人人爽人人爽| 人妻无码视频一区二区三区| 国产成人手机高清在线观看网站| 国产成一区二区| 国产九色在线| 欧美日韩免费高清一区色橹橹| 国产精品夜夜夜爽阿娇| 国产精品综合网| 国产精品69久久久| 美女视频免费精品| 国产成人+综合亚洲+天堂| √新版天堂资源在线资源| 51久久夜色精品国产麻豆| 91porn在线视频| 99久久夜色精品国产网站| 激情五月开心婷婷| 日韩精品第一区| 99www免费人成精品| 欧亚av在线| 中文字幕av一区中文字幕天堂 | 国模一区二区| 国产午夜精品美女视频明星a级| 日韩在线中文视频| 91精品国产成人| 中文字幕日韩精品无码内射| 91视频青青草| 亚洲男同gay网站| 黑丝美女一区二区| 成人毛片老司机大片| 国产精品视频一二三区| 91在线小视频| 国产一级特黄a大片99| 亚洲妇女成熟| 久久久精品久久久久| 神马午夜电影一区二区三区在线观看 | 欧美午夜影院在线视频| 你懂得视频在线观看| 福利一区二区在线观看| 国产九九在线视频| 欧美区国产区| 亚洲精品国产一区| 精品国产一区二区三区不卡蜜臂| 国产精品久久久久久久天堂| 日本一级理论片在线大全| 精品小视频在线| a毛片在线免费观看| 日本二三区不卡| 国产网址在线观看| 中文字幕亚洲区| 欧美色图亚洲激情| 丁香激情综合国产| 97超碰成人在线| 久久精品日产第一区二区| 国产a级黄色大片| 久久免费av| 欧美激情第六页| 最新国产精品精品视频| 国产欧美精品久久久| 免费成人在线电影| 久久久久久久久久久免费| 色的视频在线免费看| 亚洲欧美日韩中文视频| 日韩中文字幕免费观看| 91精品国产综合久久福利| 国产情侣呻吟对白高潮| 欧美性猛交xxxx免费看久久久| 国产亚洲小视频| 亚洲桃色在线一区| 国产极品美女在线| 国产精品国模大尺度视频| 久久亚洲AV无码专区成人国产| proumb性欧美在线观看| 麻豆免费在线观看视频| 国产美女久久久久| 午夜视频在线网站| 久久成人av少妇免费| 亚洲黄色小视频在线观看| 久久免费国产| 国产免费视频传媒| 久久亚洲风情| av在线无限看| 免费在线观看精品| 9久久婷婷国产综合精品性色 | 欧美亚洲激情| 茄子视频成人在线观看| 中文字幕中文字幕精品| 久久精精品视频| 欧美黑白配在线| 久久综合给合久久狠狠色| 欧美理伦片在线播放| 精品在线不卡| 四虎5151久久欧美毛片| 国产日韩欧美在线观看| 麻豆成全视频免费观看在线看| 国内精品视频一区| 欧美v亚洲v| 久久久久久国产精品三级玉女聊斋 | 国产一区二区在线免费观看| 欧美又黄又嫩大片a级| 美女视频第一区二区三区免费观看网站| 丝袜老师办公室里做好紧好爽 | 国内精品视频久久| 蜜桃av.网站在线观看| 国产成人在线一区二区| 草民电影神马电影一区二区| 国产精品久久久久福利| 亚洲高清影院| 亚洲在线视频观看| www.成人在线.com| 国语精品中文字幕| 亚欧洲精品视频在线观看| 天天人人精品| 国产精品精品| 永久免费网站视频在线观看| 在线观看视频日韩| 欧美 日韩精品| 日韩综合小视频| 一级片视频免费观看| 国内精品写真在线观看| 69亚洲乱人伦| 久久久久久久久久久久久女国产乱| 日韩av在线看免费观看| 亚洲视频网在线直播| 免费毛片在线播放免费| 亚洲伊人伊色伊影伊综合网| 欧美a视频在线观看| 欧美日韩高清在线播放| 熟妇高潮一区二区高潮| 亚洲欧美视频在线| 欧美激情二区| 欧美激情性做爰免费视频| 蜜桃视频在线观看播放| 国产欧美va欧美va香蕉在线| 中文字幕日韩高清在线| 欧美lavv| 韩日视频一区| 91看片就是不一样| 国产一区二区三区免费在线观看| 国产伦精品一区三区精东| 久久久久久毛片| 九九在线观看视频| 色94色欧美sute亚洲13| av免费观看网址| 国产一区二区三区丝袜| 在线观看h网| 国产精品永久免费视频| 成功精品影院| 午夜精品短视频| 国产精品毛片| 91蝌蚪视频在线| 国产农村妇女精品| 久久精品国产亚洲av无码娇色| 在线观看国产日韩| 涩爱av在线播放一区二区| 久久精品人人做人人爽| 美女写真久久影院| 国产精品二区三区| 999精品色在线播放| 男人透女人免费视频| 懂色av一区二区三区免费看| 亚洲色图27p| 色综合久久88色综合天天6| 这里只有精品国产| 亚洲一区二区久久| 毛片在线网站| 国语精品中文字幕| 国内精品福利| 久久发布国产伦子伦精品| 欧美激情一区在线| 欧美精品亚洲精品日韩精品| 精品久久一区二区| 精品国产丝袜高跟鞋| 国产日韩精品视频| 蜜桃一区二区三区| 无码人妻丰满熟妇区96| 成人午夜激情在线| 亚洲av鲁丝一区二区三区| 91精品黄色片免费大全| freemovies性欧美| 国产福利精品av综合导导航| 亚洲v天堂v手机在线| av在线免费观看国产| 国产一区二区视频在线播放| 黄色av片三级三级三级免费看| 欧美伊人久久久久久午夜久久久久| 少妇一级淫片免费看| 久久久中文字幕| 国产毛片精品| 欧美色图12p| 国产91在线免费| 男人的天堂亚洲在线| 亚洲熟女乱综合一区二区三区| 亚洲精品ww久久久久久p站| 国产精品高清无码| 色偷偷9999www| 最新版天堂资源在线| 91精品一久久香蕉国产线看观看 | 精品美女被调教视频大全网站| 在线视频1区2区| 欧美亚洲国产一区在线观看网站| 久久一区二区精品| 婷婷成人综合| 欧美,日韩,国产在线| 国产乱码精品一区二区三区忘忧草| √天堂中文官网8在线| 69堂国产成人免费视频| 欧美人与性动交α欧美精品济南到 | 涩视频在线观看| 亚洲自拍偷拍图区| 国产激情久久久久久熟女老人av| 欧美激情一区二区久久久| 亚洲精品黑牛一区二区三区| 亚洲熟妇无码另类久久久| 99精品视频在线播放观看| 国语对白做受69按摩| 日韩视频亚洲视频| 激情五月综合婷婷| 男人天堂新网址| 99久久综合精品| 91成人一区二区三区| 欧美激情国产高清| 九一亚洲精品| 午夜免费福利视频在线观看| 亚洲制服丝袜av| 无套内谢的新婚少妇国语播放| 欧美亚洲视频在线观看| 不卡一区2区| 中文字幕第36页| 亚洲一区二区视频| 免费黄色片在线观看| 91在线观看免费观看| 亚洲大胆av| 国产三级在线观看完整版| 日韩网站在线看片你懂的| 日本一道高清亚洲日美韩| 18视频在线观看娇喘|