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

為什么 JS 中的對象字面量很酷

開發 前端
JS 是一種基于原型的語言,因此一切都是對象。在對象創建,配置和訪問原型時,必須提供一種易于構造的語言。

在 ES6 之前,JS 中的對象字面量(也稱為對象初始化器)是非常基礎的。可以定義兩種類型的屬性:

  • 鍵值對 {name1: value1}
  • 獲取器 { get name(){..} } 和 設置器 { set name(val){..}} 的計算屬性值
  1. var myObject = { 
  2.   myString: 'value 1', 
  3.   get myNumber() { 
  4.     return this._myNumber; 
  5.   }, 
  6.   set myNumber(value) { 
  7.     this._myNumber = Number(value); 
  8.   }, 
  9. }; 
  10. myObject.myString; // => 'value 1' 
  11. myObject.myNumber = '15'
  12. myObject.myNumber; // => 15 

JS 是一種基于原型的語言,因此一切都是對象。在對象創建,配置和訪問原型時,必須提供一種易于構造的語言。

定義一個對象并設置它的原型是一個常見的任務。最好的方式是直接在對象字面量使用一條語句來設置原型。

不幸的是,字面量的局限性不允許用一個簡單的解決方案來實現這一點。必須結合使用object.create() 和對象字面量來設置原型。

  1. var myProto = { 
  2.   propertyExists: function(name) { 
  3.     return name in this; 
  4.   } 
  5. }; 
  6.  
  7. var myNumbers = Object.create(myProto); 
  8. myNumbers['arrat'] = [1, 6, 7]; 
  9. myNumbers.propertyExists('array'); // => true 
  10. myNumbers.propertyExists('collection'); // => false 

我認為這種解決方案不夠靈活。JS 是基于原型的,為什么要用原型創建對象那么麻煩?

幸運的是,JS 也在慢慢完善。JS 中很多令人沮喪的問題都是逐步解決的。

本文演示了 ES 6 如何解決上述問題,并使用額外的功能改進對象字面量。

  • 在對象構造上設置原型
  • 方法的聲明
  • super 調用
  • 計算屬性名

JS

1. 在對象構造上設置原型

如你所知,訪問現有對象原型的一種方法是使用 getter 屬性 __proto__:

  1. var myObject = { 
  2.   name: 'Hello World!', 
  3. }; 
  4. myObject.__proto__; // => {} 
  5. myObject.__proto__.isPrototypeOf(myObject); // => true 

myObject.__ proto__ 返回 myObject 的原型對象。

請注意,不建議將 object.__ proto__ 用作 getter/setter。替代方法應考慮使用Object.getPrototypeOf() 和 Object.setPrototypeOf()。

ES6允許使用__proto__作為屬性名,并在 {__proto__:protoObject}中設置原型。

接著,咱們使用 __proto__ 屬性進行對象初始化,并優化上面的代碼:

  1. var myProto = { 
  2.   propertyExists: function(name) { 
  3.     return name in this; 
  4.   }, 
  5. }; 
  6. var myNumbers = { 
  7.   __proto__: myProto, 
  8.   array: [1, 6, 7], 
  9. }; 
  10. myNumbers.propertyExists('array'); // => true 
  11. myNumbers.propertyExists('collection'); // => false 

myNumbers 對象是使用特殊屬性名 proto 與創建原型 myProto,這次咱們使用一條語句就創建,沒有像上面還需要 object.create() 這樣的附加函數。

如你所看,使用 __proto__ 進行編碼很簡單,我一直喜歡簡單明了的解決方案。

說點脫離主題。我覺得奇怪的是,簡單靈活的解決方案需要大量的工作和設計。如果解決方案很簡單,你可能會認為設計起來很容易。但是反之亦然:

  • 要使它簡單明了是很復雜的
  • 把它變得復雜和難以理解是很容易的

如果某些東西看起來太復雜或難以使用,則可能還需要進一步的完善。

你對簡單性有何看法?(請在下面隨意寫評論)

2. proto 用法的特殊情況

即使__proto__看起來很簡單,您也應該注意一些特殊情況。

JS

 

在對象字面量中只能使用__proto__一次,否則 JS 會報錯:

  1. var object = { 
  2.   __proto__: { 
  3.     toString: function() { 
  4.       return '[object Numbers]' 
  5.     } 
  6.   }, 
  7.   numbers: [1, 5, 89], 
  8.   __proto__: { 
  9.     toString: function() { 
  10.       return '[object ArrayOfNumbers]' 
  11.     } 
  12.   } 
  13. }; 

上面示例中的對象字面量中使用兩次__proto__屬性,這是不允許的。在這種情況下,將在會拋出錯誤:SyntaxError: Duplicate __proto__ fields are not allowed in object literals 。

JS 約束只能用一個對象或 null 作為 __proto__ 屬性的值。任何使用原始類型(字符串,數字,布爾值)或 undefined 類型都將被忽略,并且不會更改對象的原型。

  1. var objUndefined = { 
  2.   __proto__: undefined, 
  3. }; 
  4. Object.getPrototypeOf(objUndefined); // => {} 
  5. var objNumber = { 
  6.   __proto__: 15, 
  7. }; 
  8. Object.getPrototypeOf(objNumber); // => {} 

對象字面量使用 undefined 和 數字 15 來設置 __proto__ 值。因為僅允許將對象或 null 用作原型,所以__proto__值將被忽略,但 objUndefined 和 objNumber 仍具有其默認原型:純 JS 對象 {}, 。

當然,嘗試使用基本類型來設置對象的原型也會很奇怪。

當對象字面具有計算結果為'proto'的字符串時 {['__proto__']:protoObj },也要小心。以這種方式創建的屬性不會更改對象的原型,而只是使用鍵 '__proto__' 創建一個擁有的屬性

3. 簡寫方法定義

可以使用較短的語法在對象常量中聲明方法,以省略 function 關鍵字和 : 冒號的方式。這被稱為簡寫方法定義。

接著,咱們使用簡寫的方法來定義一些方法:

  1. var collection = { 
  2.   items: [], 
  3.   add(item) { 
  4.     this.items.push(item); 
  5.   }, 
  6.   get(index) { 
  7.     return this.items[index]; 
  8.   }, 
  9. }; 
  10. collection.add(15); 
  11. collection.add(3); 
  12. collection.get(0); // => 15 

一個很好的好處是,以這種方式聲明的方法被命名為函數,這對于調試目的很有用。從上面示例中執行 collection.add.name 會返回函數名稱 “add”。

(1) super 的使用

JS 一個有趣的改進是使用 super 關鍵字作為從原型鏈訪問繼承的屬性的能力。看下面的例子:

  1. var calc = { 
  2.   numbers: null, 
  3.   sumElements() { 
  4.     return this.numbers.reduce(function(a, b) { 
  5.       return a + b; 
  6.     }); 
  7.   }, 
  8. }; 
  9. var numbers = { 
  10.   __proto__: calc, 
  11.   numbers: [4, 6, 7], 
  12.   sumElements() { 
  13.     if (this.numbers == null || this.numbers.length === 0) { 
  14.       return 0; 
  15.     } 
  16.     return super.sumElements(); 
  17.   }, 
  18. }; 
  19. numbers.sumElements(); // => 17 

calc 是 numbers 對象的原型。在 numbers 的 sumElements方法中,可以使用 super關鍵字從原型訪問方法:super.sumElements()

最終,super 是從對象原型鏈訪問繼承的屬性的快捷方式。

在前面的示例中,可以嘗試直接執行 calc.sumElements() 來調用原型,會報錯。然而,super.sumElements() 可以正確調用,因為它訪問對象的原型鏈。并確保原型中的 sumElements() 方法使用 this.numbers 正確訪問數組。

super 存在清楚地表明繼承的屬性將被使用。

(2) super 使用限制

super 只能在對象字面量的簡寫方法定義內使用。

如果試圖從普通方法聲明{ name: function(){} } 訪問它,JS 將拋出一個錯誤:

  1. var calc = { 
  2.   numbers: null, 
  3.   sumElements() { 
  4.     return this.numbers.reduce(function(a, b) { 
  5.       return a + b; 
  6.     }); 
  7.   }, 
  8. }; 
  9. var numbers = { 
  10.   __proto__: calc, 
  11.   numbers: [4, 6, 7], 
  12.   sumElements: function() { 
  13.     if (this.numbers == null || this.numbers.length === 0) { 
  14.       return 0; 
  15.     } 
  16.     return super.sumElements(); 
  17.   }, 
  18. }; 
  19. // Throws SyntaxError: 'super' keyword unexpected here 
  20. numbers.sumElements(); 

方法 sumElements 被定義為一個屬性: sumElements: function(){…}。因為super 只能在簡寫方法中使用,所以在這種情況下調用它會拋出 SyntaxError: 'super' keyword unexpected here。

此限制在很大程度上不影響對象字面量的聲明方式。由于語法較短,因此通常最好使用簡寫方法定義。

4. 計算屬性名

在 ES6 之前,對象初始化使用的是字面量的形式,通常是靜態字符串。要創建具有計算名稱的屬性,就必須使用屬性訪問器。

  1. function prefix(prefStr, name) { 
  2.   return prefStr + '_' + name; 
  3. var object = {}; 
  4. object[prefix('number', 'pi')] = 3.14; 
  5. object[prefix('bool', 'false')] = false; 
  6. object; // => { number_pi: 3.14, bool_false: false } 

當然,這種定義屬性的方式是令人愉快的。

接著使用簡寫方式來改完上面的例子:

  1. function prefix(prefStr, name) { 
  2.   return prefStr + '_' + name; 
  3. var object = { 
  4.   [prefix('number', 'pi')]: 3.14, 
  5.   [prefix('bool', 'false')]: false, 
  6. }; 
  7. object; // => { number_pi: 3.14, bool_false: false } 

[prefix('number','pi')]通過計算 prefix('number', 'pi') 表達式(即'number_pi')來設置屬性名稱。

相應地,[prefix('bool', 'false')] 將第二個屬性名稱設置為'bool_false'。

(1) symbol 作為屬性名稱

symbol 也可以用作計算的屬性名稱。只要確保將它們包括在方括號中即可:{[Symbol('name')]:'Prop value'}

例如,用特殊屬性 Symbol.iterator 并迭代對象自身的屬性名稱。如下示例所示:

  1. var object = { 
  2.    number1: 14, 
  3.    number2: 15, 
  4.    string1: 'hello', 
  5.    string2: 'world', 
  6.    [Symbol.iterator]: function *() { 
  7.      var own = Object.getOwnPropertyNames(this), 
  8.        prop; 
  9.      while(prop = own.pop()) { 
  10.        yield prop; 
  11.      } 
  12.    } 
  13. [...object]; // => ['number1', 'number2', 'string1', 'string2'] 

[Symbol.iterator]: function *() { } 定義一個屬性,該屬性用于迭代對象的自有屬性。展開運算符 [... object] 使用迭代器并返回自有的屬性的列表

(2) 剩余和展開屬性

剩余屬性允許從對象中收集在分配銷毀后剩下的屬性。

下面的示例在解構對象之后收集剩余的屬性:

  1. var object = { 
  2.   propA: 1, 
  3.   propB: 2, 
  4.   propC: 3, 
  5. }; 
  6. let { propA, ...restObject } = object; 
  7. propA; // => 1 
  8. restObject; // => { propB: 2, propC: 3 } 

展開屬性允許將源對象的自有屬性復制到對象文字面量中。在此示例中,對象字面量從源對象收集到對象的其他屬性:

  1. var source = { 
  2.   propB: 2, 
  3.   propC: 3, 
  4. }; 
  5. var object = { 
  6.   propA: 1, 
  7.   ...source, 
  8. }; 
  9. object; // => { propA: 1, propB: 2, propC: 3 } 

6. 總結

在 ES6 中,即使是作為對象字面量的相對較小的結構也得到了相當大的改進。

可以使用__proto__ 屬性名稱直接從初始化器設置對象的原型。這比使用 Object.create() 更容易。

請注意,__proto__ 是 ES6 標準附件B的一部分,不鼓勵使用。該附件實現對于瀏覽器是必需的,但對于其他環境是可選的。NodeJS 4、5和6支持此功能。

現在方法聲明的形式更短,因此不必輸入 function 關鍵字。在簡化方法中,可以使用 super關 鍵字,該關鍵字可以輕松訪問對象原型鏈中的繼承屬性。

如果屬性名稱是在運行時計算的,那么現在您可以使用計算的屬性名稱[expression]來初始化對象。

責任編輯:趙寧寧 來源: 大遷世界
相關推薦

2020-04-02 09:01:54

JSES 6開發

2021-10-09 07:10:30

Go字面量組合

2018-04-10 13:40:14

Kubernetes容器服務器

2020-12-18 11:35:22

TypeScript語言Java

2023-09-20 00:02:33

C++14二進制字面量

2021-05-28 08:01:00

JS原型概念

2023-11-07 15:11:46

Kafka技巧

2009-07-06 14:42:24

Visual Basi

2022-06-08 08:01:28

模板字面量類型

2020-08-02 22:54:04

Python編程語言開發

2020-08-03 07:50:56

存儲對象存儲

2022-05-10 11:32:12

加密貨幣比特幣供應限制

2022-05-10 14:17:26

加密貨幣供應量以太坊

2012-05-02 15:56:20

PHP

2019-09-24 10:17:14

2015-02-11 10:22:25

對象存儲云共享S3存儲

2023-09-19 08:03:01

JavaScriptevery()

2011-04-12 13:53:25

ASP.NET MVCjQuery

2020-11-10 22:59:52

COPR軟件倉庫

2024-08-27 10:54:20

JSON函數屬性
點贊
收藏

51CTO技術棧公眾號

亚洲一区二区三区在线免费观看| 伊人伊成久久人综合网站| 特级西西444| 成人高潮片免费视频| 精品9999| 日韩精品中文字幕久久臀| 国产一区亚洲二区三区| 亚洲s色大片| 国产久卡久卡久卡久卡视频精品| 久久久久久久久久久久av| 黑丝av在线播放| 天堂久久午夜av| 亚洲人午夜精品天堂一二香蕉| 99久久99| 91青青草视频| 综合天堂av久久久久久久| 日韩成人中文电影| 精品久久久99| 国产不卡人人| 国产精品乱码人人做人人爱| 成人综合电影| 人人妻人人爽人人澡人人精品| 91精品一区国产高清在线gif| 亚洲第一精品自拍| 日本高清久久久| 成年人黄色大片在线| 国产精品视频第一区| 国产a一区二区| 中文无码av一区二区三区| 亚洲性图久久| 久久精品91久久香蕉加勒比| 中文字幕丰满乱子伦无码专区| 99视频这里有精品| 91久久国产综合久久| 蜜臀av色欲a片无码精品一区| 国产黄色片在线观看| 粉嫩av一区二区三区在线播放| 国产精品午夜视频| 99久热在线精品996热是什么| 91精品国产麻豆国产在线观看 | 国产一区二区三区不卡在线观看| 青青青国产精品一区二区| 久久久久国产精品夜夜夜夜夜| 精品视频97| 日韩成人久久久| 白丝校花扒腿让我c| 亚洲综合伊人| 欧洲av在线精品| 国产成人a亚洲精v品无码| 麻豆蜜桃在线| 亚洲美女免费视频| 最新精品视频| 777电影在线观看| 久久婷婷一区二区三区| 国产欧美日韩一区二区三区| 国产精品人妻一区二区三区| 奇米888四色在线精品| 日韩免费黄色av| 中文字幕在线观看视频网站| 在线观看日韩av电影| 欧美日韩爱爱视频| 老湿机69福利| 永久亚洲成a人片777777| 北条麻妃久久精品| 老司机成人免费视频| 欧美a级片视频| 日韩视频在线一区| 国产三级精品三级观看| 无需播放器亚洲| 日韩最新在线视频| 久久精品黄色片| 伊人久久大香线| 欧美高清激情视频| 久久精品视频日本| 亚洲影院免费| 亚洲成人高清| 国产精品久久夜| 亚洲一区二区三区色| 淫片在线观看| 国产精品久久久久久久午夜片| 亚洲一区尤物| a级在线观看| 亚洲综合视频在线| 香港三级韩国三级日本三级| 自拍偷拍欧美视频| 欧美图片一区二区三区| 九九久久久久久| 日本免费一区二区视频| 亚洲大胆人体在线| 精品国产av色一区二区深夜久久| 中日韩免视频上线全都免费| 亚洲欧洲黄色网| 欧美性猛交xxxx乱大交少妇| 亚洲国产成人精品女人| 韩国视频理论视频久久| 亚洲欧美日韩激情| 激情另类小说区图片区视频区| 91久久精品一区二区别| 天堂中文在线官网| 国产精品午夜春色av| 国产精品88久久久久久妇女| 蜜桃在线视频| 欧美日韩一区中文字幕| 影音先锋资源av| 视频国产一区| 久热99视频在线观看| 欧美不卡视频在线观看| 日韩电影在线看| 亚洲影院色无极综合| 日本成人一区二区三区| 成 人片 黄 色 大 片| 精品无码三级在线观看视频| 国产精品一国产精品最新章节| 免费福利在线视频| 亚洲欧美日韩在线不卡| 99久久久无码国产精品6| 粉嫩av国产一区二区三区| 日韩激情在线视频| 91成人福利视频| 久久国产免费| 成人精品水蜜桃| 国产视频第一区| 亚洲一区二区视频| 日本黄大片一区二区三区| 欧美三级午夜理伦三级小说| 久久精品国产清自在天天线| 69视频免费在线观看| 国产精品一品二品| 翔田千里亚洲一二三区| 亚洲小少妇裸体bbw| 日韩视频中午一区| 天堂av免费在线| 久久精品一区二区国产| 国产伦视频一区二区三区| 免费大片在线观看www| 色偷偷一区二区三区| 在线观看成人动漫| 欧美va天堂在线| 国产精品视频在线播放| 免费国产在线观看| 欧美三级xxx| 亚洲妇女无套内射精| 91麻豆精品国产91久久久平台 | wwwwxxxx国产| 91久久黄色| 99久久久精品免费观看国产| 精品麻豆一区二区三区| 精品视频999| 天天躁日日躁aaaa视频| 国产精品日韩精品欧美精品| 国产高清在线一区| 黄色小说在线播放| 精品日韩一区二区三区免费视频| 在线看的片片片免费| 麻豆精品精品国产自在97香蕉| 蜜桃成人免费视频| 欧美调教sm| 亚洲第一中文字幕| 日本学生初尝黑人巨免费视频| 国产精品一区二区久激情瑜伽| 精品国产无码在线| 国产亚洲久久| 欧美成人精品一区| www.色呦呦| 亚洲精品视频自拍| 中文字幕无人区二| 精品电影一区| 久久亚洲高清| 美女18一级毛片一品久道久久综合| 日韩精品视频在线播放| 天天干天天干天天操| 久久综合九色综合97婷婷| 欧美在线观看成人| 国产精品嫩模av在线| 国产精品精品视频一区二区三区| av电影在线网| 欧美精品在线观看播放| 天天天天天天天天操| 国产不卡视频在线观看| 无码熟妇人妻av在线电影| 高清日韩欧美| 91成人在线视频| 天堂在线中文字幕| 91久久国产综合久久| 永久免费看mv网站入口| 国产成人午夜精品影院观看视频| 国产亚洲黄色片| 尤物tv在线精品| 国产精品视频在线观看| 免费毛片在线看片免费丝瓜视频| 精品福利一区二区三区 | 欧美日韩午夜剧场| 色屁屁草草影院ccyy.com| 黄一区二区三区| 欧美无砖专区免费| 国产精品最新| 亚洲一区二区三区毛片| 蜜桃视频m3u8在线观看| 日韩在线欧美在线国产在线| www.xxxx国产| 色综合久久88色综合天天6 | 国产精品国产| 国产精品成人aaaaa网站| 宅男网站在线免费观看| 亚洲女成人图区| 国产精品久久久久久久成人午夜| 性欧美疯狂xxxxbbbb| av免费播放网站| 福利一区福利二区| 爆乳熟妇一区二区三区霸乳| 欧美欧美全黄| 日产国产精品精品a∨| 伊人www22综合色| 国产精品白嫩初高中害羞小美女 | 亚洲成人网久久久| 亚洲一区二区视频在线播放| 亚洲mv在线观看| 顶级黑人搡bbw搡bbbb搡| 91在线免费播放| 久久久久久综合网| 爽好多水快深点欧美视频| www.国产二区| 日韩免费在线| 久久波多野结衣| 国产精品亚洲综合在线观看| 国产精品69久久| av在线小说| 美女福利视频一区| 在线日本视频| 亚洲免费精彩视频| 色偷偷在线观看| 欧美一区二区视频在线观看2020 | 欧美色图免费看| 成年免费在线观看| 亚洲一区二区三区激情| 手机在线免费看毛片| 国产精品热久久久久夜色精品三区| 黄色av网址在线观看| 国产高清一区日本| 日本中文字幕二区| 久久国产精品色婷婷| 韩国日本美国免费毛片| 国产视频一区三区| 国产原创中文在线观看| 韩日视频一区| 4444在线观看| 中出一区二区| 国产精品h视频| 天天综合一区| 亚洲午夜精品久久久久久浪潮| 国内亚洲精品| 欧美一区二区三区电影在线观看| 亲子伦视频一区二区三区| 国产日韩一区二区三区| 久久精品色播| 精品欧美一区二区精品久久| 国产成人夜色高潮福利影视| 国产99在线免费| av不卡一区| 国产伦精品一区二区三区在线| 亚洲一区二区三区四区电影| 99九九视频| 国产精品男女| 麻豆av一区二区三区| 香蕉久久夜色精品国产使用方法| 久久综合伊人77777麻豆| 一区二区小说| 色综合久久av| 水蜜桃精品av一区二区| 好色先生视频污| 欧美成人tv| 国产精品va在线观看无码| 激情久久综合| 99精品人妻少妇一区二区| 久久九九电影| 亚洲综合色在线观看| 国产精品一色哟哟哟| 中国一级特黄录像播放| 91免费观看国产| www.黄色在线| 亚洲色图制服诱惑| 中文字幕第28页| 欧美日韩中文字幕| 中文区中文字幕免费看| 欧美一区二区三区男人的天堂| 丰满熟妇乱又伦| 日韩精品亚洲精品| 香蕉视频网站在线观看| 久操成人在线视频| 伊人色综合一区二区三区影院视频| 国产精品福利在线观看网址| av在线成人| 久久艹中文字幕| 欧美1级片网站| 免费超爽大片黄| 日韩va欧美va亚洲va久久| 日本高清免费在线视频| 94色蜜桃网一区二区三区| 四季av中文字幕| 亚洲自拍与偷拍| 国产精品熟女视频| 日韩一区二区三区在线观看| 少妇性bbb搡bbb爽爽爽欧美| 色偷偷av一区二区三区乱| 黄污视频在线观看| 国产精品久久久精品| 中文字幕区一区二区三| 日本不卡一区二区三区视频| 欧美黄色精品| 黑鬼大战白妞高潮喷白浆| 国产精品自拍一区| 欧美 日韩 国产 成人 在线观看 | 亚洲影院在线| 性久久久久久久久久久久久久| 91一区一区三区| 欧美亚洲日本在线| 在线观看日产精品| 男人天堂综合网| 久久精品电影一区二区| 在线看的毛片| 99久久无色码| 999国产精品永久免费视频app| 春日野结衣av| 福利电影一区二区三区| 国产美女高潮视频| 91黄视频在线| 天天干天天爱天天操| 久久97精品久久久久久久不卡| 中韩乱幕日产无线码一区| 精品视频一区二区| 国产精品va| 亚洲一区二区中文字幕在线观看| 久久久久久久一区| 亚洲日本视频在线观看| 精品久久一区二区三区| 国产一二三区在线观看| 国产精品自拍视频| 精品国产乱码久久久久久果冻传媒| 国产a级片网站| 国产麻豆日韩欧美久久| 色婷婷粉嫩av| 欧美性xxxxxxxx| 四虎精品在永久在线观看 | 在线精品视频一区二区三四| 亚洲欧美日韩动漫| 久久久久国产精品免费网站| 视频亚洲一区二区| 亚洲成年人专区| 久久国产剧场电影| 亚洲欧美精品久久| 欧美美女一区二区| 亚乱亚乱亚洲乱妇| 成人激情免费在线| 99国产精品免费视频观看| 中文字幕第100页| 国产精品久久久久久户外露出| 中文字幕av影视| 亚洲午夜av电影| 美女色狠狠久久| 视频一区二区在线| 免费的成人av| 91香蕉视频污在线观看| 欧美日本一区二区| 欧美激情黑人| 亚洲va欧美va国产综合久久| 中文无码久久精品| 2018国产精品| 亚洲成a人v欧美综合天堂| 天天摸天天碰天天爽天天弄| 69视频在线播放| 欧美女优在线视频| 午夜两性免费视频| 亚洲欧美日韩中文字幕一区二区三区 | 国产又黄又爽又色| 亚洲人成在线观| 国产成人精选| 黄色影视在线观看| 不卡高清视频专区| 天天操中文字幕| 深夜成人在线观看| 视频二区欧美| 97成人在线免费视频| 国产欧美久久久精品影院| 91好色先生tv| 久久久久久久一| 精品在线播放| 国产福利在线免费| 亚洲综合免费观看高清完整版 | 欧美在线精品免播放器视频| 成人在线免费视频观看| a级大片免费看| 亚州成人在线电影| 成人av毛片| 波多野结衣成人在线| 午夜亚洲福利在线老司机| 亚洲欧美另类日本| 亚洲国产精品久久久久久| www.一区| www.xxx麻豆| 国产精品视频一二三区|