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

前端百題斬—賦值、淺拷貝、深拷貝大PK

開發 前端
淺拷貝指的就是循環遍歷對象一遍,將該對象上的屬性賦值到另一個對象上。在這個過程中屬性值為基本類型則拷貝的就是基本類型的值;若該值為引用類型,則拷貝的就是就是一個內存地址。

[[429471]]

寫該系列文章的初衷是“讓每位前端工程師掌握高頻知識點,為工作助力”。

相信老鐵們不管是在學習還是面試過程中,都會遇到賦值、淺拷貝、深拷貝,特別是淺拷貝和深拷貝,我記憶比較深刻的遇到這個問題有兩次:

一次系統寫出bug就是因為對深淺拷貝理解不清楚;

百度面試。

1 賦值

賦值指的就是將一個變量直接賦值給另一個變量,如下所示:

  1. const a1 = 10; 
  2. const a2 = a1; 
  3. console.log(a2); // 10 
  4.  
  5. const b1 = { 
  6.     m: 10, 
  7.     n: 20 
  8. }; 
  9.  
  10. const b2 = b1; 
  11. console.log(b2); // { m: 10, n: 20 } 

如上所示,賦值就是將一個值賦給另一個值,在賦值過程中要注意兩點:

  1. 對于基本類型賦值就是在棧內存中開辟一個新的存儲區域來存儲新的變量;
  2. 對于引用類型賦值,就是將該引用類型的地址,該地址指向堆中的同一值。

2 淺拷貝

2.1 基本實現

淺拷貝指的就是循環遍歷對象一遍,將該對象上的屬性賦值到另一個對象上。在這個過程中屬性值為基本類型則拷貝的就是基本類型的值;若該值為引用類型,則拷貝的就是就是一個內存地址。

  1. function clone(source) { 
  2.     if (!(typeof source === 'object' && source !== null)) { 
  3.         return source; 
  4.     } 
  5.     const target = {}; // 只考慮Object類型 
  6.     for (let [key, value] of Object.entries(source)) { 
  7.         target[key] = value; 
  8.     } 
  9.  
  10.     return target; 
  11.  
  12. const obj = { 
  13.     a: 10, 
  14.     b: { 
  15.         m: 20 
  16.     } 
  17. }; 
  18.  
  19. const cloneObj = clone(obj); 
  20.  
  21. cloneObj.a = 20; 
  22. cloneObj.b.m = 30; 
  23.  
  24. console.log(obj); // { a: 10, b: { m: 30 } } 
  25. console.log(cloneObj); // { a: 20, b: { m: 30 } } 

上述就是簡單的淺拷貝過程,可以看到淺拷貝就是將原始對象中的值遍歷一層,然后賦值給一個新的對象。在遍歷過程中可以獲取到一下信息:

  1. 遍歷到a屬性的時候,其是一個基本類型,所以會在棧內存中創建一個新的存儲區域來存儲變量。
  2. 遍歷到b屬性的時候,由于其為引用類型,其會在棧內存中存儲器堆地址,從而指向堆內存中的同一對象。
  3. 當通過淺拷貝創建的對象cloneObj中的a屬性和b.m屬性重新賦值,可以發現a屬性值不一樣,但b.m屬性值卻發生了變化,從而驗證了上述1、2兩條分析。

2.2 進階

既然本章我們講了淺拷貝,那么不得不了解Object.assign(),該方法就是一個淺拷貝的過程,用于對象的合并,將源對象(source)的所有可枚舉屬性,復制到目標對象(target)。

2.2.1 基礎

要實現一個函數首先應該了解一個函數,對于該方法的基本使用就不再贅述,下面主要講幾個注意點:

  1. 如果目標對象與源對象有同名屬性(或多個源對象有同名屬性),則后面的屬性會覆蓋前面的屬性;
  2. 如果只有一個參數,Object.assign會直接返回該參數。如果該參數不是對象,則會先轉為對象,然后再返回;(注意:由于undefined和null無法轉為對象,將它們作為參數會報錯)
  3. 非對象參數出現在源對象位置,這些參數會轉化為對象,如果無法轉成對象便跳過(所以undefined和null不會報錯)。(注意:字符串會以數組形式復制到目標對象,其它不會)
  4. 只復制源對象的自身屬性(不復制繼承屬性),也不復制不可枚舉的屬性;
  5. 屬性名為Symbol值的屬性也會被Object.assign復制。

2.2.2 實現

上面闡述了主要的注意點,下面我們就來實現一下Object.assign(),實現步驟如下所示:

  1. 對目標對象進行判斷,不能為null和undefined;
  2. 將目標轉換為對象(防止string、number等);
  3. 獲取后續源對象自身中的可枚舉對象(包含Symbol)復制到目標對象;
  4. 返回該處理好的目標對象;
  5. 利用Object.defineProperty()將該函數配置為不可枚舉的掛載到Object上。
  1. function ObjectAssign(target, ...sources) { 
  2.     // 對第一個參數進行判斷,不能為undefined和null 
  3.     if (target === undefined || target === null) { 
  4.         throw new TypeError('cannot convert first argument to object'); 
  5.     } 
  6.  
  7.     // 將第一個參數轉換為對象 
  8.     const targetObj = Object(target); 
  9.     // 將源對象(source)自身的所有可枚舉屬性復制到目標對象(target) 
  10.     for (let i = 0; i < sources.length; i++) { 
  11.         let source = sources[i]; 
  12.         // 對于undefined和null在源對象中不會報錯,會直接跳過 
  13.         if (source !== undefined && source !== null) { 
  14.             // 將源角色轉換成對象 
  15.             // 需要將源角色自身的可枚舉屬性(包含Symbol值的屬性)進行復制 
  16.             // Reflect.ownKeys(obj)  返回一個數組,包含對象自身的所有屬性,不管屬性名是Symbol還是字符串,也不管是否可枚舉 
  17.             const keysArrays = Reflect.ownKeys(Object(source)); 
  18.             for (let nextIndex = 0; nextIndex < keysArrays.length; nextIndex++) { 
  19.                 const nextKey = keysArrays[nextIndex]; 
  20.                 // 去除不可枚舉屬性 
  21.                 const desc = Object.getOwnPropertyDescriptor(source, nextKey); 
  22.                 if (desc !== undefined && desc.enumerable) { 
  23.                     targetObj[nextKey] = source[nextKey]; 
  24.                 } 
  25.             } 
  26.         } 
  27.     } 
  28.  
  29.     return targetObj; 
  30.  
  31. // 由于掛載到Object的assign是不可枚舉的,直接掛載上去是可枚舉的,所以采用這種方式 
  32. if (typeof Object.myAssign !== 'function') { 
  33.     Object.defineProperty(Object, "myAssign", { 
  34.         value: ObjectAssign, 
  35.         writable: true
  36.         enumerable: false
  37.         configurable: true 
  38.     }); 
  39.  
  40. const target = { 
  41.     a: 10 
  42. }; 
  43. const source1 = { 
  44.     b: 20, 
  45.     c: 30 
  46. }; 
  47. const source2 = { 
  48.     c: 40 
  49. }; 
  50.  
  51. console.log(Object.assign(target, source1, source2)); // { a: 10, b: 20, c: 40 } 
  52. console.log(Object.myAssign(target, source1, source2)); // { a: 10, b: 20, c: 40 } 

3 深拷貝

深拷貝其實就是淺拷貝的進階版,因為淺拷貝只循環遍歷了一層數據,對于引用類型拷貝的是對象的地址,但是深拷貝會進行多層的遍歷,將所有數據進行數據層面的拷貝。下面就利用三種方式實現深拷貝。(這篇文章寫得很好,大家可以一起看一下)

3.1 乞丐版

首先來看一下最簡單的深拷貝方式,就是利用JSON.stringify()和JSON.parse(),但是該方式其實是存在很多問題的:

  1. 不能正確處理正則表達式,其會變為空對象;
  2. 不能正確處理函數,其變為undefined;
  3. 不能正常輸出值為undefined的內容。
  1. function cloneDeep(source) { 
  2.     return JSON.parse(JSON.stringify(source)); 
  3.  
  4. const obj = { 
  5.     a: 10, 
  6.     b: undefined, 
  7.     c: /\w/g, 
  8.     d: function() { 
  9.         return true
  10.     } 
  11. }; 
  12. console.log(obj); // { a: 10, b: undefined, c: /\w/g, d: [Function: d] } 
  13. console.log(cloneDeep(obj)); // { a: 10, c: {} } 

3.2 遞歸版

既然乞丐版有這么多問題,那么就嘗試一下“淺拷貝+遞歸”的方式實現一下。

  1. function cloneDeep(source) { 
  2.     // 如果輸入的為基本類型,直接返回 
  3.     if (!(typeof source === 'object' && source !== null)) { 
  4.         return source; 
  5.     } 
  6.  
  7.     // 判斷輸入的為數組還是對象,進行對應的創建 
  8.     const target = Array.isArray(source) ? [] : {}; 
  9.      
  10.     for (let [key, value] of Object.entries(source)) { 
  11.         // 此處應該去除一些內置對象,根據需要可以自己去除,本初只去除了RegExp對象 
  12.         if (typeof value === 'object' && value !== null && !(value instanceof RegExp)) { 
  13.             target[key] = cloneDeep(value); 
  14.         } 
  15.         else { 
  16.             target[key] = value; 
  17.         } 
  18.     } 
  19.  
  20.     return target; 
  21.  
  22. const obj = { 
  23.     a: 10, 
  24.     b: undefined, 
  25.     c: /\w/g, 
  26.     d: function() { 
  27.         return true
  28.     }, 
  29.     e: { 
  30.         m: 20, 
  31.         n: 30 
  32.     } 
  33. }; 
  34. const result = cloneDeep(obj); 
  35.  
  36. result.e.m = 100; 
  37.  
  38. console.log('拷貝前:', obj); 
  39. console.log('拷貝后:', result); 

輸出結果如下所示:

3.3 循環方式

利用遞歸的方式實現深拷貝,其實是存在爆棧的風險的,下面就將遞歸的方式改為循環的方式。

  1. // 循環方式 
  2. function cloneDeep(source) { 
  3.     if (!(typeof source === 'object' && source !== null)) { 
  4.         return source; 
  5.     } 
  6.  
  7.     const root = Array.isArray(source) ? [] : {}; 
  8.     // 定義一個棧 
  9.     const loopList = [{ 
  10.         parent: root, 
  11.         key: undefined, 
  12.         data: source, 
  13.     }]; 
  14.  
  15.     while (loopList.length > 0) { 
  16.         // 深度優先 
  17.         const node = loopList.pop(); 
  18.         const parent = node.parent; 
  19.         const key = node.key
  20.         const data = node.data; 
  21.  
  22.         // 初始化賦值目標,key為undefined則拷貝到父元素,否則拷貝到子元素 
  23.         let res = parent; 
  24.         if (typeof key !== 'undefined') { 
  25.             res = parent[key] = Array.isArray(data) ? [] : {}; 
  26.         } 
  27.  
  28.         for (let [childKey, value] of Object.entries(data)) { 
  29.             if (typeof value === 'object' && value !== null && !(value instanceof RegExp)) { 
  30.                 loopList.push({ 
  31.                     parent: res, 
  32.                     key: childKey, 
  33.                     data: value 
  34.                 }); 
  35.             } else { 
  36.                 res[childKey] = value; 
  37.             } 
  38.         } 
  39.     } 
  40.  
  41.     return root; 
  42.  
  43. const obj = { 
  44.     a: 10, 
  45.     b: undefined, 
  46.     c: /\w/g, 
  47.     d: function() { 
  48.         return true
  49.     }, 
  50.     e: { 
  51.         m: 20, 
  52.         n: 30 
  53.     } 
  54. }; 
  55. const result = cloneDeep(obj); 
  56.  
  57. result.e.m = 100; 
  58.  
  59. console.log('拷貝前:', obj); 
  60. console.log('拷貝后:', result); 

輸出結果如下所示:

 

責任編輯:姜華 來源: 前端點線面
相關推薦

2021-06-28 07:12:28

賦值淺拷貝深拷貝

2022-09-30 15:03:09

C語言深拷貝淺拷貝

2021-07-16 12:33:24

Javascript深拷貝淺拷貝

2017-08-16 13:30:05

Java深拷貝淺拷貝

2021-01-08 06:15:09

深拷貝淺拷貝寫時拷貝

2023-05-17 08:42:46

深拷貝Golang

2009-05-19 17:28:44

深拷貝淺拷貝clone()

2022-07-26 08:07:03

Python淺拷貝深拷貝

2020-10-12 08:35:22

JavaScript

2024-03-15 15:03:23

2021-09-27 11:07:11

深拷貝淺拷貝內存

2024-02-05 22:56:16

C++拷貝開發

2020-06-23 08:41:47

JavaScript開發技術

2020-08-03 08:24:26

原型模式拷貝

2019-02-25 08:58:16

Python深拷貝淺拷貝

2021-09-10 07:41:06

Python拷貝Python基礎

2024-04-17 09:01:08

Python深拷貝淺拷貝

2018-09-26 14:37:17

JavaScript前端編程語言

2023-05-17 07:36:00

淺拷貝深拷貝對象

2018-05-10 14:20:18

前端JavaScript深拷貝
點贊
收藏

51CTO技術棧公眾號

午夜一区二区三区四区| 免费黄色在线播放| av电影在线网| 国产伦理精品不卡| 9.1国产丝袜在线观看| 欧洲美熟女乱又伦| 亚洲伊人影院| 在线影院国内精品| 国产资源第一页| 日本福利片在线| 国产在线视视频有精品| 欧美亚洲一区在线| 午夜69成人做爰视频| 久久93精品国产91久久综合| 欧美一区二区观看视频| 日韩欧美在线免费观看视频| 成人日批视频| 久久久国产午夜精品| 亚洲字幕在线观看| 国产精品国产精品国产| 激情成人综合| 久久亚洲精品小早川怜子66| 美女洗澡无遮挡| 999久久精品| 欧美精品久久99久久在免费线| 国产成人在线免费看| 成人在线直播| 中文乱码免费一区二区| 精品日本一区二区| 亚洲AV午夜精品| 国内精品伊人久久久久av影院| 青青草一区二区| www.av视频| 97偷自拍亚洲综合二区| 亚洲图片在线综合| 日韩精品极品视频| 777米奇影视第四色| 波多野结衣在线播放| 中文字幕字幕中文在线中不卡视频| 久久综合中文色婷婷| 日本xxxx人| 国产成人精品影视| 91免费版网站在线观看| 国产丝袜视频在线观看| 久久99精品久久久久久久久久久久| 琪琪第一精品导航| 亚洲s码欧洲m码国产av| 999亚洲国产精| 26uuu亚洲国产精品| www.youjizz.com亚洲| 欧美精品99| 欧美大片大片在线播放| 欧美精品成人久久| 欧美日韩精选| 久久久久日韩精品久久久男男| 欧美成人免费看| 欧美特黄一区| 久久精品精品电影网| 欧美激情精品久久久久久免费 | 欧美亚洲另类久久综合| 天堂中文字幕在线| 久久久www成人免费毛片麻豆| 久久久久久欧美精品色一二三四| 性高潮久久久久久久久久| 99精品视频在线观看| 美女黄毛**国产精品啪啪| 极品白浆推特女神在线观看| 久久久精品tv| 在线观看精品视频| 天使と恶魔の榨精在线播放| 亚洲综合在线第一页| 男女视频网站在线观看| 午夜激情在线播放| 欧美性淫爽ww久久久久无| 国产精品一区二区小说| 午夜视频一区二区在线观看| 亚洲国产99精品国自产| 丰满少妇一区二区| 97精品国产| 午夜欧美大片免费观看| 无码无套少妇毛多18pxxxx| 美女尤物国产一区| 国产精品久久久久久免费观看| 色婷婷视频在线| 国产亚洲欧美日韩俺去了| 老司机av福利| 九九色在线视频| 精品视频一区三区九区| 午夜性福利视频| 婷婷精品在线观看| 日韩中文字幕国产精品| 国产av无码专区亚洲av毛网站 | caoporn超碰97| 国产剧情一区二区在线观看| 亚洲黄色有码视频| 日韩av片在线免费观看| 亚洲国产午夜| 国产欧美在线观看| 日本韩国在线观看| 国产精品国产三级国产普通话蜜臀| 国产激情在线看| 久久91导航| 欧美videossexotv100| 成人在线手机视频| 亚洲国产美女 | 亚洲中文一区二区三区| 成人动漫精品一区二区| 一区二区日本伦理| 国产不卡123| 91精品蜜臀在线一区尤物| 无套内谢大学处破女www小说| 91久久电影| 2019亚洲日韩新视频| 99热这里只有精品66| 国产亚洲va综合人人澡精品| 岛国大片在线播放| 国产成人免费视频网站视频社区 | 国精产品一区一区三区免费视频| 91精品啪在线观看国产18| 欧美一区二区视频97| 亚洲av无码乱码国产精品久久| 欧美国产一区二区在线观看| 内射国产内射夫妻免费频道| 综合激情久久| 欧美成人性色生活仑片| 中文字幕有码无码人妻av蜜桃| 91香蕉视频污在线| 日本中文字幕网址| 中文字幕一区二区三区四区久久| 久久精品色欧美aⅴ一区二区| 无码人妻精品一区二区50| 99国内精品久久| 老太脱裤让老头玩ⅹxxxx| 老司机亚洲精品一区二区| 日韩在线视频免费观看| 日本欧美www| 国产三级一区二区三区| 成熟老妇女视频| 在线观看欧美理论a影院| 久久久久久国产免费| 精品黑人一区二区三区国语馆| 中文字幕亚洲在| 性欧美在线视频| 久久精品欧美一区| 91亚洲精品久久久| 97caopron在线视频| 51精品秘密在线观看| 三级av在线免费观看| 精品一区二区三区视频在线观看| 色视频一区二区三区| 中文字幕日本一区二区| 国产一区二区av| 中文字幕二区三区| 亚洲欧洲韩国日本视频| 五月六月丁香婷婷| 国产精品vip| 国产不卡一区二区三区在线观看| 免费网站在线观看人| 亚洲第一天堂av| 国产超碰人人爽人人做人人爱| 91老师国产黑色丝袜在线| 亚洲精品无码久久久久久| 综合国产视频| 国产精品日韩在线观看| 麻豆av在线免费看| 日韩一区二区三区在线观看| 国产午夜小视频| 26uuuu精品一区二区| 91小视频网站| 亚洲精品一区二区妖精| 成人久久18免费网站漫画| 黄毛片在线观看| 亚洲一区二区黄| av资源免费看| 精品久久久精品| 三年中国中文观看免费播放| 国产美女av一区二区三区| 国产曰肥老太婆无遮挡| 久操精品在线| 亚洲精品免费网站| 日韩伦理精品| 社区色欧美激情 | 免费av网站观看| 色94色欧美sute亚洲线路一久| 波多野结衣喷潮| 波多野结衣在线aⅴ中文字幕不卡| 成人观看免费完整观看| 午夜国产一区二区| 国产在线精品一区二区三区》| 欧美色片在线观看| 欧美老少做受xxxx高潮| 国产专区在线播放| 欧美不卡123| 精人妻无码一区二区三区| 一区二区三区在线高清| 91成年人网站| 国产精品亚洲а∨天堂免在线| 免费毛片小视频| 亚洲精品在线观看91| 日韩av电影免费在线观看| 日本一区二区三区免费视频| 老司机久久99久久精品播放免费| 一区二区三区四区五区视频| 麻豆一区二区麻豆免费观看| 成人黄色午夜影院| 卡通欧美亚洲| 欧美裸体男粗大视频在线观看| 国产在线观看高清视频| 欧美精品一区二区三区久久久| 中文字幕av免费观看| 天天操天天干天天综合网| 在线免费看av网站| 国产日韩精品久久久| 中文字幕在线播放一区| 国产在线精品不卡| 男女男精品视频站| 国产九九精品| 国产一区二区三区小说| 五月天久久久| 亚洲欧洲中文| 奇米色欧美一区二区三区| 国产视频在线观看一区| 久久久久久爱| 91久久精品国产91性色| 999国产精品亚洲77777| 欧美专区日韩视频| 理论不卡电影大全神| 欧美激情久久久| caoporn免费在线视频| 色777狠狠综合秋免鲁丝| 国产精品二线| 国产亚洲精品va在线观看| 日韩欧美亚洲系列| 亚洲精品美女免费| 欧美 日韩 人妻 高清 中文| 日韩女优毛片在线| 国产农村妇女毛片精品| 91精品国产乱| 国产男女猛烈无遮挡| 欧美日本一区二区三区| 91成年人视频| 91黄视频在线| 国产91av在线播放| 欧美色国产精品| 中文字幕 欧美激情| 欧美亚日韩国产aⅴ精品中极品| 国语对白做受69按摩| 91电影在线观看| 中文字幕乱码一区二区 | 99在线无码精品入口| 欧美卡1卡2卡| 国产剧情精品在线| 日韩一卡二卡三卡四卡| www.五月婷| 亚洲国产精品va在线看黑人| 四虎在线视频| 亚洲男人天堂2024| 国产剧情在线观看| 最新国产成人av网站网址麻豆| 欧美激情二区| 久久不射电影网| 国内高清免费在线视频| 5278欧美一区二区三区| 久久91导航| 96国产粉嫩美女| 久久成人福利| 欧美一区国产一区| 99热在线成人| 久久在线中文字幕| 米奇777在线欧美播放| 欧美三级午夜理伦三级富婆| 国产乱人伦精品一区二区在线观看 | 欧美h视频在线| 久久电影院7| 18禁裸男晨勃露j毛免费观看| 午夜在线精品| 久久国产精品国产精品| 高清久久久久久| 国产精品无码久久久久一区二区| 中文在线资源观看网站视频免费不卡 | 日韩理论在线观看| 久久久无码一区二区三区| 欧美性高跟鞋xxxxhd| 亚洲天堂自拍偷拍| 亚洲精品美女在线观看| 欧美精品日韩少妇| 97精品一区二区三区| 日韩成人免费av| 国产高清精品一区二区三区| 奇米狠狠一区二区三区| 亚洲精品天堂成人片av在线播放| 校园春色综合网| 日本一本在线视频| 久久久99精品免费观看不卡| 欧美日韩一级大片| 在线观看免费视频综合| 成人久久精品人妻一区二区三区| 国产午夜精品免费一区二区三区| 91精品国产91久久久久久青草| 456国产精品| 日韩一区二区三区高清在线观看| 欧美精品亚洲| 亚洲网站视频| 黄色三级视频在线播放| 久久久五月婷婷| 日韩av电影网址| 91精品国产综合久久久蜜臀粉嫩 | av高清在线免费观看| 麻豆国产91在线播放| 免费中文字幕av| 一区二区三区在线观看网站| 波多野结衣啪啪| 亚洲大尺度美女在线| 黄色免费在线观看网站| 国产精品999| 天海翼精品一区二区三区| 人妻激情另类乱人伦人妻| 久久99深爱久久99精品| 小早川怜子久久精品中文字幕| 天天影视网天天综合色在线播放| 国产精品一区二区人人爽| 天堂精品中文字幕在线| 精品久久久久av| www.av亚洲| 久久综合久久鬼| 欧美成人国产一区二区| 黄a在线观看| 国产日韩av高清| 欧美日韩在线播放视频| 92看片淫黄大片一级| 99国内精品久久久久| 色噜噜国产精品视频一区二区| 欧美人与牲禽动交com| 91aaaa| 欧美日韩国产免费观看| 日本一二三四区视频| 亚洲欧美综合在线精品| 一级做a爰片久久毛片16| 综合久久五月天| 欧美日韩视频免费看| 一区二区三区精品国产| 蓝色福利精品导航| 国产小视频你懂的| 91麻豆精品91久久久久久清纯| 国产高清一区二区三区视频| 91青草视频久久| 国产精品多人| 在线观看成人动漫| 午夜久久久久久久久| 视频国产在线观看| 国产经典一区二区| 久久综合99| 五月天六月丁香| 亚洲国产精品自拍| 五月天丁香视频| 日本欧美一级片| 欧美日韩在线二区| www.亚洲自拍| 亚洲一级片在线观看| 天天操天天射天天| 人人澡人人澡人人看欧美| 精品视频99| 三级av免费看| 精品动漫一区二区三区| 国产中文字幕在线播放| 成人欧美一区二区三区在线湿哒哒| 久久久久久久久丰满| 无码人妻丰满熟妇区毛片蜜桃精品 | 欧美v亚洲v综合ⅴ国产v| 麻豆蜜桃在线观看| 视频一区国产精品| 国产精品一区在线观看你懂的| 国产精品变态另类虐交| 亚洲人成网7777777国产| 国产精品66| 9色porny| 欧美国产一区二区| 成人精品在线播放| 国产精品高潮呻吟久久av野狼| 99re66热这里只有精品8| 日本美女视频网站| 91国偷自产一区二区使用方法| 搞黄网站在线观看| 免费在线观看91| 激情亚洲综合在线| 日韩久久久久久久久| 最好看的2019的中文字幕视频| 一区二区在线免费播放| 成人在线观看黄| 亚洲黄一区二区三区| 日韩在线免费看| 亚洲最大福利视频| 石原莉奈一区二区三区在线观看| 久久久精品视频免费观看| 亚洲男女性事视频| 在这里有精品| 黄色手机在线视频| 黄色成人在线免费| 在线观看午夜av| 亚洲精品在线视频观看|