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

Vue中使用裝飾器,我是認真的

開發 前端
本文題目是Vue中使用裝飾器,我是認真的,但本文將從裝飾器的概念開發聊起,一起來看看吧。

[[336212]]

作為一個曾經的Java coder, 當我第一次看到js里面的裝飾器(Decorator)的時候,就馬上想到了Java中的注解,當然在實際原理和功能上面,Java的注解和js的裝飾器還是有很大差別的。本文題目是Vue中使用裝飾器,我是認真的,但本文將從裝飾器的概念開發聊起,一起來看看吧。

通過本文內容,你將學到以下內容:

  1. 了解什么是裝飾器
  2. 在方法使用裝飾器
  3. 在class中使用裝飾器
  4. 在Vue中使用裝飾器

本文首發于公眾號【前端有的玩】,不想當咸魚,想要換工作,關注公眾號,帶你每日一起刷大廠面試題,關注 === 大廠offer。

什么是裝飾器

裝飾器是ES2016提出來的一個提案,當前處于Stage 2階段,關于裝飾器的體驗,可以點擊 https://github.com/tc39/proposal-decorators查看詳情。裝飾器是一種與類相關的語法糖,用來包裝或者修改類或者類的方法的行為,其實裝飾器就是設計模式中裝飾者模式的一種實現方式。不過前面說的這些概念太干了,我們用人話來翻譯一下,舉一個例子。

在日常開發寫bug過程中,我們經常會用到防抖和節流,比如像下面這樣 

  1. class MyClass {  
  2.   follow = debounce(function() {  
  3.     console.log('我是子君,關注我哦')  
  4.   }, 100)  
  5.  
  6. const myClass = new MyClass()  
  7. // 多次調用只會輸出一次  
  8. myClass.follow()  
  9. myClass.follow()  

上面是一個防抖的例子,我們通過debounce函數將另一個函數包起來,實現了防抖的功能,這時候再有另一個需求,比如希望在調用follow函數前后各打印一段日志,這時候我們還可以再開發一個log函數,然后繼續將follow包裝起來 

  1. /**  
  2.  * 最外層是防抖,否則log會被調用多次  
  3.  */  
  4. class MyClass {  
  5.   follow = debounce 
  6.     log(function() {  
  7.       console.log('我是子君,關注我哦')  
  8.     }),  
  9.     100  
  10.   )  
  11.  

上面代碼中的debounce和log兩個函數,本質上是兩個包裝函數,通過這兩個函數對原函數的包裝,使原函數的行為發生了變化,而js中的裝飾器的原理就是這樣的,我們使用裝飾器對上面的代碼進行改造 

  1. class MyClass {  
  2.   @debounce(100)  
  3.   @log  
  4.   follow() {  
  5.     console.log('我是子君,關注我哦')  
  6.   }  
  7.  

裝飾器的形式就是 @ + 函數名,如果有參數的話,后面的括號里面可以傳參

在方法上使用裝飾器

裝飾器可以應用到class上或者class里面的屬性上面,但一般情況下,應用到class屬性上面的場景會比較多一些,比如像上面我們說的log,debounce等等,都一般會應用到類屬性上面,接下來我們一起來具體看一下如何實現一個裝飾器,并應用到類上面。在實現裝飾器之前,我們需要先了解一下屬性描述符

了解一下屬性描述符

在我們定義一個對象里面的屬性的時候,其實這個屬性上面是有許多屬性描述符的,這些描述符標明了這個屬性能不能修改,能不能枚舉,能不能刪除等等,同時ECMAScript將這些屬性描述符分為兩類,分別是數據屬性和訪問器屬性,并且數據屬性與訪問器屬性是不能共存的。

數據屬性

數據屬性包含一個數據值的位置,在這個位置可以讀取和寫入值。數據屬性包含了四個描述符,分別是

  1. configurable

表示能不能通過delete刪除屬性,能否修改屬性的其他描述符特性,或者能否將數據屬性修改為訪問器屬性。當我們通過let obj = {name: ''}聲明一個對象的時候,這個對象里面所有的屬性的configurable描述符的值都是true

      2. enumerable

表示能不能通過for in或者Object.keys等方式獲取到屬性,我們一般聲明的對象里面這個描述符的值是true,但是對于class類里面的屬性來說,這個值是false

      3. writable

表示能否修改屬性的數據值,通過將這個修改為false,可以實現屬性只讀的效果。

      4. value

表示當前屬性的數據值,讀取屬性值的時候,從這里讀取;寫入屬性值的時候,會寫到這個位置。

訪問器屬性

訪問器屬性不包含數據值,他們包含了getter與setter兩個函數,同時configurable與enumerable是數據屬性與訪問器屬性共有的兩個描述符。

      1. getter

在讀取屬性的時候調用這個函數,默認這個函數為undefined

      2. setter

在寫入屬性值的時候調用這個函數,默認這個函數為undefined

了解了這六個描述符之后,你可能會有幾個疑問: 我如何去定義修改這些屬性描述符?這些屬性描述符與今天的文章主題有什么關系?接下來是揭曉答案的時候了。

使用Object.defineProperty

了解過vue2.0雙向綁定原理的同學一定知道,Vue的雙向綁定就是通過使用Object.defineProperty去定義數據屬性的getter與setter方法來實現的,比如下面有一個對象 

  1. let obj = {  
  2.   name: '子君',  
  3.   officialAccounts: '前端有的玩'  
  4.  

我希望這個對象里面的用戶名是不能被修改的,用Object.defineProperty該如何定義呢? 

  1. Object.defineProperty(obj,'name', {  
  2.   // 設置writable 是 false, 這個屬性將不能被修改  
  3.   writable: false  
  4. })  
  5. // 修改obj.name  
  6. obj.name = "君子"  
  7. // 打印依然是子君  
  8. console.log(obj.name)  

通過Object.defineProperty可以去定義或者修改對象屬性的屬性描述符,但是因為數據屬性與訪問器屬性是互斥的,所以一次只能修改其中的一類,這一點需要注意。

定義一個防抖裝飾器

裝飾器本質上依然是一個函數,不過這個函數的參數是固定的,如下是防抖裝飾器的代碼 

  1. /**  
  2. *@param wait 延遲時長  
  3. */  
  4. function debounce(wait) {  
  5.   return function(target, name, descriptor) {  
  6.     descriptor.value = debounce(descriptor.value, wait)  
  7.   }  
  8.  
  9. // 使用方式  
  10. class MyClass {  
  11.   @debounce(100)  
  12.   follow() {  
  13.     console.log('我是子君,我的公眾號是 【前端有的玩】,關注有驚喜哦')  
  14.   }  
  15.  

我們逐行去分析一下代碼

  1. 首先我們定義了一個 debounce函數,同時有一個參數wait,這個函數對應的就是在下面調用裝飾器時使用的@debounce(100)
  2. debounce函數返回了一個新的函數,這個函數即裝飾器的核心,這個函數有三個參數,下面逐一分析
    1. target: 這個類屬性函數是在誰上面掛載的,如上例對應的是MyClass類
    2. name: 這個類屬性函數的名稱,對應上面的follow
    3. descriptor: 這個就是我們前面說的屬性描述符,通過直接descriptor上面的屬性,即可實現屬性只讀,數據重寫等功能

      3. 然后第三行 descriptor.value = debounce(descriptor.value, wait), 前面我們已經了解到,屬性描述符上面的value對應的是這個屬性的值,所以我們通過重寫這個屬性,將其用debounce函數包裝起來,這樣在函數調用follow時實際調用的是包裝后的函數

通過上面的三步,我們就實現了類屬性上面可使用的裝飾器,同時將其應用到了類屬性上面

在class上使用裝飾器

裝飾器不僅可以應用到類屬性上面,還可以直接應用到類上面,比如我希望可以實現一個類似Vue混入那樣的功能,給一個類混入一些方法屬性,應該如何去做呢? 

  1. // 這個是要混入的對象  
  2. const methods = {  
  3.   logger() {  
  4.     console.log('記錄日志')  
  5.   }  
  6.  
  7. // 這個是一個登陸登出類  
  8. class Login{  
  9.   login() {}  
  10.   logout() {} 
  11.  

如何將上面的methods混入到Login中,首先我們先實現一個類裝飾器 

  1. function mixins(obj) {  
  2.   return function (target) {  
  3.     Object.assign(target.prototype, obj)    
  4.   }  
  5.  
  6. // 然后通過裝飾器混入  
  7. @mixins(methods)  
  8. class Login{  
  9.   login() {}  
  10.   logout() {}  
  11.  

這樣就實現了類裝飾器。對于類裝飾器,只有一個參數,即target,對應的就是這個類本身。

了解完裝飾器,我們接下來看一下如何在Vue中使用裝飾器。

在Vue中使用裝飾器

使用ts開發Vue的同學一定對vue-property-decorator不會感到陌生,這個插件提供了許多裝飾器,方便大家開發的時候使用,當然本文的中點不是這個插件。其實如果我們的項目沒有使用ts,也是可以使用裝飾器的,怎么用呢?

配置基礎環境

除了一些老的項目,我們現在一般新建Vue項目的時候,都會選擇使用腳手架vue-cli3/4來新建,這時候新建的項目已經默認支持了裝飾器,不需要再配置太多額外的東西,如果你的項目使用了eslint,那么需要給eslint配置以下內容。 

  1. parserOptions: {  
  2.    ecmaFeatures:{  
  3.      // 支持裝飾器  
  4.      legacyDecorators: true  
  5.    }  
  6.  }  

使用裝飾器

雖然Vue的組件,我們一般書寫的時候export出去的是一個對象,但是這個并不影響我們直接在組件中使用裝飾器,比如就拿上例中的log舉例。 

  1. function log() {  
  2.   /**  
  3.    * @param target 對應 methods 這個對象  
  4.    * @param name 對應屬性方法的名稱  
  5.    * @param descriptor 對應屬性方法的修飾符  
  6.    */  
  7.   return function(target, name, descriptor) {  
  8.     console.log(target, name, descriptor)  
  9.     const fn = descriptor.value  
  10.     descriptor.value = function(...rest) {  
  11.       console.log(`這是調用方法【${name}】前打印的日志`)  
  12.       fn.call(this, ...rest)  
  13.       console.log(`這是調用方法【${name}】后打印的日志`)  
  14.     }  
  15.   }  
  16.  
  17. export default {  
  18.   created() {  
  19.     this.getData()  
  20.   },  
  21.   methods: {  
  22.     @log()  
  23.     getData() {  
  24.       console.log('獲取數據')  
  25.     }  
  26.   }  
  27.  

看了上面的代碼,是不是發現在Vue中使用裝飾器還是很簡單的,和在class的屬性上面使用的方式一模一樣,但有一點需要注意,在methods里面的方法上面使用裝飾器,這時候裝飾器的target對應的是methods。

除了在methods上面可以使用裝飾器之外,你也可以在生命周期鉤子函數上面使用裝飾器,這時候target對應的是整個組件對象。

一些常用的裝飾器

下面小編羅列了幾個小編在項目中常用的幾個裝飾器,方便大家使用

1. 函數節流與防抖

函數節流與防抖應用場景是比較廣的,一般使用時候會通過throttle或debounce方法對要調用的函數進行包裝,現在就可以使用上文說的內容將這兩個函數封裝成裝飾器, 防抖節流使用的是lodash提供的方法,大家也可以自行實現節流防抖函數哦 

  1. import { throttle, debounce } from 'lodash'  
  2. /**  
  3.  * 函數節流裝飾器  
  4.  * @param {number} wait 節流的毫秒  
  5.  * @param {Object} options 節流選項對象  
  6.  * [options.leading=true] (boolean): 指定調用在節流開始前。  
  7.  * [options.trailing=true] (boolean): 指定調用在節流結束后。  
  8.  */  
  9. export const throttle =  function(wait, options = {}) {  
  10.   return function(target, name, descriptor) {  
  11.     descriptor.value = throttle(descriptor.value, wait, options)  
  12.   }  
  13.  
  14. /**  
  15.  * 函數防抖裝飾器  
  16.  * @param {number} wait 需要延遲的毫秒數。  
  17.  * @param {Object} options 選項對象  
  18.  * [options.leading=false] (boolean): 指定在延遲開始前調用。  
  19.  * [options.maxWait] (number): 設置 func 允許被延遲的最大值。  
  20.  * [options.trailing=true] (boolean): 指定在延遲結束后調用。  
  21.  */  
  22. export const debounce = function(wait, options = {}) {  
  23.   return function(target, name, descriptor) {  
  24.     descriptor.value = debounce(descriptor.value, wait, options)  
  25.   }  
  26.  

封裝完之后,在組件中使用 

  1. import {debounce} from '@/decorator'  
  2. export default {  
  3.   methods:{  
  4.     @debounce(100) 
  5.      resize(){}  
  6.   }  
  7.  

2. loading

在加載數據的時候,為了個用戶一個友好的提示,同時防止用戶繼續操作,一般會在請求前顯示一個loading,然后在請求結束之后關掉loading,一般寫法如下 

  1. export default {  
  2.   methods:{  
  3.     async getData() {  
  4.       const loading = Toast.loading()  
  5.       try{  
  6.         const data = await loadData()  
  7.         // 其他操作  
  8.       }catch(error){  
  9.         // 異常處理  
  10.         Toast.fail('加載失敗');  
  11.       }finally{  
  12.         loading.clear()  
  13.       }    
  14.     }  
  15.   }  
  16.  

我們可以把上面的loading的邏輯使用裝飾器重新封裝,如下代碼 

  1. import { Toast } from 'vant'  
  2. /**  
  3.  * loading 裝飾器  
  4.  * @param {*} message 提示信息  
  5.  * @param {function} errorFn 異常處理邏輯  
  6.  */  
  7. export const loading =  function(message = '加載中...'errorFn = function() {}) {  
  8.   return function(target, name, descriptor) {  
  9.     const fn = descriptor.value  
  10.     descriptor.value = async function(...rest) {  
  11.       const loading = Toast.loading({  
  12.         message: message,  
  13.         forbidClick: true  
  14.       })  
  15.       try {  
  16.         return await fn.call(this, ...rest)  
  17.       } catch (error) {  
  18.         // 在調用失敗,且用戶自定義失敗的回調函數時,則執行  
  19.         errorFn && errorFn.call(this, error, ...rest)  
  20.         console.error(error) 
  21.        } finally {  
  22.         loading.clear()  
  23.       }  
  24.     }  
  25.   }  
  26.  

然后改造上面的組件代碼 

  1. export default {  
  2.   methods:{  
  3.     @loading('加載中')  
  4.     async getData() {  
  5.       try{  
  6.         const data = await loadData()  
  7.         // 其他操作  
  8.       }catch(error){  
  9.         // 異常處理  
  10.         Toast.fail('加載失敗');  
  11.       }    
  12.     }  
  13.   }  
  14.  

3. 確認框

當你點擊刪除按鈕的時候,一般都需要彈出一個提示框讓用戶確認是否刪除,這時候常規寫法可能是這樣的 

  1. import { Dialog } from 'vant'  
  2. export default {  
  3.   methods: {  
  4.     deleteData() {  
  5.       Dialog.confirm({  
  6.         title: '提示', 
  7.          message: '確定要刪除數據,此操作不可回退。'  
  8.       }).then(() => {  
  9.         console.log('在這里做刪除操作')  
  10.       })  
  11.     }  
  12.   }  
  13.  

我們可以把上面確認的過程提出來做成裝飾器,如下代碼 

  1. import { Dialog } from 'vant'  
  2. /**  
  3.  * 確認提示框裝飾器  
  4.  * @param {*} message 提示信息  
  5.  * @param {*} title 標題  
  6.  * @param {*} cancelFn 取消回調函數  
  7.  */  
  8. export function confirm( 
  9.    message = '確定要刪除數據,此操作不可回退。' 
  10.   title = '提示' 
  11.   cancelFn = function() {}  
  12. ) {  
  13.   return function(target, name, descriptor) {  
  14.     const originFn = descriptor.value  
  15.     descriptor.value = async function(...rest) {  
  16.       try {  
  17.         await Dialog.confirm({  
  18.           message,  
  19.           title: title  
  20.         })  
  21.         originFn.apply(this, rest)  
  22.       } catch (error) {  
  23.         cancelFn && cancelFn(error)  
  24.       }  
  25.     }  
  26.   }  
  27.  

然后再使用確認框的時候,就可以這樣使用了 

  1. export default {  
  2.   methods: {  
  3.     // 可以不傳參,使用默認參數  
  4.     @confirm()  
  5.     deleteData() {  
  6.       console.log('在這里做刪除操作')  
  7.     } 
  8.   }  
  9.  

是不是瞬間簡單多了,當然還可以繼續封裝很多很多的裝飾器,因為文章內容有限,暫時提供這三個。

裝飾器組合使用

在上面我們將類屬性上面使用裝飾器的時候,說道裝飾器可以組合使用,在Vue組件上面使用也是一樣的,比如我們希望在確認刪除之后,調用接口時候出現loading,就可以這樣寫(一定要注意順序) 

  1. export default {  
  2.   methods: {  
  3.     @confirm()  
  4.     @loading()  
  5.     async deleteData() {  
  6.       await delete()  
  7.     }  
  8.   }  
  9.  

本節定義的裝飾器,均已應用到這個項目中 https://github.com/snowzijun/vue-vant-base, 這是一個基于Vant開發的開箱即用移動端框架,你只需要fork下來,無需做任何配置就可以直接進行業務開發,歡迎使用,喜歡麻煩給一個star。

我是子君,今天就寫這么多,本文首發于【前端有的玩】,這是一個專注于前端技術,前端面試相關的公眾號,同時關注之后即刻拉你加入前端交流群,我們一起聊前端,歡迎關注。

結語

不要吹滅你的靈感和你的想象力; 不要成為你的模型的奴隸。 ——文森特・梵高 

 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2013-05-21 09:32:11

ChromebookChrome OS

2016-09-23 18:40:42

微軟開源代碼開源社區

2022-05-10 09:12:16

TypeScript裝飾器

2024-11-04 15:30:43

Python裝飾器函數

2021-02-18 15:43:37

Python裝飾器Decorator

2010-02-01 17:50:32

Python裝飾器

2021-09-28 14:07:06

Databricks九章云極

2020-08-06 14:10:41

Facebook 開發TikTok

2017-11-08 09:50:58

數據庫關系數據庫Oracle

2014-05-26 15:20:13

產品細節工匠情懷

2021-06-17 09:32:17

前端TypeScript 技術熱點

2020-12-30 09:43:04

互聯網微軟芯片

2016-09-22 14:22:06

數據中心節約能源

2022-09-14 08:16:48

裝飾器模式對象

2009-12-25 18:12:43

WPF裝飾器

2017-07-14 10:10:08

Vue.jsMixin

2021-08-01 07:58:58

Vue 加載組件

2024-09-12 15:32:35

裝飾器Python
點贊
收藏

51CTO技術棧公眾號

亚洲日穴在线视频| 日韩成人免费在线观看| 中文字幕在线观看国产| 亚洲日本视频在线| 欧美经典一区二区| 97在线视频精品| 亚洲日本精品国产第一区| 久久精品国产亚洲AV无码麻豆| 日韩制服一区| 91麻豆精东视频| 国内成人精品一区| av噜噜在线观看| av在线电影网| 国产美女撒尿一区二区| 亚洲日韩欧美一区二区在线| 国产一区二区久久久| 欧美性猛交xxxxx少妇| 国产成人77亚洲精品www| 久久婷婷色综合| 97精品国产97久久久久久春色| www.中文字幕av| 老色鬼在线视频| 成人一区二区三区在线观看| 久久国产视频网站| 男女污污视频网站| 免费av网站在线看| 蜜臀av性久久久久蜜臀aⅴ | 国产日本一区二区| 午夜精品福利电影| 熟女少妇a性色生活片毛片| abab456成人免费网址| 一区二区视频在线| 99视频在线免费观看| 加勒比av在线播放| 成人另类视频| 欧美日韩视频在线| 欧美日韩精品免费观看视一区二区| 欧美精品久久久久性色| 成人av国产| 欧美日本在线播放| 好吊色视频988gao在线观看| 国产99视频在线| 亚洲小说区图片区| 日韩成人网免费视频| 成人免费观看视频在线观看| 手机看片1024日韩| 亚洲欧美日韩专区| 色哟哟亚洲精品一区二区| 性猛交ⅹ×××乱大交| 久操视频在线免费播放| 国产成人免费在线视频| 欧美黄色性视频| 免费无码一区二区三区| 午夜精品久久久久久久久久蜜桃| 国产亚洲一区二区三区四区| 国产精品久久久一区二区三区| 国产成人无码精品久久久久| 欧洲三级视频| 欧美一级高清片| www国产精品内射老熟女| 国产福利在线观看| 国产成人在线电影| 2022国产精品| 国产一级淫片a视频免费观看| 波多野结衣在线观看一区二区| 亚洲欧美国产精品久久久久久久| 在线观看高清免费视频| 中中文字幕av在线| www一区二区| 精品欧美日韩| 国产乱子伦精品无码码专区| 黄色国产精品| 中文国产成人精品| 不许穿内裤随时挨c调教h苏绵 | 欧美日韩夜夜| 欧美三级电影网站| 久久精品无码中文字幕| www.成人.com| 国产精品美女久久久久高潮| 国产精品美女黄网| 人妻无码一区二区三区久久99| 日本大胆欧美人术艺术动态| 欧美猛交免费看| 日本少妇高潮喷水xxxxxxx| 国产视频一区二区在线播放| 欧美性极品少妇精品网站| 国产精品波多野结衣| 日产精品久久久久久久性色| 国产精品影音先锋| 国产精品视频公开费视频| 国产精品第九页| 国产日韩欧美一区| 欧美激情欧美激情| 亚洲熟女综合色一区二区三区| 天堂影院一区二区| 8x海外华人永久免费日韩内陆视频| 亚洲欧洲综合网| 精品国产中文字幕第一页| 深夜福利亚洲导航| 精品无码久久久久久久| 91精品国偷自产在线电影| 亚洲偷欧美偷国内偷| 视频免费在线观看| 99a精品视频在线观看| 亚洲精品乱码久久久久久按摩观| 亚洲精品国产91| 中文字幕一区二区三区在线视频 | 午夜视频一区二区| 欧美 日韩 国产精品| 91精彩视频在线观看| 国产亚洲欧美色| 国风产精品一区二区| 一区二区乱码| 狠狠综合久久av一区二区小说| 香港日本韩国三级网站| 精品国产影院| 日韩av在线一区| 亚洲人与黑人屁股眼交| 国产伦理一区| 91久久精品一区二区别| 久久精品蜜桃| 国产网站一区二区| 成年在线观看视频| 91在线成人| 日韩av一区二区在线| 国产女人18水真多毛片18精品| 天天射综合网视频| 色偷偷综合社区| 亚洲 欧美 日韩 综合| 国产精品婷婷| 91免费版黄色| 免费在线观看av| 色综合天天性综合| 老司机午夜av| 成人在线免费| 日韩国产欧美区| 妺妺窝人体色www聚色窝仙踪| 蜜臀av性久久久久蜜臀aⅴ流畅| 久久伊人资源站| 国产视频精选在线| 欧美日韩国产在线播放| 绯色av蜜臀vs少妇| 亚洲电影影音先锋| 国产在线拍偷自揄拍精品| 一级片在线观看视频| 狠狠色狠狠色综合日日91app| 亚洲一区二区日本| 天天av天天翘| 亚洲一区在线观看免费| 男女激情无遮挡| 亚洲va中文在线播放免费| 亚洲第一网站男人都懂| 久久久久久国产精品无码| 亚洲午夜91| 国产精品av一区| 国产三级视频在线| 色婷婷综合久久| 六月婷婷七月丁香| 久久久久99| 91久久精品国产91性色| 欧美自拍偷拍第一页| 一区二区三区在线视频播放 | 国产成人免费视频网站| 特级西西444| caoporn成人| 97人人爽人人喊人人模波多| 四虎影视精品成人| 中文字幕不卡在线观看| 免费极品av一视觉盛宴| 精品国产一区二区三区2021| 日韩高清有码在线| 少妇太紧太爽又黄又硬又爽| 精品一区二区三区影院在线午夜| 国产乱码一区| 蜜臀久久精品| 亚洲少妇中文在线| 麻豆一区产品精品蜜桃的特点| 国产精品2024| 日韩国产成人无码av毛片| 日韩精品99| 日韩在线视频线视频免费网站| 国产一区二区视频免费观看| 亚洲黄色小视频| 亚洲高清无码久久| 天天天综合网| 97在线电影| 久久青草伊人| 日韩亚洲欧美中文高清在线| 精品在线播放视频| 国产三级久久久| 一级黄色片在线免费观看| 国产一区日韩一区| 日本一区二区精品| 国产不卡人人| 在线观看日韩一区| 黄瓜视频污在线观看| 亚洲激情网址| 国产成人免费电影| 3d性欧美动漫精品xxxx软件| 日韩高清人体午夜| 中文字幕人妻色偷偷久久| 亚洲精品久久嫩草网站秘色| 日本丰满少妇裸体自慰| 在线观看的日韩av| 午夜精品短视频| 三级成人在线| 欧美极品少妇xxxxⅹ裸体艺术| 国产视频一二三四区| 国产精品人妖ts系列视频| 性色av浪潮av| 欧美日韩亚洲一区| http;//www.99re视频| 综合另类专区| 亚洲天堂av综合网| 亚洲精品成av人片天堂无码| 亚洲人午夜精品天堂一二香蕉| 偷偷色噜狠狠狠狠的777米奇| 蜜臀av在线播放一区二区三区| 黄色国产一级视频| 亚洲精品极品少妇16p| 欧美日韩免费观看一区| 1204国产成人精品视频| 国产日韩在线免费| 中文不卡1区2区3区| 欧美高清视频在线播放| 免费在线观看av网站| 一区二区亚洲欧洲国产日韩| 一区二区视频网站| 狠狠躁夜夜躁人人爽超碰91| 久久亚洲成人av| 亚洲精品免费播放| 欧美人与禽zoz0善交| 裸体在线国模精品偷拍| 亚洲美女自拍偷拍| 国产一区二区区别| 成人av在线网址| 青青青草视频在线| 亚洲精品视频在线播放| 日韩一级在线视频| 天天综合日日夜夜精品| 国产人妻一区二区| 91免费国产在线| 欧美成人三级伦在线观看| 国产suv精品一区二区883| 亚洲不卡中文字幕无码| 欧美黄污视频| 欧美高清视频一区| 特黄特色欧美大片| 成人性教育视频在线观看| 日韩av一级| 国产精品亚洲激情| 国产精品69xx| 在线视频一区二区| av在线天堂| 最近中文字幕2019免费| 2019中文字幕在线视频| 在线电影av不卡网址| 二人午夜免费观看在线视频| 影音先锋欧美精品| 午夜精品一区| 日韩高清a**址| 亚洲 国产 欧美 日韩| 欧美色倩网站大全免费| 这里只有精品999| 亚洲福利视频一区二区| 91动漫免费网站| 成人av综合一区| www.久久av.com| 亚洲欧美日韩国产一区| 黄色国产精品视频| 欧美日韩岛国| 97在线国产视频| 亚洲综合日本| 在线观看的毛片| 国内精品伊人久久久久av一坑| 潘金莲一级淫片aaaaaaa| www.性欧美| 深夜福利网站在线观看| 玖玖精品视频| 天堂社区在线视频| 9色精品在线| 免费人成在线观看视频播放| 日韩五码在线| 嫩草av久久伊人妇女超级a| 久久国产精品区| 日日夜夜精品视频免费观看 | 国产日韩中文在线| 亚洲天堂av资源在线观看| 国产伦精品一区二区三区视频孕妇| 久久资源综合| 色噜噜色狠狠狠狠狠综合色一| 97久久夜色精品国产| 日本在线视频一区| 国产一级成人av| 欧美日韩综合网| 亚洲午夜精品一区 二区 三区| 日本中文字幕网址| 国产在线精品视频| 亚洲18在线看污www麻豆| 风流少妇一区二区| 手机av在线不卡| 午夜国产精品一区| 国产精品亚洲lv粉色| 日韩成人激情在线| 中文字幕资源网在线观看| 日韩免费黄色av| 亚洲黄色网址| 成人做爽爽免费视频| 亚洲+变态+欧美+另类+精品| 亚洲在线视频福利| 亚洲最好看的视频| 女人被男人躁得好爽免费视频 | 中文字幕男人天堂| 亚洲第五色综合网| 日本三级视频在线观看| 青青精品视频播放| 成人勉费视频| 2014亚洲精品| 久久在线电影| www.国产区| 奇米精品一区二区三区在线观看一 | 欧美这里有精品| 天天综合网在线| 欧美精品在线播放| 国产经典一区| 久久久久久九九| 成人黄色免费观看| 国产在线观看一区| 欧美网站在线| 亚洲丝袜在线观看| 亚洲天堂网中文字| 中国女人一级一次看片| 亚洲欧美一区二区三区久久| 草草在线视频| 国产一区二区三区av在线| 欧美 亚欧 日韩视频在线 | 国产999精品久久| 日本中文在线视频| 亚洲一区欧美一区| 99免费在线视频| 北条麻妃99精品青青久久| 成人av集中营| 亚洲欧美久久久久一区二区三区| 中文在线播放一区二区 | 日韩电影大全网站| 欧美日韩国产高清视频| 国产精品美女久久久| 国产黑丝在线观看| 岛国av在线不卡| 天堂av在线7| 国产成人精品免费久久久久| 国产精品诱惑| 亚洲综合成人婷婷小说| 国产精品久久久久蜜臀| 狠狠干狠狠操视频| 亚洲色图清纯唯美| 999久久久久| 欧美激情a∨在线视频播放| 超碰97久久| 你懂的av在线| 国产亚洲精久久久久久| 成人免费一区二区三区| 最新91在线视频| 精品视频国内| 日韩国产小视频| fc2成人免费人成在线观看播放 | 99精品99久久久久久宅男| 欧美在线免费| 中文字幕一区二区人妻电影丶| 欧美日韩亚洲系列| www免费网站在线观看| 成人激情综合网| 一区福利视频| 西西444www无码大胆| 欧美日韩和欧美的一区二区| 久久五月精品| 国内精品久久国产| 日韩av电影天堂| 极品盗摄国产盗摄合集| 亚洲精品不卡在线| 成人国产免费电影| 日韩免费精品视频| 日韩一区欧美| 91网址在线播放| 亚洲人成精品久久久久| 粉嫩av一区二区夜夜嗨| 操日韩av在线电影| 国产成人午夜性a一级毛片| 日本福利视频导航| 99在线视频精品| 欧美激情一区二区三区免费观看 | 91久色国产| 老牛嫩草一区二区三区日本 | 欧美一级在线播放| 最新国产一区二区| 亚洲国产精品毛片av不卡在线| 亚洲欧洲日本在线| 一区二区精品视频在线观看| 久久久久女教师免费一区| 精品国产一区二区三区香蕉沈先生|