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

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

開發 前端
相信老鐵們不管是在學習還是面試過程中,都會遇到賦值、淺拷貝、深拷貝,特別是淺拷貝和深拷貝,我記憶比較深刻的遇到這個問題有兩次:1.一次系統寫出bug就是因為對深淺拷貝理解不清楚;2.百度面試。

 [[407599]]

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

  • 一次系統寫出bug就是因為對深淺拷貝理解不清楚;
  • 百度面試。

23.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 } 

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

對于基本類型賦值就是在棧內存中開辟一個新的存儲區域來存儲新的變量;

對于引用類型賦值,就是將該引用類型的地址,該地址指向堆中的同一值。

23.2 淺拷貝

23.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 } } 

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

遍歷到a屬性的時候,其是一個基本類型,所以會在棧內存中創建一個新的存儲區域來存儲變量。

遍歷到b屬性的時候,由于其為引用類型,其會在棧內存中存儲器堆地址,從而指向堆內存中的同一對象。

當通過淺拷貝創建的對象cloneObj中的a屬性和b.m屬性重新賦值,可以發現a屬性值不一樣,但b.m屬性值卻發生了變化,從而驗證了上述1、2兩條分析。

23.2.2 進階

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

23.2.2.1 基礎

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

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

23.2.2.2 實現

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

  • 對目標對象進行判斷,不能為null和undefined;
  • 將目標轉換為對象(防止string、number等);
  • 獲取后續源對象自身中的可枚舉對象(包含Symbol)復制到目標對象;
  • 返回該處理好的目標對象;
  • 利用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 } 

23.3 深拷貝

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

23.3.1 乞丐版

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

  • 不能正確處理正則表達式,其會變為空對象;
  • 不能正確處理函數,其變為undefined;
  • 不能正常輸出值為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: {} } 

23.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); 

輸出結果如下所示:

23.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-10-18 09:01:01

前端賦值淺拷貝

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淺拷貝深拷貝

2024-03-15 15:03:23

2020-10-12 08:35:22

JavaScript

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-10-19 22:23:05

typeof方式Instanceof

2021-05-09 22:00:59

TypeofInstanceof運算符

2021-09-10 07:41:06

Python拷貝Python基礎

2024-04-17 09:01:08

Python深拷貝淺拷貝

2018-09-26 14:37:17

JavaScript前端編程語言
點贊
收藏

51CTO技術棧公眾號

国产九九热视频| 欧美一区三区二区在线观看| 一区二区精品免费视频| 免费超爽大片黄| 99久久精品国产色欲| 最新亚洲视频| 最新国产精品拍自在线播放| 69久久精品无码一区二区| www.超碰在线| 国产精品久久久久久久第一福利| 99国产在线视频| 日韩欧美在线观看免费| 在线精品国产| 国产亚洲一级高清| 黄页网站在线看| av成人在线看| 精品久久久视频| 三年中文高清在线观看第6集| 天天干天天操av| 狠狠狠色丁香婷婷综合久久五月| 51色欧美片视频在线观看| www欧美com| 日韩专区精品| 国产丝袜一区二区三区免费视频| 一级 黄 色 片一| 欧美日韩123区| 五月综合激情网| 中国黄色录像片| 91在线视频| 久久精品这里都是精品| 精品国产乱码久久久久久88av | 91免费看片在线| 国产黄网在线观看| 国产精品毛片在线| 久久免费视频这里只有精品| 欧美另类videoxo高潮| 国产免费av一区二区三区| 亚洲国产91精品在线观看| 日本r级电影在线观看| 91麻豆精品| 欧美三级日本三级少妇99| 激情婷婷综合网| jizz欧美激情18| 1769在线观看| 中文字幕+乱码+中文字幕一区| 久久青青草综合| 天天干天天草天天射| 成人黄色777网| 国产福利久久| 熟妇人妻系列aⅴ无码专区友真希 熟妇人妻av无码一区二区三区 | 2024国产精品视频| 久久精品99久久| 天堂91在线| 中文字幕一区二区三区四区久久| 在线看一区二区| 精品久久久久久久免费人妻| 综合日韩av| 色猫猫国产区一区二在线视频| 91专区在线观看| 日韩脚交footjobhd| 精品久久久久国产| 北条麻妃69av| 美女写真久久影院| 欧美日韩在线三级| 欧美日韩精品区别| 精品视频在线播放一区二区三区| 717成人午夜免费福利电影| 三级性生活视频| 亚洲va欧美va人人爽成人影院| 精品美女一区二区三区| 99re久久精品国产| 国产成人三级| 丝袜亚洲另类欧美重口| h色网站在线观看| 亚洲承认在线| 国产mv久久久| 国产精品老熟女视频一区二区| 国产精品伊人色| 国产无套精品一区二区| 福利片在线看| 亚洲欧美日本在线| 黄色一级片播放| 国产无遮挡又黄又爽又色视频| 成人性生交大片免费看网站 | 欧美日韩亚洲国产成人| 操喷在线视频| 91高清视频在线| 亚洲黄色av片| 日本成人7777| 日韩在线资源网| 国产无遮挡裸体免费视频| 久久精品国语| 91精品天堂| 久久天堂电影| 一区二区三区四区五区视频在线观看| 男人天堂1024| 久久wwww| 亚洲午夜精品久久久久久性色| 国产精品免费人成网站酒店| 欧美精品九九| 国产精品免费观看在线| 高潮毛片7777777毛片| 久久一区二区三区四区| 男人草女人视频| 亚洲第一影院| 日韩av综合网| 老湿机69福利| 免费观看成人鲁鲁鲁鲁鲁视频| 国产成人精品一区二区三区福利| 成人资源www网在线最新版| 亚洲国产成人精品视频| 日本三级黄色网址| 免费视频国产一区| 欧美激情第1页| 国产又粗又大又黄| 国产亚洲欧美日韩日本| 欧美三级在线观看视频| 国产视频网站一区二区三区| 一区二区三区精品99久久| 国产在线综合网| 国产综合成人久久大片91| 欧美一区三区二区在线观看| 欧美日韩国产观看视频| 日韩精品综合一本久道在线视频| 国产精品一区二区亚洲| 日韩电影在线免费观看| 久久久精彩视频| 成年人视频观看| 国产一区二区三区免费观看在线| 一本色道久久88亚洲综合88| 中文字字幕在线中文| 成人免费看视频| 九九久久九九久久| 亚洲国产91视频| 中文字幕一区日韩电影| 成人午夜精品视频| 国产午夜精品福利| 无码精品国产一区二区三区免费| 久久97精品| 欧美国产高跟鞋裸体秀xxxhd| 国产精品无码专区av免费播放| 欧美激情一区二区三区四区| 99视频精品免费| 神马电影久久| 国产成人精品亚洲精品| 国产69久久| 欧美伊人久久大香线蕉综合69| 成人黄色免费网址| 青青草国产精品97视觉盛宴| 五月天久久狠狠| 欧美视频精品| 久久亚洲春色中文字幕| 国产黄色av片| 亚瑟在线精品视频| 亚洲天堂网一区二区| 国产精品综合| 日韩欧美99| 欧美日韩va| 色综合视频网站| 隣の若妻さん波多野结衣| 亚洲成av人片| 欧美做受高潮6| 老司机精品视频在线| 天天综合中文字幕| 一区二区三区四区高清视频| 久久免费视频网站| 国产三级视频在线看| 欧美日韩免费不卡视频一区二区三区| av最新在线观看| 粉嫩嫩av羞羞动漫久久久| 热99这里只有精品| 精品国产一区二区三区四区| 国产在线拍偷自揄拍精品| 亚洲制服国产| 日韩精品亚洲元码| 国产又粗又猛又爽又黄的| 亚洲激情校园春色| 老司机福利av| 久草在线在线精品观看| 性高湖久久久久久久久aaaaa| 欧美一级三级| 国产欧美日韩精品在线观看| 国产丝袜精品丝袜| 在线看国产精品| 精品久久久久久亚洲综合网站| 精品久久中文字幕| 婷婷丁香综合网| 不卡的看片网站| 久久婷婷综合色| 亚洲福利精品| 亚洲一区三区在线观看| 精品国产一区二区三区成人影院| 国产精品激情自拍| 国产啊啊啊视频在线观看| 在线视频欧美性高潮| 亚洲AV无码乱码国产精品牛牛| 91福利视频网站| 国产真实乱偷精品视频| 国产精品欧美综合在线| 在线观看国产免费视频| 国产在线不卡一卡二卡三卡四卡| 久久久久狠狠高潮亚洲精品| 欧美日一区二区在线观看 | 国产在线视频欧美| 国产伦久视频在线观看| 裸体女人亚洲精品一区| 春暖花开成人亚洲区| 精品国产电影一区二区| 国产精品欧美综合亚洲| 色吊一区二区三区| 日韩av黄色片| 亚洲久草在线视频| 女人裸体性做爰全过| 2021国产精品久久精品| wwwww在线观看| 麻豆精品一区二区三区| 青青在线视频观看| 亚洲福利一区| 国产成人艳妇aa视频在线 | 日韩综合中文字幕| 日本高清中文字幕二区在线| 精品国产免费一区二区三区四区| 国产又爽又黄免费软件| 在线视频你懂得一区二区三区| 国产精品7777| 亚洲亚洲精品在线观看| 日本高清一二三区| 国产精品毛片无遮挡高清| 微拍福利一区二区| 久久五月婷婷丁香社区| 亚洲熟女乱综合一区二区三区| 成人性生交大合| 9191在线视频| 国产成人免费在线观看| 久久久九九九热| 国产尤物一区二区在线| 成年网站免费在线观看| 美国毛片一区二区三区| 邪恶网站在线观看| 欧美aaa在线| 成年人视频在线免费| 丝袜亚洲精品中文字幕一区| 成年人观看网站| 久久精品一区二区国产| 日本熟妇人妻xxxxx| 日本伊人色综合网| 北条麻妃视频在线| 免费日本视频一区| 亚洲最大天堂网| 国产一区二区免费看| 日本特黄在线观看| 成人午夜激情影院| 一起草在线视频| 久久久久久亚洲综合| 免费黄在线观看| 亚洲人成小说网站色在线 | 日韩成人av一区二区| www.色综合.com| 成年人在线观看av| 国产喷白浆一区二区三区| 一区二区三区在线播放视频| 亚洲另类在线制服丝袜| 免费视频一二三区| 精品久久久久久| 日本一区二区三区久久| 777a∨成人精品桃花网| 欧美自拍偷拍一区二区| 亚洲美女av黄| 视频三区在线| 欧美激情2020午夜免费观看| 精品国偷自产在线视频| 秋霞在线视频| 日产精品久久久一区二区福利| 全球最大av网站久久| 亚洲一区二区三区在线免费观看| 国产成人福利av| 亚洲成人a**址| 你懂的国产精品永久在线| 欧美一级视频免费看| 日韩激情在线观看| 午夜影院免费版| 久久综合九色综合97婷婷| 国产三级在线观看完整版| 一区二区不卡在线视频 午夜欧美不卡在| 日本熟妇毛茸茸丰满| 欧美日韩在线播| 亚洲精品国产av| 国产亚洲精品美女久久久| 最新日本在线观看| 国产精品69久久| 国产精品va视频| 久久久久欧美| 欧美fxxxxxx另类| 免费黄色特级片| 东方aⅴ免费观看久久av| 免费看黄色三级| 午夜欧美一区二区三区在线播放| 天天天天天天天干| 亚洲国产成人精品女人久久久 | 国产福利视频一区二区| 日韩激情综合| 色女人综合av| 亚洲美女网站| 精品人妻一区二区乱码| 亚洲国产精品成人久久综合一区| 国产黄色片视频| 91精品在线麻豆| 成年人免费在线视频| 97视频在线免费观看| 玖玖玖电影综合影院| 亚洲欧美日韩在线综合| 亚洲综合国产| 97精品人人妻人人| 亚洲精品成人少妇| 亚洲天堂网视频| 国产亚洲精品美女| 成人影院av| 狠狠色综合网站久久久久久久| 中文字幕一区二区三区欧美日韩| 91精品无人成人www| 国产日韩欧美不卡在线| 中文字字幕在线中文| 亚洲精品v欧美精品v日韩精品| 99自拍视频在线观看| 91精品久久久久久久久久入口| 视频国产一区| 日韩a在线播放| 91丨porny丨国产入口| 日韩免费av片| 精品国产免费久久| 色婷婷视频在线观看| 91久久精品www人人做人人爽| 天天影视综合| 99中文字幕在线| 综合久久一区二区三区| 一级黄色片在线观看| 中文字幕日韩在线视频| 成人网ww555视频免费看| 日韩高清av| 美女在线视频一区| 91香蕉视频污在线观看| 欧美日韩三级在线| 日本在线免费网| 91免费在线视频网站| 亚洲综合婷婷| 久久精品aⅴ无码中文字字幕重口| 一区二区三区精品久久久| www久久久com| 亚洲 日韩 国产第一| 久久婷婷国产| 日韩中文字幕三区| 久久精品亚洲精品国产欧美 | 麻豆国产精品视频| 开心激情五月网| 日韩午夜在线影院| 99在线视频影院| 久久亚洲高清| 美女国产一区二区三区| www.毛片com| 亚洲精品久久视频| 九九热线视频只有这里最精品| 亚洲一区不卡在线| 国产精品一区二区黑丝| 日本va欧美va国产激情| 亚洲色图狂野欧美| **国产精品| 久久久性生活视频| 久久久美女毛片| 亚洲字幕av一区二区三区四区| 久久久久99精品久久久久| 99精品中文字幕在线不卡| 波多野结衣家庭教师在线播放| 国产欧美一区二区精品秋霞影院| 国产毛片一区二区三区va在线| 久久久久成人网| 红桃成人av在线播放| 在线一区二区不卡| 激情懂色av一区av二区av| a天堂在线资源| 超碰97人人在线| 欧美a一区二区| 国产网站在线看| 亚洲最大中文字幕| 亚洲不卡视频| 免费黄色一级网站| 亚洲综合丝袜美腿| 成人性生交大片免费看午夜| 97伦理在线四区| 三级不卡在线观看| 久久综合综合久久| 最近更新的2019中文字幕| 开心激情综合| 九九九九九九九九| 欧美午夜激情在线| 在线观看中文字幕的网站| 日本不卡一区| 成人av电影免费在线播放| 中文字幕日产av| 5566成人精品视频免费| 婷婷久久国产对白刺激五月99|