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

監(jiān)聽一個變量的變化,需要怎么做

安全 應(yīng)用安全
監(jiān)聽一個變量的變化,當(dāng)變量變化時執(zhí)行某些操作,這類似現(xiàn)在流行的前端框架(例如 React、Vue等)中的數(shù)據(jù)綁定功能,在數(shù)據(jù)更新時自動更新 DOM 渲染,那么如何實現(xiàn)數(shù)據(jù)綁定喃?

[[395785]]

本文轉(zhuǎn)載自微信公眾號「三分鐘學(xué)前端」,作者sisterAn。轉(zhuǎn)載本文請聯(lián)系三分鐘學(xué)前端公眾號。

監(jiān)聽一個變量的變化,當(dāng)變量變化時執(zhí)行某些操作,這類似現(xiàn)在流行的前端框架(例如 React、Vue等)中的數(shù)據(jù)綁定功能,在數(shù)據(jù)更新時自動更新 DOM 渲染,那么如何實現(xiàn)數(shù)據(jù)綁定喃?

本文給出兩種思路:

  • ES5 的 Object.defineProperty
  • ES6 的 Proxy

ES5 的 Object.defineProperty

Object.defineProperty() 方法會直接在一個對象上定義一個新屬性,或者修改一個對象的現(xiàn)有屬性,并返回此對象

——MDN

  1. Object.defineProperty(obj, prop, descriptor) 

其中:

  • obj :要定義屬性的對象
  • prop :要定義或修改的屬性的名稱或 Symbol
  • descriptor :要定義或修改的屬性描述符
  1. var user = {  
  2.     name'sisterAn'  
  3.  
  4. Object.defineProperty(user'name', { 
  5.     enumerable: true
  6.     configurable:true
  7.     setfunction(newVal) { 
  8.         this._name = newVal  
  9.         console.log('set: ' + this._name) 
  10.     }, 
  11.     get: function() { 
  12.         console.log('get: ' + this._name) 
  13.         return this._name 
  14.     } 
  15. }) 
  16.  
  17. user.name = 'an' // set: an 
  18. console.log(user.name) // get: an 

如果是完整的對變量的每一個子屬性進行監(jiān)聽:

  1. // 監(jiān)視對象 
  2. function observe(obj) { 
  3.    // 遍歷對象,使用 get/set 重新定義對象的每個屬性值 
  4.     Object.keys(obj).map(key => { 
  5.         defineReactive(obj, key, obj[key]) 
  6.     }) 
  7.  
  8. function defineReactive(obj, k, v) { 
  9.     // 遞歸子屬性 
  10.     if (typeof(v) === 'object') observe(v) 
  11.      
  12.     // 重定義 get/set 
  13.     Object.defineProperty(obj, k, { 
  14.         enumerable: true
  15.         configurable: true
  16.         get: function reactiveGetter() { 
  17.             console.log('get: ' + v) 
  18.             return v 
  19.         }, 
  20.         // 重新設(shè)置值時,觸發(fā)收集器的通知機制 
  21.         setfunction reactiveSetter(newV) { 
  22.             console.log('set: ' + newV) 
  23.             v = newV 
  24.         }, 
  25.     }) 
  26.  
  27. let data = {a: 1} 
  28. // 監(jiān)視對象 
  29. observe(data) 
  30. data.a // get: 1 
  31. data.a = 2 // set: 2 

通過 map 遍歷,通過深度遞歸監(jiān)聽子子屬性

注意, Object.defineProperty 擁有以下缺陷:

  • IE8 及更低版本 IE 是不支持的
  • 無法檢測到對象屬性的新增或刪除
  • 如果修改數(shù)組的 length ( Object.defineProperty 不能監(jiān)聽數(shù)組的長度),以及數(shù)組的 push 等變異方法是無法觸發(fā) setter 的

對此,我們看一下 vue2.x 是如何解決這塊的?

vue2.x 中如何監(jiān)測數(shù)組變化

使用了函數(shù)劫持的方式,重寫了數(shù)組的方法,Vue 將 data 中的數(shù)組進行了原型鏈重寫,指向了自己定義的數(shù)組原型方法。這樣當(dāng)調(diào)用數(shù)組 api 時,可以通知依賴更新。如果數(shù)組中包含著引用類型,會對數(shù)組中的引用類型再次遞歸遍歷進行監(jiān)控。這樣就實現(xiàn)了監(jiān)測數(shù)組變化。

對于數(shù)組而言,Vue 內(nèi)部重寫了以下函數(shù)實現(xiàn)派發(fā)更新

  1. // 獲得數(shù)組原型 
  2. const arrayProto = Array.prototype 
  3. export const arrayMethods = Object.create(arrayProto) 
  4. // 重寫以下函數(shù) 
  5. const methodsToPatch = [ 
  6.   'push'
  7.   'pop'
  8.   'shift'
  9.   'unshift'
  10.   'splice'
  11.   'sort'
  12.   'reverse' 
  13. methodsToPatch.forEach(function (method) { 
  14.   // 緩存原生函數(shù) 
  15.   const original = arrayProto[method] 
  16.   // 重寫函數(shù) 
  17.   def(arrayMethods, method, function mutator (...args) { 
  18.   // 先調(diào)用原生函數(shù)獲得結(jié)果 
  19.     const result = original.apply(this, args) 
  20.     const ob = this.__ob__ 
  21.     let inserted 
  22.     // 調(diào)用以下幾個函數(shù)時,監(jiān)聽新數(shù)據(jù) 
  23.     switch (method) { 
  24.       case 'push'
  25.       case 'unshift'
  26.         inserted = args 
  27.         break 
  28.       case 'splice'
  29.         inserted = args.slice(2) 
  30.         break 
  31.     } 
  32.     if (inserted) ob.observeArray(inserted) 
  33.     // 手動派發(fā)更新 
  34.     ob.dep.notify() 
  35.     return result 
  36.   }) 
  37. }) 

vue2.x 怎么解決給對象新增屬性不會觸發(fā)組件重新渲染的問題

受現(xiàn)代 JavaScript 的限制 ( Object.observe 已被廢棄),Vue 無法檢測到對象屬性的添加或刪除。

由于 Vue 會在初始化實例時對屬性執(zhí)行 getter/setter 轉(zhuǎn)化,所以屬性必須在 data 對象上存在才能讓 Vue 將它轉(zhuǎn)換為響應(yīng)式的。

對于已經(jīng)創(chuàng)建的實例,Vue 不允許動態(tài)添加根級別的響應(yīng)式屬性。但是,可以使用 Vue.set(object, propertyName, value) 方法向嵌套對象添加響應(yīng)式屬性。

vm.$set()實現(xiàn)原理

  1. export function set(target: Array<any> | Object, keyany, val: any): any { 
  2.   // target 為數(shù)組 
  3.   if (Array.isArray(target) && isValidArrayIndex(key)) { 
  4.     // 修改數(shù)組的長度, 避免索引>數(shù)組長度導(dǎo)致 splice() 執(zhí)行有誤 
  5.     target.length = Math.max(target.length, key); 
  6.     // 利用數(shù)組的 splice 方法觸發(fā)響應(yīng)式 
  7.     target.splice(key, 1, val); 
  8.     return val; 
  9.   } 
  10.   // target 為對象, key 在 target 或者 target.prototype 上 且必須不能在 Object.prototype 上,直接賦值 
  11.   if (key in target && !(key in Object.prototype)) { 
  12.     target[key] = val; 
  13.     return val; 
  14.   } 
  15.   // 以上都不成立, 即開始給 target 創(chuàng)建一個全新的屬性 
  16.   // 獲取 Observer 實例 
  17.   const ob = (target: any).__ob__; 
  18.   // target 本身就不是響應(yīng)式數(shù)據(jù), 直接賦值 
  19.   if (!ob) { 
  20.     target[key] = val; 
  21.     return val; 
  22.   } 
  23.   // 進行響應(yīng)式處理 
  24.   defineReactive(ob.value, key, val); 
  25.   ob.dep.notify(); 
  26.   return val; 
  • 如果目標是數(shù)組,使用 vue 實現(xiàn)的變異方法 splice 實現(xiàn)響應(yīng)式
  • 如果目標是對象,判斷屬性存在,即為響應(yīng)式,直接賦值
  • 如果 target 本身就不是響應(yīng)式,直接賦值
  • 如果屬性不是響應(yīng)式,則調(diào)用 defineReactive 方法進行響應(yīng)式處理

ES6 的 Proxy

眾所周知,尤大大的 vue3.0 版本用 Proxy 代替了defineProperty 來實現(xiàn)數(shù)據(jù)綁定,因為 Proxy 可以直接監(jiān)聽對象和數(shù)組的變化,并且有多達 13 種攔截方法。并且作為新標準將受到瀏覽器廠商重點持續(xù)的性能優(yōu)化。

Proxy

Proxy 對象用于創(chuàng)建一個對象的代理,從而實現(xiàn)基本操作的攔截和自定義(如屬性查找、賦值、枚舉、函數(shù)調(diào)用等)

— MDN

  1. const p = new Proxy(target, handler) 

其中:

  • target :要使用 Proxy 包裝的目標對象(可以是任何類型的對象,包括原生數(shù)組,函數(shù),甚至另一個代理)
  • handler :一個通常以函數(shù)作為屬性的對象,各屬性中的函數(shù)分別定義了在執(zhí)行各種操作時代理 p 的行為
  1. var handler = { 
  2.     get: function(target, name){ 
  3.         return name in target ? target[name] : 'no prop!' 
  4.     }, 
  5.     setfunction(target, prop, value, receiver) { 
  6.         target[prop] = value; 
  7.         console.log('property set: ' + prop + ' = ' + value); 
  8.         return true
  9.     } 
  10. }; 
  11.  
  12. var user = new Proxy({}, handler) 
  13. user.name = 'an' // property setname = an 
  14.  
  15. console.log(user.name) // an 
  16. console.log(user.age) // no prop! 

上面提到過 Proxy 總共提供了 13 種攔截行為,分別是:

  • getPrototypeOf / setPrototypeOf
  • isExtensible / preventExtensions
  • ownKeys / getOwnPropertyDescriptor
  • defineProperty / deleteProperty
  • get / set / has
  • apply / construct

感興趣的可以查看 MDN ,一一嘗試一下,這里不再贅述

另外考慮兩個問題:

  • Proxy只會代理對象的第一層,那么又是怎樣處理這個問題的呢?
  • 監(jiān)測數(shù)組的時候可能觸發(fā)多次get/set,那么如何防止觸發(fā)多次呢(因為獲取push和修改length的時候也會觸發(fā))

Vue3 Proxy

對于第一個問題,我們可以判斷當(dāng)前 Reflect.get 的返回值是否為 Object ,如果是則再通過 reactive 方法做代理, 這樣就實現(xiàn)了深度觀測。

對于第二個問題,我們可以判斷是否是 hasOwProperty

下面我們自己寫個案例,通過proxy 自定義獲取、增加、刪除等行為

  1. const toProxy = new WeakMap(); // 存放被代理過的對象 
  2. const toRaw = new WeakMap(); // 存放已經(jīng)代理過的對象 
  3. function reactive(target) { 
  4.   // 創(chuàng)建響應(yīng)式對象 
  5.   return createReactiveObject(target); 
  6. function isObject(target) { 
  7.   return typeof target === "object" && target !== null
  8. function hasOwn(target,key){ 
  9.   return target.hasOwnProperty(key); 
  10. function createReactiveObject(target) { 
  11.   if (!isObject(target)) { 
  12.     return target; 
  13.   } 
  14.   let observed = toProxy.get(target); 
  15.   if(observed){ // 判斷是否被代理過 
  16.     return observed; 
  17.   } 
  18.   if(toRaw.has(target)){ // 判斷是否要重復(fù)代理 
  19.     return target; 
  20.   } 
  21.   const handlers = { 
  22.     get(target, key, receiver) { 
  23.         let res = Reflect.get(target, key, receiver); 
  24.         track(target,'get',key); // 依賴收集== 
  25.         return isObject(res)  
  26.         ?reactive(res):res; 
  27.     }, 
  28.     set(target, key, value, receiver) { 
  29.         let oldValue = target[key]; 
  30.         let hadKey = hasOwn(target,key); 
  31.         let result = Reflect.set(target, key, value, receiver); 
  32.         if(!hadKey){ 
  33.           trigger(target,'add',key); // 觸發(fā)添加 
  34.         }else if(oldValue !== value){ 
  35.           trigger(target,'set',key); // 觸發(fā)修改 
  36.         } 
  37.         return result; 
  38.     }, 
  39.     deleteProperty(target, key) { 
  40.       console.log("刪除"); 
  41.       const result = Reflect.deleteProperty(target, key); 
  42.       return result; 
  43.     } 
  44.   }; 
  45.    
  46.   // 開始代理 
  47.   observed = new Proxy(target, handlers); 
  48.   toProxy.set(target,observed); 
  49.   toRaw.set(observed,target); // 做映射表 
  50.   return observed; 

總結(jié)

Proxy 相比于 defineProperty 的優(yōu)勢:

基于 Proxy 和 Reflect ,可以原生監(jiān)聽數(shù)組,可以監(jiān)聽對象屬性的添加和刪除

不需要深度遍歷監(jiān)聽:判斷當(dāng)前 Reflect.get 的返回值是否為 Object ,如果是則再通過 reactive 方法做代理, 這樣就實現(xiàn)了深度觀測

只在 getter 時才對對象的下一層進行劫持(優(yōu)化了性能)

所以,建議使用 Proxy 監(jiān)測變量變化

參考

MDN

 

帶你了解 vue-next(Vue 3.0)之 爐火純青

 

責(zé)任編輯:武曉燕 來源: 三分鐘學(xué)前端
相關(guān)推薦

2022-05-13 08:12:00

JMeter測試計劃

2023-08-27 21:25:20

用戶畫像數(shù)據(jù)數(shù)據(jù)分析

2024-08-28 08:38:51

2010-11-17 15:43:55

軟件測試Bug

2018-06-25 08:33:33

技術(shù)總監(jiān)職場規(guī)劃

2018-12-13 11:52:48

2022-03-10 11:25:51

InnoDB優(yōu)化

2023-09-27 22:44:18

數(shù)據(jù)遷移數(shù)據(jù)庫

2012-05-24 14:58:55

開源代碼

2023-08-28 08:52:49

監(jiān)聽頁面用戶

2022-04-26 06:36:09

渠道分析數(shù)據(jù)采集

2019-10-15 09:20:40

Linux系統(tǒng)服務(wù)器

2020-08-03 08:30:00

JSCSS排序

2016-09-21 10:18:26

阿里Dubbo性能測試

2025-09-03 02:46:00

Vue.js響應(yīng)式變量

2011-03-11 09:53:46

FacebookMySQL

2021-05-05 10:48:33

滲透測試漏洞網(wǎng)絡(luò)攻擊

2017-07-20 13:11:46

Code ReviewPR評審

2022-09-19 18:14:58

分布式架構(gòu)中間件

2021-08-19 09:00:12

監(jiān)控文件Python
點贊
收藏

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

色片在线免费观看| 日韩精品无码一区二区三区| 国产在线综合网| 亚洲另类春色校园小说| 欧美日韩一区视频| 97久久国产亚洲精品超碰热| 日本韩国一区| 国产一本一道久久香蕉| 91精品国产成人www| 国产又粗又长又硬| 加勒比久久高清| 欧美三级中文字幕在线观看| 欧美中日韩在线| 成人高潮成人免费观看| 国产91丝袜在线播放九色| 国产98色在线| 国产午夜精品无码一区二区| 成人精品视频| 国产视频丨精品|在线观看| 欧美午夜精品理论片| 欧美成人ⅴideosxxxxx| 亚洲成人一区二区| 免费成人进口网站| аⅴ资源新版在线天堂| 99re热这里只有精品免费视频| 国产精品美女呻吟| 午夜精品三级久久久有码| 综合久久十次| 伊人久久综合97精品| 亚洲激情 欧美| 亚洲三级av| 欧美久久久久久蜜桃| 凹凸日日摸日日碰夜夜爽1| 欧美1234区| 亚洲欧美日本在线| 国产精品夜夜夜爽张柏芝| 国产午夜精品一区理论片| 99在线热播精品免费| av激情久久| 精品国产伦一区二区三区| 精品一区二区三区蜜桃| 国产精品麻豆va在线播放| av网站中文字幕| 一本久道久久综合婷婷鲸鱼| 欧美国产日韩精品| 国产精品老熟女一区二区| 清纯唯美亚洲综合一区| 最近2019年中文视频免费在线观看| 中国美女乱淫免费看视频| 高潮按摩久久久久久av免费| 精品国产免费一区二区三区四区 | 日韩一区二区久久| 欧美激情亚洲精品| 玖玖爱免费视频| 欧美日韩99| 久久露脸国产精品| 日韩av在线播放观看| 一本综合精品| 国产成人精品av| 国产精品sm调教免费专区| 日韩成人一级大片| 国产精品爽爽爽| 91久久精品无码一区二区| 久久电影网站中文字幕| 91亚洲精品在线观看| www.国产欧美| 成人高清在线视频| 久久综合九九| caoporn国产精品免费视频| 国产精品免费人成网站| 亚洲成人动漫在线| 超碰在线网站| 欧美日韩在线第一页| 日日摸天天爽天天爽视频| 另类中文字幕国产精品| 91精品欧美福利在线观看| 欧美人与性动交α欧美精品| 欧美顶级毛片在线播放| 少妇高潮久久77777| 欧美三级 欧美一级| 亚洲午夜激情在线| 欧美尤物巨大精品爽| 在线免费观看视频网站| 高清不卡一二三区| 麻豆成人小视频| 拍真实国产伦偷精品| 亚洲国产精品一区二区久久恐怖片| 国产91在线免费| 视频欧美精品| 亚洲国产精品久久91精品| 无码少妇一区二区| 国一区二区在线观看| 青草热久免费精品视频| 国产三级按摩推拿按摩| 99精品偷自拍| 中文字幕中文字幕一区三区| аⅴ资源天堂资源库在线| 欧美午夜精品久久久久久超碰 | 久久亚洲中文字幕无码| 青青热久免费精品视频在线18| 91精品国产乱码久久蜜臀| 中出视频在线观看| 91精品一区二区三区综合| 欧洲成人性视频| 国产av无码专区亚洲av麻豆| 久久新电视剧免费观看| 亚洲va韩国va欧美va精四季| www.51av欧美视频| 欧美一区二区在线看| 亚洲国产精品成人综合久久久| 999久久久91| 全亚洲最色的网站在线观看| 亚洲国产精品久久久久久6q| 国产精品视频一二三| 激情伊人五月天| 日韩精品一区二区三区中文在线| 一区二区三区www| 日韩精品一卡二卡| 国产91丝袜在线播放| 国产日本欧美在线| 成人在线视频免费看| 亚洲毛片在线观看| 精品美女久久久久| 成人性生交大片| 国产日产欧美一区二区| 国产亚洲欧美日韩精品一区二区三区| 亚洲精品一区中文字幕乱码| 日韩特黄一级片| 国产91对白在线观看九色| dy888午夜| 亚州精品国产| 精品国产网站地址| 中文字幕永久在线观看| 国产亚洲va综合人人澡精品| 丝袜老师办公室里做好紧好爽| 国产精品2023| 久久久久久国产精品久久| 99久久精品免费看国产交换| 亚洲三级理论片| 亚洲精品乱码久久久久久动漫| 91青青国产在线观看精品| 国产精品亚洲第一区| 色多多视频在线观看| 欧美日韩视频专区在线播放| 极品人妻videosss人妻| 日韩福利视频导航| 欧美自拍资源在线| 欧美日一区二区三区| 国产一区二区av| 五月激情丁香网| 国产精品乱子久久久久| 免费一区二区三区在线观看| 久久亚洲影视| 91色视频在线导航| 五月天激情在线| 欧美mv日韩mv| 精品美女久久久久| 国产欧美视频一区二区| 中文字幕国产免费| 91精品久久久久久久蜜月| 99国产高清| 51漫画成人app入口| 日韩精品福利在线| 久一区二区三区| www.日韩在线| 欧美黑人又粗又大又爽免费| 日韩欧美精品| 99三级在线| а√在线天堂官网| 国产一区二区三区直播精品电影| 中文字幕在线观看高清| 亚洲精品亚洲人成人网| 成熟妇人a片免费看网站| 模特精品在线| 正在播放一区| 欧美日韩一区二区三区在线电影| 国产91久久婷婷一区二区| 最新真实国产在线视频| 日韩欧美在线综合网| 特级西西444www大精品视频免费看| 国产农村妇女毛片精品久久麻豆| 天堂av8在线| av成人黄色| 在线观看日韩羞羞视频| silk一区二区三区精品视频| 日韩av成人在线观看| 激情视频在线观看| 日韩精品在线免费观看视频| 亚洲网站在线免费观看| 亚洲aaa精品| 殴美一级黄色片| 91蜜桃视频在线| 两女双腿交缠激烈磨豆腐| 亚洲欧美日韩专区| 狠狠精品干练久久久无码中文字幕 | 97人人干人人| 78精品国产综合久久香蕉| 久久国产精品视频| 欧美美女色图| 欧美不卡视频一区| 亚洲熟妇无码久久精品| 亚洲va中文字幕| 久久久久久视频| 久久久.com| 亚洲一区二区在线免费| 捆绑紧缚一区二区三区视频| 欧美三级一级片| 你懂的网址国产 欧美| 手机成人在线| 中文字幕精品影院| 国产精品一区二| 999精品嫩草久久久久久99| 欧美性做爰毛片| 青青青国内视频在线观看软件| 国产一区二区三区丝袜| 欧美日韩国产中文字幕在线| 欧美va在线播放| 国产精品爽爽久久久久久| 色噜噜狠狠成人中文综合| 国产在线欧美在线| 亚洲一区在线观看免费 | 国产精品揄拍一区二区| 欧美裸体视频| 久久久亚洲国产| 伊人福利在线| 久热精品在线视频| 欧美成人精品一区二区男人看| 亚洲一区999| 蜜桃视频在线观看网站| 日韩国产欧美精品在线| www.我爱av| 日韩美女天天操| 国产三级在线观看视频| 欧美裸体bbwbbwbbw| 最新在线中文字幕| 色狠狠av一区二区三区| 国产成人在线播放视频| 亚洲r级在线视频| a v视频在线观看| 午夜av区久久| 中日韩精品视频在线观看| 婷婷久久综合九色国产成人| 日本少妇裸体做爰| 狠狠色狠狠色综合日日五| 日韩和一区二区| 偷拍与自拍一区| 国产欧美一区二区三区在线看蜜臂| 亚洲高清在线视频| 看片网址国产福利av中文字幕| 亚洲一区二区三区四区在线 | 国产精品一区二区欧美黑人喷潮水| 亚洲1区在线| 国产精品日韩欧美一区二区| 成人知道污网站| 久久青青草原| 国产亚洲电影| 亚洲日本精品| 欧美一区久久| 久久久亚洲国产精品| 午夜亚洲激情| 最新天堂中文在线| 国产精品影视天天线| 亚洲精品成人无码毛片| 99re66热这里只有精品3直播| 在线免费观看黄色小视频| 国产女主播一区| 91麻豆免费视频网站| 亚洲一区在线观看免费 | 9191国产精品| 亚洲女人18毛片水真多| 亚洲美女黄色片| 秋霞午夜在线观看| 97久久久久久| 91亚洲精品| 国产98在线|日韩| 国产尤物久久久| 手机成人av在线| 亚洲国产日韩欧美一区二区三区| 成人羞羞国产免费网站| 国产真实乱对白精彩久久| 中国极品少妇xxxx| 欧美韩国一区二区| 妺妺窝人体色www婷婷| 色婷婷久久一区二区三区麻豆| 91精品人妻一区二区三区果冻| 亚洲成人av在线播放| bbbbbbbbbbb在线视频| 欧美国产日韩精品| 日本精品裸体写真集在线观看| 亚洲自拍偷拍第一页| 日韩伦理一区二区三区| 一区二区在线观看网站| 亚洲激情网址| 99国产精品久久久久久| 91女人视频在线观看| 国产精品成人69xxx免费视频| 亚洲成av人片一区二区梦乃| 中文字幕在线视频第一页| 亚洲国产精品视频在线观看| 日本www在线| 国产精品高潮呻吟久久av无限 | 色一情一乱一伦一区二区三区| 欧美欧美全黄| 亚洲欧美久久久久| 91免费观看在线| 国产精选第一页| 欧美一区午夜视频在线观看| 国外av在线| 97视频在线观看成人| 精品国产18久久久久久二百| 色婷婷精品国产一区二区三区| 国产欧美另类| 国产性猛交96| 有码一区二区三区| 中文字幕在线一| 亚洲欧美制服丝袜| 182在线视频观看| yellow视频在线观看一区二区| 久久精品国产www456c0m| 韩国日本在线视频| 26uuu亚洲婷婷狠狠天堂| 精品处破女学生| 日韩片之四级片| 成人a在线视频免费观看| 国产精品美女久久久久av超清| 免费一区二区三区视频导航| 霍思燕三级露全乳照| 丁香婷婷综合色啪| 加勒比av在线播放| 欧美一区二区三区免费在线看| 日本电影在线观看网站| 国产精品视频免费在线| 国产真实有声精品录音| 国产三级日本三级在线播放| 久久久久免费观看| 亚洲天堂视频网站| 亚洲欧美国产精品久久久久久久| 天天综合av| 欧美一区1区三区3区公司 | 天天射综合影视| 天堂在线视频免费| 国产最新精品视频| 欧美理伦片在线播放| 男女超爽视频免费播放| 北岛玲一区二区三区四区| 精品91久久久| 亚洲人成毛片在线播放| 精品视频在线一区二区在线| 日韩中文字幕一区二区| 麻豆精品一区二区三区| 娇小11一12╳yⅹ╳毛片| 7777精品伊人久久久大香线蕉完整版| 自拍视频在线免费观看| 成人精品aaaa网站| 欧美视频福利| 亚洲啪av永久无码精品放毛片 | 91成品人影院| 美女视频久久黄| 超碰成人在线观看| 日韩欧美亚洲天堂| 国产偷v国产偷v亚洲高清| 在线观看中文字幕码| 欧美丰满少妇xxxxx做受| 噜噜噜狠狠夜夜躁精品仙踪林| 日本精品一区在线观看| 国产亚洲自拍一区| 国产又黄又粗又猛又爽| 久久69精品久久久久久久电影好| 精品亚洲免a| 亚洲乱码国产一区三区| 亚洲日本va午夜在线影院| 好吊色一区二区三区| 欧美亚洲在线播放| 日韩欧美大片| 国产成人精品一区二区在线小狼| 午夜视黄欧洲亚洲| 丁香在线视频| 3d蒂法精品啪啪一区二区免费| 夜久久久久久| 久久精品一区二区三区四区五区| 精品久久久久av影院| 蜜臀国产一区| 成年人三级视频| 久久久国产午夜精品| 99久久免费国产精精品| 国产69久久精品成人| 999久久久91| 中文字幕av网址| 日韩一区二区精品葵司在线| 在线中文字幕播放| 18视频在线观看娇喘| 91免费精品国自产拍在线不卡| 国产免费久久久| 人九九综合九九宗合| 综合天堂久久久久久久| 18禁裸乳无遮挡啪啪无码免费| 欧美一级夜夜爽| 黄色精品视频网站| 欧美日韩激情视频在线观看| 亚洲四区在线观看|