久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

element ui 多个子组件_ElementUI 技术揭秘(2) 组件库的整体设计

發布時間:2024/7/23 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 element ui 多个子组件_ElementUI 技术揭秘(2) 组件库的整体设计 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

需求分析

當我們去實現一個組件庫的時候,并不會一上來就擼碼,而是把它當做產品一樣,思考一下我們的組件庫的需求。那么對于 element-ui,除了基于 Vue.js 技術棧開發組件,它還有哪些方面的需求呢。

  • 豐富的 feature:豐富的組件,自定義主題,國際化。

  • 文檔 & demo:提供友好的文檔和 demo,維護成本小,支持多語言。

  • 安裝 & 引入:支持 npm 方式和 cdn 方式,并支持按需引入。

  • 工程化:開發,測試,構建,部署,持續集成。

  • 需求有了,接下來就需要去思考如何去實現,本文會依據 element-ui 2.11.1 版本的源碼來分析這些需求是如何實現的。當然,element-ui 早期一定不是這樣子的,我們分析的這個版本已經是經過它多次迭代優化后的,如果你想去了解它的發展歷程,可以去 GitHub 搜索它的歷史版本。

    豐富的 feature

    豐富的組件

    組件庫最核心的還是組件,先來看一下 element-ui 組件的設計原則:一致、反饋、效率、可控。具體的解釋在官網有,我就不多貼了,在 element-ui 開發團隊背后,有一個強大的設計團隊,這也得益于 element-ui 的創始人 sofish 在公司的話語權和地位,爭取到這么好的資源。所以 element-ui 組件的外型、配色、交互都做的非常不錯。

    作為一個基礎組件庫,還有一個很重要的方面就是組件種類豐富。element-ui 官方目前有 55 個組件,分成了 6 大類,分別是基礎組件、表單類組件、數據類組件、提示類組件、導航類組件和其它類型組件。這些豐富的基礎組件能很好地滿足大部分 PC 端 to B 業務開發需求。

    開發這么多組件,需要大量的時間和精力,所以這里要非常感謝 element-ui 團隊,為我們提供了這些基礎組件,我們基于它們做二次開發,節約了非常多的時間。

    element-ui 的組件源碼在 packages 目錄里維護,而并不在 src 目錄中。這么做并不是為了要采用 monorepo,我也并沒有找到 lerna 包管理工具,這么做的目的我猜測是為了讓每個組件可以單獨打包,支持按需引入。但實際上想達到這個目的也并不一定需要這么去組織維護代碼,我更推薦把組件庫中的組件代碼放在 src/components 目錄中維護,然后通過修改 webpack 配置腳本也可以做到每個組件單獨打包以及支持按需引入,源碼放在 src 目錄總是更合理的。

    自定義主題

    element-ui 的一大特色是支持自定義主題,你可以使用在線主題編輯器,可以修改定制 Element 所有全局和組件的 Design Tokens,并可以方便地實時預覽樣式改變后的視覺。同時它還可以基于新的定制樣式生成完整的樣式文件包,供直接下載使用,那么它是如何做到這點的呢?

    element-ui 組件的樣式、公共樣式都在 packages/theme-chalk 文件中,并且它是可以獨立發布的。element-ui 組件樣式中的顏色、字體、線條等等樣式都是通過變量的方式引入的,在 packages/theme-chalk/src/common/var.scss 中我們可以看到這些變量的定義,這樣就給做多主題提供了方便,因為我只要修改這些變量,就可以實現組件的主題改變。

    了解了基本原理,做在線替換主題也并不是難事了,我并不會詳細去講在線定制主題前端交互部分,感興趣的同學可以自己去看源碼,都在 examples 目錄中,我這里只說一下本質的原理。

    想要做到在線換膚,并且實時預覽,需要借助 server 的幫助,比如主題可以通過一個配置去維護,用戶做一系列操作后,會生成新的主題配置,把這個配置通過接口提交的方式告訴 server,然后 server 會根據這個配置做返回生成新的 CSS(具體的實施的方案未開源,大致會做一些變量替換,然后編譯),新的 CSS 的樣式就會覆蓋默認的樣式,達到了切換主題的目的。

    我們可以在主題編輯頁面打開網絡面板,可以看到有 2 個 xhr 請求,如圖:


    其中,updateVarible 是一個 POST 請求,他會把你修改的的主題配置提交到后端 server,提交的數據你可以自己去查看它的 Request Payload,這個 POST 請求會返回一段 CSS 文本,然后會動態插入到 head 標簽的底部,來覆蓋默認樣式,你可以通過審查元素看到 head 底部會動態插入一個 id 為 chalk-style 的標簽。

    下圖就是該請求返回的樣式文本 :


    相關代碼在 examples/components/theme/loader/index.vue 中。

    ????onAction()?{
    ??????this.triggertProgressBar(true);
    ??????const?time?=?+new?Date();
    ??????updateVars(this.userConfig)
    ????????.then(res?=>?{
    ??????????this.applyStyle(res,?time);
    ????????})
    ????????.catch(err?=>?{
    ??????????this.onError(err);
    ????????})
    ????????.then(()?=>?{
    ??????????this.triggertProgressBar(false);
    ????????});
    ????},
    ????applyStyle(res,?time)?{
    ??????if?(time?this.lastApply)?return;
    ??????this.updateDocs(()?=>?{
    ????????updateDomHeadStyle('chalk-style',?res);
    ??????});
    ??????this.lastApply?=?time;
    ????}

    onAction 函數中的 updateVars 就是去發送 POST 請求,而 applyStyle 函數就是去修改和覆蓋默認樣式,updateDocs 函數會去更新默認主題顏色,updateDomHeadStyle 樣式會添加或者修改 id 為 chalk-style 的 style 標簽,目的就是覆蓋默認樣式,應用新主題樣式。

    updateVars 請求在頁面加載的時候會發起,在你修改完主題配置后也會發起。

    再來看一下 getVarible 請求,它是一個 GET 請求,返回的內容是主題配置頁面右側配置面板的數據源,如下圖所示:

    主題配置面板根據該數據源生成,并且當你去編輯其中一項的時候,又會發起 updateVars POST 請求,把更新的配置提交,然后后端會返回新的 CSS 并在前端生效。

    另外,用戶修改的配置還利用了 localStorage 在本地保存了一份,這樣用戶每次編輯都可以保存一份主題,下次也可以繼續基于某個主題繼續編輯。

    不過,這么實現多主題也并非完美,為了編譯加速,element-ui 把樣式部分單獨抽離出單獨的文件,這樣給開發組件的同學帶來很大的不便,當你去編寫組件的樣式的時候,需要在多個文件中來回切換,而且這樣也不符合組件就近管理的原則。但是如果把樣式寫在組件中,server 端去編譯生成單獨樣式文件的時間就會增長(需要從組件中提取 CSS),所以這是一個需要權衡的問題。

    國際化

    說到 Vue 的國際化方案,大家很容易會聯想到 vue-i18n 方案,element-ui 并未引入 vue-i18n,不過它是可以很好地與 vue-i18n 兼容的。

    所有的國際化方案都會用到語言包,語言包通常會返回一個 JSON 格式的數據,element-ui 組件庫的語言包在 src/locale/lang 目錄下,以英語語言包為例:

    export?default?{
    ??el:?{
    ????colorpicker:?{
    ??????confirm:?'OK',
    ??????clear:?'Clear'
    ????}
    ????//?...
    ??}
    }


    在 packages/color-picker/src/components/picker-dropdown.vue 中,我們在模板部分可以看到這個語言包的使用:

    <el-buttonsize="mini"type="text"class="el-color-dropdown__link-btn"
    ??@click="$emit('clear')">
    ??{{?t('el.colorpicker.clear')?}}
    el-button>
    <el-buttonplainsize="mini"class="el-color-dropdown__btn"
    ??@click="confirmValue">
    ??{{?t('el.colorpicker.confirm')?}}
    el-button>

    模板中用到的 t 函數,它定義在 src/mixins/locale.js 中:

    import?{?t?}?from?'element-ui/src/locale';

    export?default?{
    ??methods:?{
    ????t(...args)?{
    ??????return?t.apply(this,?args);
    ????}
    ??}
    };


    實際上是在 src/locale/index.js 中定義的 t 函數:

    export?const?t?=?function(path,?options)?{
    ??let?value?=?i18nHandler.apply(this,?arguments);
    ??if?(value?!==?null?&&?value?!==?undefined)?return?value;

    ??const?array?=?path.split('.');
    ??let?current?=?lang;

    ??for?(let?i?=?0,?j?=?array.length;?i?????const?property?=?array[i];
    ????value?=?current[property];
    ????if?(i?===?j?-?1)?return?format(value,?options);
    ????if?(!value)?return?'';
    ????current?=?value;
    ??}
    ??return?'';
    };


    這個函數是根據傳入的 path 路徑,比如我們例子中的 el.colorpicker.confirm,從語言包中找到對應的文案。其中 i18nHandler 是一個 i18n 的處理函數,這塊邏輯就是用來兼容外部的 i18n 方案如 vue-i18n。

    let?i18nHandler?=?function()?{
    ??const?vuei18n?=?Object.getPrototypeOf(this?||?Vue).$t;
    ??if?(typeof?vuei18n?===?'function'?&&?!!Vue.locale)?{
    ????if?(!merged)?{
    ??????merged?=?true;
    ??????Vue.locale(
    ????????Vue.config.lang,
    ????????deepmerge(lang,?Vue.locale(Vue.config.lang)?||?{},?{?clone:?true?})
    ??????);
    ????}
    ????return?vuei18n.apply(this,?arguments);
    ??}
    };

    export?const?i18n?=?function(fn)?{
    ??i18nHandler?=?fn?||?i18nHandler;
    };

    export?const?use?=?function(l)?{
    ??lang?=?l?||?lang;
    };


    可以看到 i18nHandler 默認會嘗試去找 Vue 原型中的 $t 函數,這是 vue-i18@5.x 的實現,會在 Vue 的原型上掛載 $t 方法。

    另外它也暴露了 i18n 方法,可以外部傳入其它的 i18n 方法,覆蓋 i18nHandler。

    如果沒有外部提供的 i18n 方法,那么就直接找到當前的語言包 let current = lang;,接下來的邏輯就是從這個語言包對象中讀到對應的字符串值,當然如果字符串需要格式化則調用 format 函數,這塊邏輯同學們感興趣可以自己看。

    因此在使用對應的語言包的時候一定要注冊:

    import?lang?from?'element-ui/lib/locale/lang/en'
    import?locale?from?'element-ui/lib/locale'

    //?設置語言
    locale.use(lang)


    這樣就注冊了英文語言包,在模板中就可以正常使用并找到對應的語言了。

    如果你要開發一個國際化項目,在運行時才能知道用戶的語言,可以考慮使用異步動態加載的方式,在渲染頁面前先獲取語言包,另外也可以考慮做緩存優化,不過這個話題延伸起來就有點多了,未來我可能會單開一個主題去分享業務如何做國際化。

    文檔 & demo

    作為一個優秀的開源組件庫,友好的文檔和 demo 是必不可少的,它也能幫你招攬到不少用戶。作為一個組件庫的開發者和維護者,也希望用最小的成本來維護文檔和 demo。

    element-ui 的文檔和 demo 是融為一體的,我們打開它的文檔,可以看到文檔不僅介紹了每個組件的使用方式,還展示了組件的各種示例,并且還可以清楚地看到每個示例的源碼,對用戶而言非常友好。那么 element-ui 內部是如何去編寫這些 demo 和文檔的呢?實際上,每個組件的文檔和 demo 都是通過一個單獨的 .md 文件生成的,那么它又是如何做到這點的呢?

    element-ui 的 demo 源碼都在 examples 目錄中維護,當我們在 element-ui 工程下運行 npm run dev 的時候,會啟動它的開發調試模式,并且運行官方文檔和 demo。

    看一下 npm scripts:

    "scripts":?{
    ????"bootstrap":?"yarn?||?npm?i",
    ????"build:file":?"node?build/bin/iconInit.js?&?node?build/bin/build-entry.js?&?node?build/bin/i18n.js?&?node?build/bin/version.js",
    ????"dev":?"npm?run?bootstrap?&&?npm?run?build:file?&&?cross-env?NODE_ENV=development?webpack-dev-server?--config?build/webpack.demo.js?&?node?build/bin/template.js",
    }


    我們省略了其它的 scripts,重點看 dev 和相關的幾個命令,其中 bootstrap 的作用是安裝依賴,build:file 的作用是運行 build 目錄下幾個命令,包括對 icon、entry、i18n、version 等初始化。在執行完 bootstrap 和 build:file 后,通過 webpack-dev-server 運行 build/webpack.demo.js,這個是重點,我們來看一下這個 webpack 的配置文件。

    const?webpackConfig?=?{
    ??mode:?process.env.NODE_ENV,
    ??entry:?isProd???{
    ????docs:?'./examples/entry.js',
    ????'element-ui':?'./src/index.js'
    ??}?:?(isPlay???'./examples/play.js'?:?'./examples/entry.js'),
    ??output:?{
    ????path:?path.resolve(process.cwd(),?'./examples/element-ui/'),
    ????publicPath:?process.env.CI_ENV?||?'',
    ????filename:?'[name].[hash:7].js',
    ????chunkFilename:?isProd???'[name].[hash:7].js'?:?'[name].js'
    ??},
    ??resolve:?{
    ????extensions:?['.js',?'.vue',?'.json'],
    ????alias:?config.alias,
    ????modules:?['node_modules']
    ??},
    ??devServer:?{
    ????host:?'0.0.0.0',
    ????port:?8085,
    ????publicPath:?'/',
    ????hot:?true
    ??},
    ??module:?{
    ????rules:?[
    ??????{
    ????????test:?/\.vue$/,
    ????????loader:?'vue-loader',
    ????????options:?{
    ??????????compilerOptions:?{
    ????????????preserveWhitespace:?false
    ??????????}
    ????????}
    ??????},
    ??????{
    ????????test:?/\.md$/,
    ????????use:?[
    ??????????{
    ????????????loader:?'vue-loader',
    ????????????options:?{
    ??????????????compilerOptions:?{
    ????????????????preserveWhitespace:?false
    ??????????????}
    ????????????}
    ??????????},
    ??????????{
    ????????????loader:?path.resolve(__dirname,?'./md-loader/index.js')
    ??????????}
    ????????]
    ??????}
    ????]
    ??}
    };


    由于整個配置文件內容比較長,我只保留了重點的部分,重點看一下 entry 和 module 下的 rules。

    element-ui 官網本質上就是一個用 vue 開發的應用,當我們運行 npm run dev 的時候,入口文件是 examples 目錄下的 entry.js:

    import?Vue?from?'vue';
    import?entry?from?'./app';
    import?VueRouter?from?'vue-router';
    import?Element?from?'main/index.js';
    import?hljs?from?'highlight.js';
    import?routes?from?'./route.config';
    import?demoBlock?from?'./components/demo-block';
    import?MainFooter?from?'./components/footer';
    import?MainHeader?from?'./components/header';
    import?SideNav?from?'./components/side-nav';
    import?FooterNav?from?'./components/footer-nav';
    import?title?from?'./i18n/title';

    import?'packages/theme-chalk/src/index.scss';
    import?'./demo-styles/index.scss';
    import?'./assets/styles/common.css';
    import?'./assets/styles/fonts/style.css';
    import?icon?from?'./icon.json';

    Vue.use(Element);
    Vue.use(VueRouter);
    Vue.component('demo-block',?demoBlock);
    Vue.component('main-footer',?MainFooter);
    Vue.component('main-header',?MainHeader);
    Vue.component('side-nav',?SideNav);
    Vue.component('footer-nav',?FooterNav);

    const?globalEle?=?new?Vue({
    ??data:?{?$isEle:?false?}?//?是否?ele?用戶
    });

    Vue.mixin({
    ??computed:?{
    ????$isEle:?{
    ??????get:?()?=>?(globalEle.$data.$isEle),
    ??????set:?(data)?=>?{globalEle.$data.$isEle?=?data;}
    ????}
    ??}
    });

    Vue.prototype.$icon?=?icon;?//?Icon?列表頁用

    const?router?=?new?VueRouter({
    ??mode:?'hash',
    ??base:?__dirname,
    ??routes
    });

    router.afterEach(route?=>?{
    ??//?https://github.com/highlightjs/highlight.js/issues/909#issuecomment-131686186
    ??Vue.nextTick(()?=>?{
    ????const?blocks?=?document.querySelectorAll('pre?code:not(.hljs)');
    ????Array.prototype.forEach.call(blocks,?hljs.highlightBlock);
    ??});
    ??const?data?=?title[route.meta.lang];
    ??for?(let?val?in?data)?{
    ????if?(new?RegExp('^'?+?val,?'g').test(route.name))?{
    ??????document.title?=?data[val];
    ??????return;
    ????}
    ??}
    ??document.title?=?'Element';
    ??ga('send',?'event',?'PageView',?route.name);
    });

    new?Vue({?//?eslint-disable-line
    ??...entry,
    ??router
    }).$mount('#app');


    入口文件做的事情很簡單,全引入的方式注冊了 element-ui 組件庫,注冊了一些官網用到的組件,注冊了路由以及路由的全局鉤子函數。

    這里我們要重點關注路由部分,路由的配置都在 examples/route.config.js 中:

    import?navConfig?from?'./nav.config';
    import?langs?from?'./i18n/route';

    const?LOAD_MAP?=?{
    ??'zh-CN':?name?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./pages/zh-CN/${name}.vue`)),
    ????'zh-CN');
    ??},
    ??'en-US':?name?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./pages/en-US/${name}.vue`)),
    ????'en-US');
    ??},
    ??'es':?name?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./pages/es/${name}.vue`)),
    ????'es');
    ??},
    ??'fr-FR':?name?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./pages/fr-FR/${name}.vue`)),
    ????'fr-FR');
    ??}
    };

    const?load?=?function(lang,?path)?{
    ??return?LOAD_MAP[lang](path);
    };

    const?LOAD_DOCS_MAP?=?{
    ??'zh-CN':?path?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./docs/zh-CN${path}.md`)),
    ????'zh-CN');
    ??},
    ??'en-US':?path?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./docs/en-US${path}.md`)),
    ????'en-US');
    ??},
    ??'es':?path?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./docs/es${path}.md`)),
    ????'es');
    ??},
    ??'fr-FR':?path?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./docs/fr-FR${path}.md`)),
    ????'fr-FR');
    ??}
    };

    const?loadDocs?=?function(lang,?path)?{
    ??return?LOAD_DOCS_MAP[lang](path);
    };

    const?registerRoute?=?(navConfig)?=>?{
    ??let?route?=?[];
    ??Object.keys(navConfig).forEach((lang,?index)?=>?{
    ????let?navs?=?navConfig[lang];
    ????route.push({
    ??????path:?`/${?lang?}/component`,
    ??????redirect:?`/${?lang?}/component/installation`,
    ??????component:?load(lang,?'component'),
    ??????children:?[]
    ????});
    ????navs.forEach(nav?=>?{
    ??????if?(nav.href)?return;
    ??????if?(nav.groups)?{
    ????????nav.groups.forEach(group?=>?{
    ??????????group.list.forEach(nav?=>?{
    ????????????addRoute(nav,?lang,?index);
    ??????????});
    ????????});
    ??????}?else?if?(nav.children)?{
    ????????nav.children.forEach(nav?=>?{
    ??????????addRoute(nav,?lang,?index);
    ????????});
    ??????}?else?{
    ????????addRoute(nav,?lang,?index);
    ??????}
    ????});
    ??});
    ??function?addRoute(page,?lang,?index)?{
    ????const?component?=?page.path?===?'/changelog'
    ????????load(lang,?'changelog')
    ??????:?loadDocs(lang,?page.path);
    ????let?child?=?{
    ??????path:?page.path.slice(1),
    ??????meta:?{
    ????????title:?page.title?||?page.name,
    ????????description:?page.description,
    ????????lang
    ??????},
    ??????name:?'component-'?+?lang?+?(page.title?||?page.name),
    ??????component:?component.default?||?component
    ????};

    ????route[index].children.push(child);
    ??}

    ??return?route;
    };

    let?route?=?registerRoute(navConfig);

    const?generateMiscRoutes?=?function(lang)?{
    ??let?guideRoute?=?{
    ????path:?`/${?lang?}/guide`,?//?指南
    ????redirect:?`/${?lang?}/guide/design`,
    ????component:?load(lang,?'guide'),
    ????children:?[{
    ??????path:?'design',?//?設計原則
    ??????name:?'guide-design'?+?lang,
    ??????meta:?{?lang?},
    ??????component:?load(lang,?'design')
    ????},?{
    ??????path:?'nav',?//?導航
    ??????name:?'guide-nav'?+?lang,
    ??????meta:?{?lang?},
    ??????component:?load(lang,?'nav')
    ????}]
    ??};

    ??let?themeRoute?=?{
    ????path:?`/${?lang?}/theme`,
    ????component:?load(lang,?'theme-nav'),
    ????children:?[
    ??????{
    ????????path:?'/',?//?主題管理
    ????????name:?'theme'?+?lang,
    ????????meta:?{?lang?},
    ????????component:?load(lang,?'theme')
    ??????},
    ??????{
    ????????path:?'preview',?//?主題預覽編輯
    ????????name:?'theme-preview-'?+?lang,
    ????????meta:?{?lang?},
    ????????component:?load(lang,?'theme-preview')
    ??????}]
    ??};

    ??let?resourceRoute?=?{
    ????path:?`/${?lang?}/resource`,?//?資源
    ????meta:?{?lang?},
    ????name:?'resource'?+?lang,
    ????component:?load(lang,?'resource')
    ??};

    ??let?indexRoute?=?{
    ????path:?`/${?lang?}`,?//?首頁
    ????meta:?{?lang?},
    ????name:?'home'?+?lang,
    ????component:?load(lang,?'index')
    ??};

    ??return?[guideRoute,?resourceRoute,?themeRoute,?indexRoute];
    };

    langs.forEach(lang?=>?{
    ??route?=?route.concat(generateMiscRoutes(lang.lang));
    });

    route.push({
    ??path:?'/play',
    ??name:?'play',
    ??component:?require('./play/index.vue')
    });

    let?userLanguage?=?localStorage.getItem('ELEMENT_LANGUAGE')?||?window.navigator.language?||?'en-US';
    let?defaultPath?=?'/en-US';
    if?(userLanguage.indexOf('zh-')?!==?-1)?{
    ??defaultPath?=?'/zh-CN';
    }?else?if?(userLanguage.indexOf('es')?!==?-1)?{
    ??defaultPath?=?'/es';
    }?else?if?(userLanguage.indexOf('fr')?!==?-1)?{
    ??defaultPath?=?'/fr-FR';
    }

    route?=?route.concat([{
    ??path:?'/',
    ??redirect:?defaultPath
    },?{
    ??path:?'*',
    ??redirect:?defaultPath
    }]);

    export?default?route;


    這個路由配置文件提供了指南、組件、主題、資源等多個路由頁面的配置,并且支持了多語言,我們重點關注一下組件路由是如何生成的,它主要通過 registerRoute(navConfig) 方法生成。

    其中 navConfig 讀取的是 examples/nav.config.json 文件,這個配置文件太長我就不貼了,它包括了多個語言的配置,維護了左側組件導航菜單路徑映射關系。

    registerRoute 函數內部就是遍歷 navConfig,根據它內部元素的數據結構生成路由配置,如果數據中有 children 則生成子路由。

    我們知道 Vue Router 的本質是根據不同的 URL path, 組件映射到對應的路由組件,對于每一個組件的路由,都是通過 addRoute(nav, lang, index) 方法生成的,該方法內部又調用了 loadDocs(lang, page.path) 獲取到對應的路由組件。

    const?loadDocs?=?function(lang,?path)?{
    ??return?LOAD_DOCS_MAP[lang](path);
    };

    const?LOAD_DOCS_MAP?=?{
    ??'zh-CN':?path?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./docs/zh-CN${path}.md`)),
    ????'zh-CN');
    ??},
    ??'en-US':?path?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./docs/en-US${path}.md`)),
    ????'en-US');
    ??},
    ??'es':?path?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./docs/es${path}.md`)),
    ????'es');
    ??},
    ??'fr-FR':?path?=>?{
    ????return?r?=>?require.ensure([],?()?=>
    ??????r(require(`./docs/fr-FR${path}.md`)),
    ????'fr-FR');
    ??}
    };


    以中文為例,我們獲取到某個 path 下的路由組件就是一個工廠函數,它對應加載的組件路徑是 exmaples/docs/zh-CN/${path}.md。這里要注意的是,和我們普通的異步組件加載方式不同,這里加載的居然是一個 .md 文件,而并非一個 .vue 文件,但卻能和 .vue 文件一樣能渲染成一個 Vue 組件,這是如何做到的呢?

    我們知道,webpack 的理念是一切資源都可以 require,只要配置了對應的 loader。回到 build/webpack.demo.js,我們發現對于 .md 文件我們配置了相應的 loader:

    ??{
    ????test:?/\.md$/,
    ????use:?[
    ??????{
    ????????loader:?'vue-loader',
    ????????options:?{
    ??????????compilerOptions:?{
    ????????????preserveWhitespace:?false
    ??????????}
    ????????}
    ??????},
    ??????{
    ????????loader:?path.resolve(__dirname,?'./md-loader/index.js')
    ??????}
    ????]
    ??}

    對于 .md 文件,這里 use 數組中配置了 2 項,它們執行順序是逆序的,也就是先執行 md-loader,再執行 vue-loader,md-loader 的代碼在 build/md-loader/index.js 中:

    const?{
    ??stripScript,
    ??stripTemplate,
    ??genInlineComponentText
    }?=?require('./util');
    const?md?=?require('./config');

    module.exports?=?function(source)?{
    ??const?content?=?md.render(source);

    ??const?startTag?=?'';
    ??const?endTagLen?=?endTag.length;

    ??let?componenetsString?=?'';
    ??let?id?=?0;?//?demo?的?id
    ??let?output?=?[];?//?輸出的內容
    ??let?start?=?0;?//?字符串開始位置

    ??let?commentStart?=?content.indexOf(startTag);
    ??let?commentEnd?=?content.indexOf(endTag,?commentStart?+?startTagLen);
    ??while?(commentStart?!==?-1?&&?commentEnd?!==?-1)?{
    ????output.push(content.slice(start,?commentStart));

    ????const?commentContent?=?content.slice(commentStart?+?startTagLen,?commentEnd);
    ????const?html?=?stripTemplate(commentContent);
    ????const?script?=?stripScript(commentContent);
    ????let?demoComponentContent?=?genInlineComponentText(html,?script);
    ????const?demoComponentName?=?`element-demo${id}`;
    ????output.push(`<${demoComponentName}?/>`);
    ????componenetsString?+=?`${JSON.stringify(demoComponentName)}:?${demoComponentContent},`;

    ????//?重新計算下一次的位置
    ????id++;
    ????start?=?commentEnd?+?endTagLen;
    ????commentStart?=?content.indexOf(startTag,?start);
    ????commentEnd?=?content.indexOf(endTag,?commentStart?+?startTagLen);
    ??}

    ??//?僅允許在?demo?不存在時,才可以在?Markdown?中寫?script?標簽
    ??//?todo:?優化這段邏輯
    ??let?pageScript?=?'';
    ??if?(componenetsString)?{
    ????pageScript?=?`;
    ??}?else?if?(content.indexOf(')?+?''.length;
    ????pageScript?=?content.slice(0,?start);
    ??}

    ??output.push(content.slice(start));
    ??return?`${output.join('')}${pageScript}
    ??`;
    };

    webpack loader 的原理很簡單,輸入是文件的原始內容,返回的是經過 loader 處理后的內容。對于 md-loader,輸入的是 .md 文檔,輸出的則是一個 Vue SFC 格式的字符串,這樣它的輸出就可以作為下一個 vue-loader 的輸入做處理了。

    我們來簡單看一下 md-loader 中間處理過程。首先執行了 md.render(source) 對 md 文檔解析,提取文檔中 :::demo {content} ::: 內容,分別生成一些 Vue 的模板字符串,然后再從這個模板字符串中循環查找 包裹的內容,從中提取模板字符串到 output 中,提取 script 到 componenetsString 中,然后構造 pageScript,最后返回的內容就是:

    ??return?`${output.join('')}${pageScript}
    ??`;

    最終生成的字符串滿足我們通常編寫的 .vue SFC 格式,它會作為下一個 vue-loader 的輸入,所以這樣我們就相當于通過加載一個 .md 格式的文件的方式加載了 Vue 組件。

    這里面還有很多和 .md 文件解析的細節,如果你對最終生成的 output 和 pageScript 代碼是什么感興趣,建議你自己調試一番。

    element-ui 這種文檔和 demo 的實現方式是非常巧妙的,大大減少了 demo 和文檔的維護成本,并且對于用戶來說也非常友好,如果你也為自己的庫構建文檔,不妨參考它的實現。

    安裝 & 引入

    通常 JS 庫都會支持 npm 和 CDN 2 種安裝方式,element-ui 也不例外。

    先說一下 CDN 的安裝方式,實際上 element-ui 會把所有組件打包生成一份 CSS 和 JS,官方也提供了例子:


    <link?rel="stylesheet"?href="https://unpkg.com/element-ui/lib/theme-chalk/index.css"><script?src="https://unpkg.com/element-ui/lib/index.js">script>


    CDN 安裝方式有它的好處,不需要構建工具,開箱即用,但缺點也很明顯,全量引入了所有組件,體積非常大。

    由于大部分人在開發 Vue 項目都是基于 vue-cli 腳手架初始化項目的,所以更推薦使用 npm 方式安裝。

    npm?i?element-ui?-S

    說到 npm 安裝,不得不提 element-ui 提供的 2 種組件引入方式,完整引入和部分引入。

    支持完整引入非常容易,把所有組件打包成一份 CSS 和 JS,并且在 package.json 中配置:

    ?"main":?"lib/element-ui.common.js"


    這樣當用戶執行 import ElementUI from 'element-ui' 的時候就可以完整引入了組件的 JS 代碼了。正如我們之前說的,element-ui 會單獨發布 CSS,所以你還需要 import 'element-ui/lib/theme-chalk/index.css'。

    完整引入的好處是方便,只需要 2 行代碼就可以完整地使用 element-ui 所有的組件,但缺點也很明顯,引入的組件包體積很大,通常一個項目也用不到所有的組件,會有資源浪費。

    因此最佳實踐就是按需引入:

    import?Vue?from?'vue'
    import?{?Button?}?from?'element-ui'

    Vue.component(Button.name,?Button)


    大部分人這么用的時候會覺得理所當然,不知道大家有沒有想過:為什么這種引入方式可以實現按需引入呢?要搞清楚這個問題,就要搞清楚 import { Button } from 'element-ui' 這個背后都做了什么。

    其實官網已經有答案了,在使用按需引入的時候,要借助 babel-plugin-component 這個 webpack 插件,并且配置 .babelrc:

    {
    ??"presets":?[["es2015",?{?"modules":?false?}]],
    ??"plugins":?[
    ????[
    ??????"component",
    ??????{
    ????????"libraryName":?"element-ui",
    ????????"styleLibraryName":?"theme-chalk"
    ??????}
    ????]
    ??]
    }


    實際上它是把 import { Button } from 'element-ui' 轉換成:

    var?button?=?require('element-ui/lib/button')
    require('element-ui/lib/theme-chalk/button.css')

    這樣我們就精準地引入了對應 lib 下的 Button 組件的 JS 和 CSS 代碼了,也就實現了按需引入 Button 組件。

    element-ui 這種按需引入的方式雖然方便,但背后卻要解決幾個問題,由于我們支持每個組件可以單獨引入,那么如果產生了組件依賴并且同時按需引入的時候,代碼冗余問題怎么解決。舉個例子,在 element-ui 中,Table 組件依賴了 CheckBox 組件,那么當我同時引入了 Table 組件和 CheckBox 組件的時候,會不會產生代碼冗余呢?

    import?{?Table,?CheckBox?}?from?'element-ui'

    如果你不做任何處理的話,答案是會,你最終引入的包會有 2 份 CheckBox 的代碼。那么 element-ui 是怎么解決這個問題的呢?實際上只是部分解決了,它的 webpack 配置文件中配置了 externals,在 build/config.js 中我們可以看到這些具體的配置:

    var?externals?=?{};

    Object.keys(Components).forEach(function(key)?{
    ??externals[`element-ui/packages/${key}`]?=?`element-ui/lib/${key}`;
    });

    externals['element-ui/src/locale']?=?'element-ui/lib/locale';
    utilsList.forEach(function(file)?{
    ??file?=?path.basename(file,?'.js');
    ??externals[`element-ui/src/utils/${file}`]?=?`element-ui/lib/utils/${file}`;
    });
    mixinsList.forEach(function(file)?{
    ??file?=?path.basename(file,?'.js');
    ??externals[`element-ui/src/mixins/${file}`]?=?`element-ui/lib/mixins/${file}`;
    });
    transitionList.forEach(function(file)?{
    ??file?=?path.basename(file,?'.js');
    ??externals[`element-ui/src/transitions/${file}`]?=?`element-ui/lib/transitions/${file}`;
    });

    externals?=?[Object.assign({
    ??vue:?'vue'
    },?externals),?nodeExternals()];

    externals 可以防止將這些 import 的包打包到 bundle 中,并在運行時再去從外部獲取這些擴展依賴。

    我們來看一下打包后的 lib/table.js,我們可以看到編譯后的 table.js 對 CheckBox 組件的依賴引入:

    module.exports?=?require("element-ui/lib/checkbox");


    這么處理的話,就不會打包生成 2 份 CheckBox JS 部分的代碼了,但是對于 CSS 部分,element-ui 并未處理冗余情況,可以看到 lib/theme-chalk/checkbox.css 和 lib/theme-chalk/table.css 中都會有 CheckBox 組件的 CSS 樣式。

    其實,要解決按需引入的 JS 和 CSS 的冗余問題并非難事,可以用后編譯的思想,即依賴包提供源碼,而編譯交給應用處理,這樣不僅不會有組件冗余代碼,甚至連編譯的冗余代碼都不會有,實際上我們基于 element-ui fork 的組件庫 zoom-ui 就應用了后編譯技術,之前在滴滴搞的開源組件庫cube-ui 組件庫也是這么玩的。更多后編譯相關介紹可以參考滴滴團隊在掘金發布的 《webpack 應用編譯優化之路》。

    工程化

    前端對于工程化的要求越來越高,element-ui 作為一個組件庫,它在工程化方面做了哪些事情呢?

    首先是開發階段,為了保證大家代碼風格的一致性,使用了 ESLint,甚至專門寫了 eslint-config-elemefe 作為 ESint 的擴展規則配置;為了方便本地開發調試,借助了 webpack 并配置了 Hot Reload;利用模塊化開發的思想把組件依賴的一些公共模塊放在了 src 目錄,并依據功能拆分出 directives、locale、mixins、transitions、utils 等模塊。

    其次是測試方面,使用了 karma 測試框架,為每一個組件編寫了單元測試,并且利用 Travis CI 集成了測試。

    接著是構建方面,element-ui 編寫了很多 npm scripts,以 dist 這個 script 為例:

    ?"dist":?"npm?run?clean?&&?npm?run?build:file?&&?npm?run?lint?&&?webpack?--config?build/webpack.conf.js?&&?webpack?--config?build/webpack.common.js?&&?webpack?--config?build/webpack.component.js?&&?npm?run?build:utils?&&?npm?run?build:umd?&&?npm?run?build:theme"

    它內部會依次執行多個命令,最終會生成 lib 目錄和打包后的文件。我并不打算介紹所有的命令,感興趣同學可自行研究,這里我想介紹一下 build:file 這個 script 做的事情:

    "build:file":?"node?build/bin/iconInit.js?&?node?build/bin/build-entry.js?&?node?build/bin/i18n.js?&?node?build/bin/version.js",

    這里會依次執行 build/bin 目錄下的一些 Node 腳本,對 icon、entry、i18n、version 等做了一系列的初始化工作,它們的內容都是根據一些規則做文件的 IO,這么做的好處就是完全通過工具的手段自動化生成文件,比人工靠譜且效率更高,這波操作非常值得我們學習和應用。

    最后是部署,通過 pub 這個 npm script 完成:

    ?"pub":?"npm?run?bootstrap?&&?sh?build/git-release.sh?&&?sh?build/release.sh?&&?node?build/bin/gen-indices.js?&&?sh?build/deploy-faas.sh"


    主要是通過運行一系列的 bash 腳本,實現了代碼的提交、合并、版本管理、npm 發布、官網發布等,讓整個發布流程自動化完成,腳本具體內容感興趣的同學可自行查看。

    總結

    至此,element-ui 的組件庫的整體設計介紹完畢,可以看到除了這些豐富的組件背后,還有很完整的一套解決方案,很多經驗都值得我們學習和借鑒,不完美的地方也值得我們去思考,其中有很多技術細節可以深入挖掘。

    把不會的東西學會了,那么你就進步了,如果你覺得這類文章有幫助,也歡迎把它推薦給你身邊的小伙伴。

    下一篇預告 :Element-UI ?技術揭秘(3)— Layout 布局組件的設計與實現。

    在這里留下你的爪印喔~

    總結

    以上是生活随笔為你收集整理的element ui 多个子组件_ElementUI 技术揭秘(2) 组件库的整体设计的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    日本熟妇乱子伦xxxx | 一区二区三区乱码在线 | 欧洲 | 性做久久久久久久久 | a在线观看免费网站大全 | 国产精品二区一区二区aⅴ污介绍 | 亚洲va中文字幕无码久久不卡 | 中文字幕乱码中文乱码51精品 | 综合人妻久久一区二区精品 | 亚洲成色在线综合网站 | 欧美亚洲日韩国产人成在线播放 | 久久久精品国产sm最大网站 | 国产精品第一国产精品 | 婷婷五月综合激情中文字幕 | 美女张开腿让人桶 | 国产又爽又黄又刺激的视频 | 东京热一精品无码av | 无码av中文字幕免费放 | 四虎永久在线精品免费网址 | 无遮挡国产高潮视频免费观看 | 天天摸天天透天天添 | 中文字幕无码免费久久99 | 久久久久se色偷偷亚洲精品av | 亚洲一区av无码专区在线观看 | 国产做国产爱免费视频 | 日韩人妻无码中文字幕视频 | 精品国产一区二区三区av 性色 | 色 综合 欧美 亚洲 国产 | 国产乱人伦偷精品视频 | 精品aⅴ一区二区三区 | 久久天天躁狠狠躁夜夜免费观看 | 亚洲精品鲁一鲁一区二区三区 | www国产亚洲精品久久久日本 | 国产乱人伦av在线无码 | 最新国产麻豆aⅴ精品无码 | 色窝窝无码一区二区三区色欲 | 精品国产一区二区三区av 性色 | 日韩人妻无码中文字幕视频 | 欧美日韩一区二区综合 | 性做久久久久久久免费看 | 娇妻被黑人粗大高潮白浆 | 国产成人一区二区三区别 | 亚洲精品成a人在线观看 | 偷窥村妇洗澡毛毛多 | 日韩欧美群交p片內射中文 | 欧美日韩视频无码一区二区三 | 欧美熟妇另类久久久久久不卡 | 亚洲欧美国产精品久久 | 鲁大师影院在线观看 | 国产一区二区三区精品视频 | 亚洲国产欧美国产综合一区 | 蜜臀av无码人妻精品 | 亚洲精品www久久久 | 日韩少妇白浆无码系列 | 无码任你躁久久久久久久 | 99久久亚洲精品无码毛片 | 无码人妻丰满熟妇区毛片18 | 国产精品无码永久免费888 | 奇米影视888欧美在线观看 | 午夜福利试看120秒体验区 | 97色伦图片97综合影院 | 国产亚洲精品久久久久久大师 | 欧美成人高清在线播放 | 97人妻精品一区二区三区 | 欧洲熟妇色 欧美 | 黑森林福利视频导航 | 成年美女黄网站色大免费视频 | 99在线 | 亚洲 | 麻豆精品国产精华精华液好用吗 | 熟妇人妻无乱码中文字幕 | 日产精品高潮呻吟av久久 | 日韩少妇白浆无码系列 | 精品乱码久久久久久久 | 欧美熟妇另类久久久久久多毛 | 久久精品丝袜高跟鞋 | 日韩精品乱码av一区二区 | 午夜福利一区二区三区在线观看 | 亚洲中文字幕在线观看 | 中文字幕日韩精品一区二区三区 | 无码av中文字幕免费放 | 成人影院yy111111在线观看 | www一区二区www免费 | 男女下面进入的视频免费午夜 | 狠狠色欧美亚洲狠狠色www | 爆乳一区二区三区无码 | 天天摸天天透天天添 | 红桃av一区二区三区在线无码av | 一本一道久久综合久久 | 国产九九九九九九九a片 | av无码电影一区二区三区 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 免费看男女做好爽好硬视频 | 一区二区三区乱码在线 | 欧洲 | 精品人妻中文字幕有码在线 | 丰满少妇弄高潮了www | 少妇厨房愉情理9仑片视频 | 狂野欧美性猛交免费视频 | 无码人妻丰满熟妇区五十路百度 | 亚洲人成网站在线播放942 | 熟妇人妻中文av无码 | 亚洲s码欧洲m码国产av | 三级4级全黄60分钟 | 蜜臀aⅴ国产精品久久久国产老师 | 国产婷婷色一区二区三区在线 | 亚洲一区二区三区无码久久 | 亚洲精品国产品国语在线观看 | 国产偷自视频区视频 | 亚洲自偷精品视频自拍 | 黑人粗大猛烈进出高潮视频 | 乱中年女人伦av三区 | 久久精品国产一区二区三区 | www国产亚洲精品久久久日本 | 亚洲精品久久久久久久久久久 | 18精品久久久无码午夜福利 | 亚洲自偷自拍另类第1页 | 国产va免费精品观看 | 亚洲国产精品无码久久久久高潮 | 国产精品久久久久久亚洲毛片 | 亚洲男女内射在线播放 | 精品无码国产一区二区三区av | 成人精品天堂一区二区三区 | 对白脏话肉麻粗话av | 欧美人与物videos另类 | 久久久久99精品国产片 | 日本乱人伦片中文三区 | 台湾无码一区二区 | 亚洲日韩精品欧美一区二区 | 欧美丰满熟妇xxxx | 青青草原综合久久大伊人精品 | 久久精品国产精品国产精品污 | 亚洲а∨天堂久久精品2021 | 激情内射亚州一区二区三区爱妻 | 日本精品久久久久中文字幕 | 亚洲精品午夜无码电影网 | 国产办公室秘书无码精品99 | 国产精品久久久久9999小说 | 无码人妻丰满熟妇区毛片18 | 亚洲一区av无码专区在线观看 | 免费无码一区二区三区蜜桃大 | 国产片av国语在线观看 | 精品无人国产偷自产在线 | 中文字幕av伊人av无码av | 午夜时刻免费入口 | 最新国产麻豆aⅴ精品无码 | 性生交片免费无码看人 | www成人国产高清内射 | 在教室伦流澡到高潮hnp视频 | 午夜性刺激在线视频免费 | 亚洲欧洲日本无在线码 | 亚洲综合无码久久精品综合 | 人妻互换免费中文字幕 | 成人免费视频在线观看 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲精品一区二区三区大桥未久 | 玩弄人妻少妇500系列视频 | 少妇愉情理伦片bd | 国产精品亚洲一区二区三区喷水 | 国产福利视频一区二区 | 高中生自慰www网站 | 丰满肥臀大屁股熟妇激情视频 | 男女下面进入的视频免费午夜 | 一本色道久久综合狠狠躁 | 扒开双腿吃奶呻吟做受视频 | 国产精品怡红院永久免费 | 国产人妻久久精品二区三区老狼 | √天堂资源地址中文在线 | 领导边摸边吃奶边做爽在线观看 | 亚洲第一无码av无码专区 | 一本加勒比波多野结衣 | 久久精品国产99精品亚洲 | 精品国产福利一区二区 | 久久精品中文字幕一区 | 欧美黑人乱大交 | 欧美丰满少妇xxxx性 | 欧美性生交活xxxxxdddd | 熟女体下毛毛黑森林 | 久久久久99精品国产片 | 99精品视频在线观看免费 | 无码人妻出轨黑人中文字幕 | 大屁股大乳丰满人妻 | 久久综合狠狠综合久久综合88 | 香蕉久久久久久av成人 | 对白脏话肉麻粗话av | 精品人妻av区 | 精品一区二区三区波多野结衣 | 少妇无套内谢久久久久 | 国内丰满熟女出轨videos | 久久久久久国产精品无码下载 | 国产精品久久久久久亚洲影视内衣 | 亚洲中文字幕在线观看 | 亚洲色www成人永久网址 | 精品夜夜澡人妻无码av蜜桃 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 一个人看的视频www在线 | 亚洲欧美日韩国产精品一区二区 | 久久 国产 尿 小便 嘘嘘 | 国产美女精品一区二区三区 | 99国产精品白浆在线观看免费 | 中文字幕无码av波多野吉衣 | 夜精品a片一区二区三区无码白浆 | 性做久久久久久久久 | 清纯唯美经典一区二区 | 中文亚洲成a人片在线观看 | 亚洲人成影院在线无码按摩店 | 日产精品高潮呻吟av久久 | 国产一区二区三区日韩精品 | 久久综合香蕉国产蜜臀av | 成在人线av无码免观看麻豆 | 国产成人精品视频ⅴa片软件竹菊 | 国产精品99爱免费视频 | 亚洲无人区一区二区三区 | 国内老熟妇对白xxxxhd | 老司机亚洲精品影院无码 | www国产亚洲精品久久网站 | 永久免费精品精品永久-夜色 | 精品亚洲成av人在线观看 | 任你躁在线精品免费 | 国产激情一区二区三区 | 国内精品久久毛片一区二区 | 久久国产36精品色熟妇 | 亚洲色偷偷男人的天堂 | 日韩人妻无码一区二区三区久久99 | 欧美freesex黑人又粗又大 | 一本色道久久综合亚洲精品不卡 | 日韩精品成人一区二区三区 | 国产精品久久福利网站 | 精品乱子伦一区二区三区 | 亚洲男人av香蕉爽爽爽爽 | 99精品无人区乱码1区2区3区 | 国产美女极度色诱视频www | 黑人大群体交免费视频 | 国产在线无码精品电影网 | 国产精品a成v人在线播放 | 亚洲熟妇自偷自拍另类 | 精品无码国产自产拍在线观看蜜 | 亚洲中文字幕av在天堂 | 国产成人无码专区 | 51国偷自产一区二区三区 | 色婷婷综合中文久久一本 | 精品无码av一区二区三区 | 5858s亚洲色大成网站www | 国产绳艺sm调教室论坛 | 欧洲vodafone精品性 | 精品久久久中文字幕人妻 | 色婷婷综合中文久久一本 | 思思久久99热只有频精品66 | 国产精品无码一区二区三区不卡 | 精品国产福利一区二区 | 亚洲阿v天堂在线 | 亚洲伊人久久精品影院 | 亚洲一区二区观看播放 | 97资源共享在线视频 | 午夜精品久久久久久久久 | 天堂无码人妻精品一区二区三区 | 亚洲区小说区激情区图片区 | 欧美xxxxx精品 | 久久99国产综合精品 | 日本xxxx色视频在线观看免费 | 又粗又大又硬又长又爽 | 亚洲国产欧美国产综合一区 | 一本久久a久久精品vr综合 | 在线播放亚洲第一字幕 | 亚洲精品一区二区三区在线观看 | 国产特级毛片aaaaaaa高清 | 天天拍夜夜添久久精品大 | av无码久久久久不卡免费网站 | 在线观看国产午夜福利片 | 无码人妻出轨黑人中文字幕 | 久久久精品欧美一区二区免费 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 天堂亚洲2017在线观看 | 欧美日韩精品 | 激情内射日本一区二区三区 | 国产精品久久久一区二区三区 | 精品久久久中文字幕人妻 | 国产xxx69麻豆国语对白 | 国产精品第一国产精品 | 欧美性猛交内射兽交老熟妇 | 国产绳艺sm调教室论坛 | 曰本女人与公拘交酡免费视频 | 国产精品igao视频网 | 亚洲国产精品久久久天堂 | 欧洲精品码一区二区三区免费看 | 久久精品人妻少妇一区二区三区 | a片在线免费观看 | 高潮喷水的毛片 | 中文字幕乱码中文乱码51精品 | 国产在线无码精品电影网 | 人人妻人人藻人人爽欧美一区 | 久久午夜无码鲁丝片秋霞 | 一区二区三区高清视频一 | 爽爽影院免费观看 | 日韩精品无码一本二本三本色 | 丝袜 中出 制服 人妻 美腿 | 99久久精品国产一区二区蜜芽 | 九九综合va免费看 | 精品亚洲成av人在线观看 | 麻豆果冻传媒2021精品传媒一区下载 | 国产女主播喷水视频在线观看 | 亚洲成在人网站无码天堂 | 日韩人妻无码中文字幕视频 | 97精品国产97久久久久久免费 | 人人爽人人澡人人人妻 | 99精品国产综合久久久久五月天 | 国产口爆吞精在线视频 | 久久综合久久自在自线精品自 | 国产午夜精品一区二区三区嫩草 | 亚洲成在人网站无码天堂 | 国产免费久久久久久无码 | 97人妻精品一区二区三区 | aⅴ亚洲 日韩 色 图网站 播放 | 国产真实伦对白全集 | 亚洲色大成网站www国产 | 日日噜噜噜噜夜夜爽亚洲精品 | 日韩人妻无码一区二区三区久久99 | 日本熟妇浓毛 | 丰满少妇人妻久久久久久 | 亚洲精品久久久久久一区二区 | 18精品久久久无码午夜福利 | 水蜜桃色314在线观看 | 一本久道久久综合婷婷五月 | 欧美性生交活xxxxxdddd | 欧美国产日韩久久mv | 久久这里只有精品视频9 | 色窝窝无码一区二区三区色欲 | 亚洲一区二区三区国产精华液 | 日韩亚洲欧美中文高清在线 | 亚洲国产精品成人久久蜜臀 | 一本久道高清无码视频 | 成熟女人特级毛片www免费 | 国産精品久久久久久久 | 国产精品办公室沙发 | 国产午夜亚洲精品不卡下载 | 中文字幕人成乱码熟女app | 夜精品a片一区二区三区无码白浆 | 国内少妇偷人精品视频 | 图片区 小说区 区 亚洲五月 | 狠狠噜狠狠狠狠丁香五月 | 狠狠综合久久久久综合网 | 白嫩日本少妇做爰 | 欧美熟妇另类久久久久久不卡 | 久久久中文字幕日本无吗 | 欧美freesex黑人又粗又大 | 精品水蜜桃久久久久久久 | 一本久道久久综合狠狠爱 | 免费乱码人妻系列无码专区 | 成人免费视频在线观看 | 亚洲国产综合无码一区 | 小鲜肉自慰网站xnxx | 99久久精品午夜一区二区 | 波多野结衣av在线观看 | 一个人免费观看的www视频 | 人妻天天爽夜夜爽一区二区 | 国语精品一区二区三区 | 欧美野外疯狂做受xxxx高潮 | 久久亚洲精品成人无码 | 精品厕所偷拍各类美女tp嘘嘘 | 亚洲精品国偷拍自产在线麻豆 | 欧美熟妇另类久久久久久不卡 | 久久国产自偷自偷免费一区调 | 奇米影视888欧美在线观看 | 久久久无码中文字幕久... | 亚洲国产精品无码久久久久高潮 | 日韩精品a片一区二区三区妖精 | 综合网日日天干夜夜久久 | 亚洲小说春色综合另类 | 日日摸天天摸爽爽狠狠97 | 欧美性猛交xxxx富婆 | 国产超碰人人爽人人做人人添 | 鲁鲁鲁爽爽爽在线视频观看 | 亚洲精品一区二区三区四区五区 | 国产另类ts人妖一区二区 | 日本爽爽爽爽爽爽在线观看免 | 亚洲区小说区激情区图片区 | 中文精品久久久久人妻不卡 | 国产成人无码一二三区视频 | 人人妻人人澡人人爽欧美一区 | 99国产精品白浆在线观看免费 | 日日天干夜夜狠狠爱 | 夜夜高潮次次欢爽av女 | 免费无码肉片在线观看 | 爽爽影院免费观看 | 精品久久综合1区2区3区激情 | 久久国产劲爆∧v内射 | 亚洲日韩乱码中文无码蜜桃臀网站 | 激情综合激情五月俺也去 | 午夜嘿嘿嘿影院 | 高潮毛片无遮挡高清免费 | 欧美三级a做爰在线观看 | 国产香蕉97碰碰久久人人 | 欧美一区二区三区 | 日韩精品无码一本二本三本色 | 亚洲欧美日韩国产精品一区二区 | 亚洲色在线无码国产精品不卡 | 综合激情五月综合激情五月激情1 | 天天拍夜夜添久久精品 | 国产精品久久久久久无码 | 好男人www社区 | 99久久人妻精品免费二区 | 少妇性荡欲午夜性开放视频剧场 | 国产福利视频一区二区 | 一本大道久久东京热无码av | 精品一区二区不卡无码av | 日韩精品一区二区av在线 | 精品 日韩 国产 欧美 视频 | 成人精品一区二区三区中文字幕 | 精品午夜福利在线观看 | 初尝人妻少妇中文字幕 | 青青青爽视频在线观看 | 国产精华av午夜在线观看 | 久久精品人人做人人综合试看 | 成人免费视频视频在线观看 免费 | 欧美亚洲日韩国产人成在线播放 | 国产片av国语在线观看 | 午夜精品久久久内射近拍高清 | 欧美人与牲动交xxxx | 熟女体下毛毛黑森林 | 小泽玛莉亚一区二区视频在线 | 中文字幕乱码人妻二区三区 | 亚洲午夜久久久影院 | 夜夜影院未满十八勿进 | 久久99国产综合精品 | 老熟女乱子伦 | 无码国产乱人伦偷精品视频 | 蜜桃av抽搐高潮一区二区 | 中文字幕乱码人妻二区三区 | 国产午夜福利100集发布 | 国产极品视觉盛宴 | 欧美性猛交xxxx富婆 | 色婷婷综合激情综在线播放 | 少妇性荡欲午夜性开放视频剧场 | 国产精品理论片在线观看 | 午夜精品久久久久久久 | 成人三级无码视频在线观看 | 国产欧美熟妇另类久久久 | 日韩人妻无码一区二区三区久久99 | 国产成人无码av片在线观看不卡 | 精品亚洲成av人在线观看 | 少妇的肉体aa片免费 | 好男人社区资源 | 色五月丁香五月综合五月 | 熟女体下毛毛黑森林 | 精品久久久中文字幕人妻 | 国产片av国语在线观看 | 亚洲精品中文字幕乱码 | 国产又粗又硬又大爽黄老大爷视 | 国产精品人人妻人人爽 | 美女毛片一区二区三区四区 | 国产真实乱对白精彩久久 | 国产精品爱久久久久久久 | 欧美 亚洲 国产 另类 | 婷婷综合久久中文字幕蜜桃三电影 | 中文字幕无码日韩专区 | 成人性做爰aaa片免费看 | 亚洲熟悉妇女xxx妇女av | 丰满岳乱妇在线观看中字无码 | 无码人妻黑人中文字幕 | 国产在线精品一区二区高清不卡 | 亚洲日韩av一区二区三区中文 | 亚洲中文字幕乱码av波多ji | 十八禁视频网站在线观看 | 男人扒开女人内裤强吻桶进去 | 99久久精品无码一区二区毛片 | 97夜夜澡人人爽人人喊中国片 | 欧美怡红院免费全部视频 | 国产女主播喷水视频在线观看 | 特大黑人娇小亚洲女 | 人妻少妇被猛烈进入中文字幕 | 在线观看国产一区二区三区 | 无码成人精品区在线观看 | 香蕉久久久久久av成人 | 国产午夜精品一区二区三区嫩草 | 国产偷国产偷精品高清尤物 | 人妻与老人中文字幕 | 国产熟女一区二区三区四区五区 | 欧美日韩综合一区二区三区 | 亚洲精品欧美二区三区中文字幕 | 狠狠色欧美亚洲狠狠色www | 三上悠亚人妻中文字幕在线 | 免费国产黄网站在线观看 | 亚洲成熟女人毛毛耸耸多 | 午夜无码人妻av大片色欲 | 国产在线无码精品电影网 | 久久亚洲中文字幕无码 | 粉嫩少妇内射浓精videos | 亚洲人亚洲人成电影网站色 | 精品亚洲成av人在线观看 | 无码人妻精品一区二区三区下载 | 狂野欧美激情性xxxx | 国产熟妇高潮叫床视频播放 | 国产三级久久久精品麻豆三级 | 国产深夜福利视频在线 | 人妻aⅴ无码一区二区三区 | 久久人人爽人人爽人人片av高清 | 色综合久久网 | 日韩视频 中文字幕 视频一区 | 熟妇人妻中文av无码 | 成人无码精品一区二区三区 | 久久这里只有精品视频9 | 99久久精品日本一区二区免费 | 一区二区三区高清视频一 | 一本精品99久久精品77 | 亚洲aⅴ无码成人网站国产app | 国产麻豆精品精东影业av网站 | 亚洲aⅴ无码成人网站国产app | 亚洲色www成人永久网址 | 亚洲自偷自拍另类第1页 | 亚洲s色大片在线观看 | 久久99精品国产.久久久久 | 99久久精品国产一区二区蜜芽 | 日本精品少妇一区二区三区 | 亚洲中文无码av永久不收费 | 无遮挡啪啪摇乳动态图 | 青青草原综合久久大伊人精品 | 四虎4hu永久免费 | 在线播放无码字幕亚洲 | 亚洲色大成网站www国产 | 在线视频网站www色 | 亚洲欧洲日本无在线码 | 国产suv精品一区二区五 | 亚洲欧洲无卡二区视頻 | av小次郎收藏 | 亚洲熟悉妇女xxx妇女av | √天堂资源地址中文在线 | 国产精品第一国产精品 | 成人aaa片一区国产精品 | 天堂亚洲免费视频 | 国产精品无码一区二区桃花视频 | 乱人伦人妻中文字幕无码 | 日韩人妻系列无码专区 | 色一情一乱一伦一区二区三欧美 | 内射欧美老妇wbb | 中文无码精品a∨在线观看不卡 | 99久久久国产精品无码免费 | 欧美日韩一区二区三区自拍 | 国产高清av在线播放 | 性啪啪chinese东北女人 | 亚洲精品一区二区三区四区五区 | 日韩少妇白浆无码系列 | 丝袜 中出 制服 人妻 美腿 | 日韩精品乱码av一区二区 | 九月婷婷人人澡人人添人人爽 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 老子影院午夜精品无码 | 久久精品一区二区三区四区 | 激情人妻另类人妻伦 | 国产成人无码av一区二区 | 久久久亚洲欧洲日产国码αv | 久久精品99久久香蕉国产色戒 | 国产成人综合色在线观看网站 | 午夜免费福利小电影 | 高潮喷水的毛片 | 东京热男人av天堂 | 夜精品a片一区二区三区无码白浆 | 内射老妇bbwx0c0ck | 内射欧美老妇wbb | 日欧一片内射va在线影院 | 亚洲日本va中文字幕 | 国产av无码专区亚洲awww | 狠狠色色综合网站 | 国产av人人夜夜澡人人爽麻豆 | 久久久久久亚洲精品a片成人 | 婷婷五月综合激情中文字幕 | 全球成人中文在线 | 亚洲中文字幕成人无码 | 任你躁在线精品免费 | 国产精品高潮呻吟av久久4虎 | 在线欧美精品一区二区三区 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲娇小与黑人巨大交 | 欧美日本日韩 | 老熟妇乱子伦牲交视频 | 小泽玛莉亚一区二区视频在线 | 久久精品人人做人人综合 | 亚洲日本va中文字幕 | 日本一卡二卡不卡视频查询 | 九一九色国产 | 福利一区二区三区视频在线观看 | 又大又紧又粉嫩18p少妇 | 亚洲精品国偷拍自产在线麻豆 | 国精品人妻无码一区二区三区蜜柚 | 亚洲乱码中文字幕在线 | 国产av久久久久精东av | 最近中文2019字幕第二页 | 人人妻人人澡人人爽人人精品浪潮 | 国产精品亚洲lv粉色 | 97精品人妻一区二区三区香蕉 | 美女扒开屁股让男人桶 | 老熟女重囗味hdxx69 | 成人精品视频一区二区三区尤物 | 亚洲狠狠婷婷综合久久 | 一区二区三区高清视频一 | 色一情一乱一伦一区二区三欧美 | 国产精品久久久久久久影院 | 国产午夜视频在线观看 | 亚洲日韩av一区二区三区四区 | 波多野结衣一区二区三区av免费 | 国产一区二区三区精品视频 | 亚洲の无码国产の无码影院 | 日日麻批免费40分钟无码 | 国产精品视频免费播放 | 国产三级久久久精品麻豆三级 | 激情爆乳一区二区三区 | 亚洲中文字幕av在天堂 | 乱人伦中文视频在线观看 | 精品久久综合1区2区3区激情 | 成人欧美一区二区三区 | 国产精品久久久久久久9999 | 欧美第一黄网免费网站 | 久久久久成人片免费观看蜜芽 | 97se亚洲精品一区 | 丰满肥臀大屁股熟妇激情视频 | 丝袜美腿亚洲一区二区 | 狂野欧美性猛交免费视频 | 日韩精品无码免费一区二区三区 | 久久久久久久久888 | 久久精品女人的天堂av | 国精产品一区二区三区 | 国产乱人无码伦av在线a | 国产真实乱对白精彩久久 | 国产福利视频一区二区 | 婷婷五月综合激情中文字幕 | 激情内射日本一区二区三区 | 亚洲欧美综合区丁香五月小说 | 狠狠亚洲超碰狼人久久 | 中文字幕 亚洲精品 第1页 | 少女韩国电视剧在线观看完整 | 欧美日韩一区二区免费视频 | 久久人人爽人人人人片 | 日产精品99久久久久久 | 国内揄拍国内精品人妻 | 乱人伦人妻中文字幕无码久久网 | 东京一本一道一二三区 | 久久久久久久久蜜桃 | 又紧又大又爽精品一区二区 | 18无码粉嫩小泬无套在线观看 | 97夜夜澡人人爽人人喊中国片 | 亚洲人成无码网www | 欧美日韩一区二区综合 | 波多野42部无码喷潮在线 | 国产精品久久久久9999小说 | 日韩视频 中文字幕 视频一区 | 在线a亚洲视频播放在线观看 | 无码国模国产在线观看 | 免费中文字幕日韩欧美 | 亚洲欧美色中文字幕在线 | 丝袜足控一区二区三区 | 亚洲理论电影在线观看 | 狠狠综合久久久久综合网 | av无码不卡在线观看免费 | 国产亚洲精品久久久闺蜜 | 亚洲精品www久久久 | 最近的中文字幕在线看视频 | 中文字幕 亚洲精品 第1页 | 免费国产黄网站在线观看 | 久久综合给合久久狠狠狠97色 | 久久久av男人的天堂 | 色欲综合久久中文字幕网 | yw尤物av无码国产在线观看 | 日韩人妻少妇一区二区三区 | 久久国产精品精品国产色婷婷 | 亚洲国产欧美日韩精品一区二区三区 | av无码久久久久不卡免费网站 | 强开小婷嫩苞又嫩又紧视频 | www一区二区www免费 | 国产人妖乱国产精品人妖 | 国产在线精品一区二区高清不卡 | 麻豆果冻传媒2021精品传媒一区下载 | 亚洲一区二区三区国产精华液 | 性色欲情网站iwww九文堂 | 亚洲自偷自偷在线制服 | 精品无人国产偷自产在线 | 免费国产成人高清在线观看网站 | 狠狠色噜噜狠狠狠7777奇米 | 男女下面进入的视频免费午夜 | 老子影院午夜精品无码 | 精品无码一区二区三区爱欲 | 亚洲色偷偷男人的天堂 | 在线天堂新版最新版在线8 | 午夜福利试看120秒体验区 | 亚洲精品综合五月久久小说 | 成人精品一区二区三区中文字幕 | 国产精品内射视频免费 | 无码中文字幕色专区 | 精品厕所偷拍各类美女tp嘘嘘 | 99久久人妻精品免费二区 | 扒开双腿疯狂进出爽爽爽视频 | 国产人妻久久精品二区三区老狼 | 小sao货水好多真紧h无码视频 | 国内精品久久毛片一区二区 | 熟女少妇在线视频播放 | 无码成人精品区在线观看 | 大肉大捧一进一出视频出来呀 | 蜜桃无码一区二区三区 | 一个人免费观看的www视频 | 国产97色在线 | 免 | 国产精品无码成人午夜电影 | 呦交小u女精品视频 | 少妇高潮一区二区三区99 | 国产精品久久久久久亚洲影视内衣 | 亚洲自偷自拍另类第1页 | 波多野结衣一区二区三区av免费 | 亚洲中文字幕无码中字 | 东京一本一道一二三区 | 亚洲呦女专区 | 欧美人与牲动交xxxx | 亚洲中文字幕在线无码一区二区 | 1000部夫妻午夜免费 | 东京热无码av男人的天堂 | 99久久久无码国产精品免费 | 真人与拘做受免费视频一 | 免费观看激色视频网站 | 国产做国产爱免费视频 | 国产做国产爱免费视频 | 成人精品视频一区二区 | 99久久久国产精品无码免费 | 亚洲精品一区二区三区在线观看 | 欧美人与善在线com | 国内少妇偷人精品视频免费 | 日韩人妻无码中文字幕视频 | 精品国精品国产自在久国产87 | 国产一区二区不卡老阿姨 | 欧美国产日韩亚洲中文 | 日本一区二区更新不卡 | 亚洲va中文字幕无码久久不卡 | 亚洲成av人综合在线观看 | 一个人看的www免费视频在线观看 | 欧美亚洲日韩国产人成在线播放 | 亚洲国产成人av在线观看 | 免费人成在线观看网站 | 成人试看120秒体验区 | 久久综合九色综合97网 | 在线 国产 欧美 亚洲 天堂 | 欧美 日韩 人妻 高清 中文 | 四十如虎的丰满熟妇啪啪 | 狠狠躁日日躁夜夜躁2020 | 在线a亚洲视频播放在线观看 | 99riav国产精品视频 | 国产精品高潮呻吟av久久 | 国产精品人人妻人人爽 | 久久亚洲国产成人精品性色 | 久久久久se色偷偷亚洲精品av | 少妇无码吹潮 | 欧洲熟妇精品视频 | 国产精品美女久久久久av爽李琼 | 欧洲精品码一区二区三区免费看 | 国产 精品 自在自线 | 亚洲区欧美区综合区自拍区 | 日本乱人伦片中文三区 | 欧美日韩久久久精品a片 | 麻豆国产丝袜白领秘书在线观看 | 性生交片免费无码看人 | 免费人成网站视频在线观看 | 国产精品人人爽人人做我的可爱 | www国产精品内射老师 | 日本熟妇大屁股人妻 | 青草青草久热国产精品 | 高潮毛片无遮挡高清免费视频 | 性生交大片免费看l | 国产精品无码一区二区三区不卡 | 国产高清不卡无码视频 | 99精品视频在线观看免费 | 国产办公室秘书无码精品99 | 国产香蕉尹人视频在线 | 久久伊人色av天堂九九小黄鸭 | 国产肉丝袜在线观看 | 日本xxxx色视频在线观看免费 | 亚欧洲精品在线视频免费观看 | 性欧美熟妇videofreesex | 亚洲精品国产a久久久久久 | 蜜桃臀无码内射一区二区三区 | 又大又硬又黄的免费视频 | 国语自产偷拍精品视频偷 | 一本久久a久久精品vr综合 | 国产午夜亚洲精品不卡下载 | 欧美人与禽猛交狂配 | 欧美黑人巨大xxxxx | 亚洲精品国偷拍自产在线麻豆 | 欧美喷潮久久久xxxxx | 亚洲精品久久久久avwww潮水 | 98国产精品综合一区二区三区 | 国产三级久久久精品麻豆三级 | 黑人玩弄人妻中文在线 | 国产成人精品视频ⅴa片软件竹菊 | 99麻豆久久久国产精品免费 | 性欧美videos高清精品 | 亚洲男人av香蕉爽爽爽爽 | 日日躁夜夜躁狠狠躁 | 欧美性猛交内射兽交老熟妇 | 国产成人无码a区在线观看视频app | 亚洲 激情 小说 另类 欧美 | 无码人妻丰满熟妇区毛片18 | 在线天堂新版最新版在线8 | 国产精品久久久午夜夜伦鲁鲁 | 少妇高潮喷潮久久久影院 | 少妇性l交大片 | 欧美第一黄网免费网站 | 精品国产麻豆免费人成网站 | 国产精品无码久久av | 国产高清av在线播放 | 成 人 网 站国产免费观看 | 久久久精品人妻久久影视 | 成人欧美一区二区三区黑人 | 青青草原综合久久大伊人精品 | 欧美日韩综合一区二区三区 | 少妇无码吹潮 | 偷窥村妇洗澡毛毛多 | 97夜夜澡人人双人人人喊 | 99精品视频在线观看免费 | 亚洲午夜久久久影院 | 日本高清一区免费中文视频 | 国産精品久久久久久久 | 扒开双腿疯狂进出爽爽爽视频 | 无码一区二区三区在线 | 美女扒开屁股让男人桶 | 乱码午夜-极国产极内射 | 亚洲区小说区激情区图片区 | 国产人妖乱国产精品人妖 | 扒开双腿吃奶呻吟做受视频 | 日韩人妻无码中文字幕视频 | 国产精品视频免费播放 | 国产精品va在线观看无码 | 九月婷婷人人澡人人添人人爽 | 亚无码乱人伦一区二区 | 人妻尝试又大又粗久久 | 亚洲人交乣女bbw | 精品国产一区av天美传媒 | 欧美一区二区三区视频在线观看 | 欧美大屁股xxxxhd黑色 | 亚洲 日韩 欧美 成人 在线观看 | 国产精品美女久久久网av | 成年美女黄网站色大免费全看 | 日本大乳高潮视频在线观看 | 在线亚洲高清揄拍自拍一品区 | 曰韩无码二三区中文字幕 | 无码国模国产在线观看 | 日本精品人妻无码77777 天堂一区人妻无码 | 东京一本一道一二三区 | 国产av无码专区亚洲a∨毛片 | 亚洲大尺度无码无码专区 | 国产一区二区三区影院 | 国产精品久久久久影院嫩草 | 成人精品视频一区二区三区尤物 | 4hu四虎永久在线观看 | 四虎国产精品免费久久 | 日本精品人妻无码77777 天堂一区人妻无码 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 天堂一区人妻无码 | 亚洲阿v天堂在线 | 美女扒开屁股让男人桶 | 久久无码人妻影院 | 亚洲综合精品香蕉久久网 | 亚洲人成影院在线观看 | 麻豆国产97在线 | 欧洲 | 久久午夜无码鲁丝片秋霞 | 国产精品-区区久久久狼 | 亚洲精品久久久久久久久久久 | 最近中文2019字幕第二页 | 漂亮人妻洗澡被公强 日日躁 | 免费看男女做好爽好硬视频 | 少妇厨房愉情理9仑片视频 | 一本久久a久久精品vr综合 | av在线亚洲欧洲日产一区二区 | 久久久久成人精品免费播放动漫 | 国产一精品一av一免费 | 成人性做爰aaa片免费看 | 2019午夜福利不卡片在线 | 中文字幕无码免费久久9一区9 | 欧美性黑人极品hd | 十八禁真人啪啪免费网站 | 成人av无码一区二区三区 | 亚洲gv猛男gv无码男同 | 午夜免费福利小电影 | 亚洲成a人片在线观看无码 | 亚洲国产成人av在线观看 | 久久99精品久久久久久 | 国产精品久久久午夜夜伦鲁鲁 | 国产高潮视频在线观看 | 国产精品a成v人在线播放 | 真人与拘做受免费视频 | 亚洲国产精品一区二区第一页 | 日本一卡二卡不卡视频查询 | 精品一区二区三区波多野结衣 | 婷婷丁香六月激情综合啪 | 久久久久久久女国产乱让韩 | 任你躁国产自任一区二区三区 | 99riav国产精品视频 | 精品久久久中文字幕人妻 | 精品国产精品久久一区免费式 | 人妻天天爽夜夜爽一区二区 | 亚洲狠狠色丁香婷婷综合 | 熟女少妇人妻中文字幕 | 日韩精品乱码av一区二区 | 精品无码国产自产拍在线观看蜜 | √天堂资源地址中文在线 | 国产在线aaa片一区二区99 | 最新国产麻豆aⅴ精品无码 | 亚洲成a人片在线观看无码3d | 黑人粗大猛烈进出高潮视频 | 又粗又大又硬又长又爽 | 九九综合va免费看 | 丰满岳乱妇在线观看中字无码 | 国产婷婷色一区二区三区在线 | 国产农村乱对白刺激视频 | 国产口爆吞精在线视频 | 亚洲国产欧美在线成人 | 色五月五月丁香亚洲综合网 | 鲁鲁鲁爽爽爽在线视频观看 | 黑人巨大精品欧美一区二区 | 亚洲精品一区二区三区大桥未久 | 欧美性黑人极品hd | 人人妻人人澡人人爽人人精品浪潮 | 少妇人妻大乳在线视频 | 人人澡人人妻人人爽人人蜜桃 | 国产精品视频免费播放 | 沈阳熟女露脸对白视频 | 久久99精品国产.久久久久 | 曰韩无码二三区中文字幕 | 精品国产一区二区三区四区在线看 | 久久精品成人欧美大片 | 日韩亚洲欧美精品综合 | 久久视频在线观看精品 | 日本丰满护士爆乳xxxx | 国产真实乱对白精彩久久 | 强伦人妻一区二区三区视频18 | 国产在线无码精品电影网 | 天天拍夜夜添久久精品大 | 亚洲国产精品美女久久久久 | 欧美丰满少妇xxxx性 | 男女猛烈xx00免费视频试看 | 精品水蜜桃久久久久久久 | 亚洲精品综合一区二区三区在线 | 日本一区二区更新不卡 | 亚洲国产高清在线观看视频 | 一本加勒比波多野结衣 | 女人被男人爽到呻吟的视频 | 日本一本二本三区免费 | 97久久精品无码一区二区 | 久久久久99精品国产片 | 日韩欧美群交p片內射中文 | 久精品国产欧美亚洲色aⅴ大片 | 亚洲阿v天堂在线 | www国产亚洲精品久久久日本 | 1000部夫妻午夜免费 | 日韩少妇白浆无码系列 | 成人一区二区免费视频 | 男人的天堂2018无码 | 丰满妇女强制高潮18xxxx | 午夜福利一区二区三区在线观看 | 成人亚洲精品久久久久 | 十八禁真人啪啪免费网站 | 成人无码精品1区2区3区免费看 | 国产成人精品三级麻豆 | 久久久久成人精品免费播放动漫 | 白嫩日本少妇做爰 | 国产成人无码av在线影院 | 东京热无码av男人的天堂 | 亚洲精品一区二区三区在线观看 | 男人扒开女人内裤强吻桶进去 | 欧美黑人巨大xxxxx | 中文字幕日产无线码一区 | 免费无码av一区二区 | 久久国产精品精品国产色婷婷 | 色婷婷综合激情综在线播放 | 中文字幕无码av波多野吉衣 | 日本饥渴人妻欲求不满 | 久久综合香蕉国产蜜臀av | 人妻体内射精一区二区三四 | 一本大道伊人av久久综合 | 国产午夜无码视频在线观看 | 日韩少妇内射免费播放 | 国产97色在线 | 免 | 国产无av码在线观看 | 天天摸天天碰天天添 | 久热国产vs视频在线观看 | 999久久久国产精品消防器材 | 大地资源网第二页免费观看 | 无码人妻少妇伦在线电影 | 亚洲精品www久久久 | 国语精品一区二区三区 | 丰满岳乱妇在线观看中字无码 | 精品偷拍一区二区三区在线看 | 国产人妻久久精品二区三区老狼 | 色狠狠av一区二区三区 | 中文字幕无线码免费人妻 | 久久国产精品二国产精品 | 人人妻人人澡人人爽人人精品浪潮 | 在线成人www免费观看视频 | 亚洲国产精品久久久天堂 | 国产人妻精品一区二区三区 | 亚洲无人区一区二区三区 | 88国产精品欧美一区二区三区 | 88国产精品欧美一区二区三区 | 1000部啪啪未满十八勿入下载 | 2019nv天堂香蕉在线观看 | √天堂资源地址中文在线 | 成人av无码一区二区三区 | 帮老师解开蕾丝奶罩吸乳网站 | 国产成人精品久久亚洲高清不卡 | 亚洲中文字幕在线无码一区二区 | 男人的天堂av网站 | 久久久久久久久888 | 人人妻人人澡人人爽欧美精品 | 国产精品丝袜黑色高跟鞋 | 国产精品爱久久久久久久 | 午夜免费福利小电影 | 少女韩国电视剧在线观看完整 | 中文字幕乱码中文乱码51精品 | 欧美日韩一区二区三区自拍 | 久久精品国产亚洲精品 | 国产麻豆精品精东影业av网站 | 国产真实伦对白全集 | 99国产精品白浆在线观看免费 | 夜夜躁日日躁狠狠久久av | 野狼第一精品社区 | 欧洲极品少妇 | 任你躁在线精品免费 | 大色综合色综合网站 | 日本xxxx色视频在线观看免费 | 欧洲熟妇精品视频 | 国产在线aaa片一区二区99 | 在线观看欧美一区二区三区 | 亚洲中文字幕在线无码一区二区 | 久久久久国色av免费观看性色 | 国内精品九九久久久精品 | 亚洲欧美国产精品久久 | 亚洲欧美国产精品专区久久 | 精品国产精品久久一区免费式 | 欧美日韩一区二区免费视频 | 少妇无套内谢久久久久 | 少妇太爽了在线观看 | 亚洲国产精品美女久久久久 | 成人女人看片免费视频放人 | 夜夜夜高潮夜夜爽夜夜爰爰 | 久久亚洲日韩精品一区二区三区 | 日韩av激情在线观看 | 伊在人天堂亚洲香蕉精品区 | 人人爽人人爽人人片av亚洲 | 久久国产劲爆∧v内射 | 国产成人无码一二三区视频 | 国产av一区二区三区最新精品 | 欧美人与牲动交xxxx | 偷窥日本少妇撒尿chinese | 乱码午夜-极国产极内射 | 久久久久久a亚洲欧洲av冫 | 伊人久久大香线蕉亚洲 | 日本肉体xxxx裸交 | 内射巨臀欧美在线视频 | 亚洲精品久久久久久久久久久 | 国产人妻精品午夜福利免费 | 波多野结衣av在线观看 | 无码精品人妻一区二区三区av | 国产内射老熟女aaaa | 久久国产精品萌白酱免费 | 理论片87福利理论电影 | 亚洲一区二区三区播放 | 免费网站看v片在线18禁无码 | 成 人 网 站国产免费观看 | 国产精品高潮呻吟av久久4虎 | 国产亚洲欧美日韩亚洲中文色 | 激情亚洲一区国产精品 | 日韩少妇白浆无码系列 | 国产亚洲精品久久久久久久 | 天堂亚洲免费视频 | 乱人伦中文视频在线观看 | 色狠狠av一区二区三区 | 国内精品人妻无码久久久影院 | 国产av无码专区亚洲awww | 久久精品国产一区二区三区肥胖 | 欧美性黑人极品hd | 色婷婷香蕉在线一区二区 | 午夜福利试看120秒体验区 | 欧美自拍另类欧美综合图片区 | 亚洲七七久久桃花影院 | 日本在线高清不卡免费播放 | 国产电影无码午夜在线播放 | 精品国产成人一区二区三区 | 国产熟妇另类久久久久 | 久久精品女人天堂av免费观看 | 日日摸天天摸爽爽狠狠97 | 人人妻人人澡人人爽欧美一区九九 | 国产成人无码专区 | 国产亚洲精品久久久久久久久动漫 | 亚洲の无码国产の无码步美 | 国产欧美亚洲精品a | 精品一区二区三区波多野结衣 | 午夜肉伦伦影院 | 亚洲а∨天堂久久精品2021 | 久久久精品成人免费观看 | 内射爽无广熟女亚洲 | 精品国产aⅴ无码一区二区 | 久久久久久久女国产乱让韩 | 骚片av蜜桃精品一区 | 蜜臀av无码人妻精品 | 鲁大师影院在线观看 | 亚洲欧美国产精品久久 | 精品国精品国产自在久国产87 | 小sao货水好多真紧h无码视频 | 欧美性生交活xxxxxdddd | 久久精品人妻少妇一区二区三区 | 久久这里只有精品视频9 | 高潮喷水的毛片 | 午夜精品久久久久久久久 | 国产特级毛片aaaaaaa高清 | 九九久久精品国产免费看小说 | 人妻夜夜爽天天爽三区 | 又湿又紧又大又爽a视频国产 | 麻豆md0077饥渴少妇 | 欧美猛少妇色xxxxx | 亚洲中文无码av永久不收费 | 久久精品国产大片免费观看 | 国产一区二区三区四区五区加勒比 | 国产热a欧美热a在线视频 | 无码人妻精品一区二区三区下载 | 欧美国产亚洲日韩在线二区 | 精品日本一区二区三区在线观看 | 国产97人人超碰caoprom | 两性色午夜视频免费播放 | 久久精品女人天堂av免费观看 | 天天摸天天碰天天添 | 性开放的女人aaa片 | 亚洲熟妇自偷自拍另类 | 国产熟妇另类久久久久 | 国产成人精品视频ⅴa片软件竹菊 | 国产精品va在线观看无码 | 亚洲精品成a人在线观看 | 狠狠噜狠狠狠狠丁香五月 | 四虎国产精品一区二区 | 精品国产精品久久一区免费式 | 噜噜噜亚洲色成人网站 | 老熟妇仑乱视频一区二区 | 成人欧美一区二区三区黑人免费 | 精品久久综合1区2区3区激情 | 久久精品一区二区三区四区 | 亚洲精品综合五月久久小说 | 久久国产劲爆∧v内射 | 人妻中文无码久热丝袜 | 少妇久久久久久人妻无码 | 精品国产一区二区三区四区在线看 | 成人片黄网站色大片免费观看 | 少妇太爽了在线观看 | 伊人久久大香线蕉午夜 | 久在线观看福利视频 | 男女下面进入的视频免费午夜 | 国产9 9在线 | 中文 | 亚洲小说春色综合另类 | 国产高清不卡无码视频 | 久久久精品456亚洲影院 | 国产无套粉嫩白浆在线 | 亚洲国产精品毛片av不卡在线 | 国产女主播喷水视频在线观看 | 中国女人内谢69xxxxxa片 | 日本一卡2卡3卡四卡精品网站 | 国产无遮挡吃胸膜奶免费看 | 国产激情艳情在线看视频 | 久久久亚洲欧洲日产国码αv | 人人妻人人藻人人爽欧美一区 | 野狼第一精品社区 | 麻豆成人精品国产免费 | 亚洲中文字幕在线无码一区二区 | 国内精品一区二区三区不卡 | 97夜夜澡人人双人人人喊 | 无码人妻丰满熟妇区五十路百度 | 香蕉久久久久久av成人 | 国产精品美女久久久 | 免费播放一区二区三区 | 无码乱肉视频免费大全合集 | 日本va欧美va欧美va精品 | 男人的天堂2018无码 | 日韩av激情在线观看 | 男女爱爱好爽视频免费看 | 婷婷五月综合缴情在线视频 | 国精品人妻无码一区二区三区蜜柚 | 无码人妻精品一区二区三区不卡 | 熟妇人妻无乱码中文字幕 | 久久精品国产亚洲精品 | 国产精品国产三级国产专播 | 国产婷婷色一区二区三区在线 | 国産精品久久久久久久 | 少妇无码av无码专区在线观看 | 男女超爽视频免费播放 | 无码av中文字幕免费放 | 撕开奶罩揉吮奶头视频 | 爱做久久久久久 | 国产艳妇av在线观看果冻传媒 | 亚洲精品国产第一综合99久久 | 在线亚洲高清揄拍自拍一品区 | 秋霞特色aa大片 | 在线欧美精品一区二区三区 | 中文字幕人妻丝袜二区 | 久久久国产一区二区三区 | 国产成人无码区免费内射一片色欲 | аⅴ资源天堂资源库在线 | 中国女人内谢69xxxx | 最近中文2019字幕第二页 | 国产亚洲精品久久久久久久 | 狠狠躁日日躁夜夜躁2020 | 日韩成人一区二区三区在线观看 | 国产黄在线观看免费观看不卡 | 18无码粉嫩小泬无套在线观看 | 国精产品一品二品国精品69xx | 极品尤物被啪到呻吟喷水 | 久久久久久av无码免费看大片 | 人人澡人人透人人爽 | 在线播放免费人成毛片乱码 | 永久免费精品精品永久-夜色 | 亚洲小说图区综合在线 | 亚欧洲精品在线视频免费观看 | 无码福利日韩神码福利片 | 国产亚洲tv在线观看 | 国产人妻人伦精品 | 中文字幕 亚洲精品 第1页 | 娇妻被黑人粗大高潮白浆 | 性色av无码免费一区二区三区 | 日本爽爽爽爽爽爽在线观看免 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 久久婷婷五月综合色国产香蕉 | 国产又粗又硬又大爽黄老大爷视 | 久久人人爽人人爽人人片av高清 | 亚洲日本va中文字幕 | 亚洲欧美日韩成人高清在线一区 | 欧美日本日韩 | 欧美熟妇另类久久久久久多毛 | 亚洲日本一区二区三区在线 | 人妻aⅴ无码一区二区三区 | 老熟妇乱子伦牲交视频 | 久久久www成人免费毛片 | 亚洲国产av精品一区二区蜜芽 | 在线 国产 欧美 亚洲 天堂 | 久久国产精品萌白酱免费 | 国产精品久久久一区二区三区 | 日韩欧美群交p片內射中文 | 亚洲の无码国产の无码影院 | 国产精品永久免费视频 | 国产一区二区三区影院 | 牲欲强的熟妇农村老妇女视频 | 精品偷拍一区二区三区在线看 | 性做久久久久久久免费看 | 久久国产精品二国产精品 | 日日夜夜撸啊撸 | 国产综合久久久久鬼色 | 欧美激情一区二区三区成人 | 纯爱无遮挡h肉动漫在线播放 | 99久久精品日本一区二区免费 | 欧美老人巨大xxxx做受 | 国产精品怡红院永久免费 | 久久精品99久久香蕉国产色戒 | 日本一本二本三区免费 | 丁香花在线影院观看在线播放 | 成人试看120秒体验区 | 国产无遮挡又黄又爽免费视频 | 国产激情无码一区二区app | 久久综合给久久狠狠97色 | 精品无码国产自产拍在线观看蜜 | 亚洲欧洲日本综合aⅴ在线 | 国产精品久久国产三级国 | 精品日本一区二区三区在线观看 | 午夜精品久久久内射近拍高清 | 免费播放一区二区三区 | 精品国产乱码久久久久乱码 | 婷婷六月久久综合丁香 | 国产精品美女久久久久av爽李琼 | 亚洲无人区一区二区三区 | 一区二区传媒有限公司 | 亚洲s码欧洲m码国产av | 无码人妻黑人中文字幕 | 欧美老妇与禽交 | а天堂中文在线官网 | 男人扒开女人内裤强吻桶进去 | 青青草原综合久久大伊人精品 | 欧美日韩在线亚洲综合国产人 | 日日碰狠狠躁久久躁蜜桃 | 狠狠色丁香久久婷婷综合五月 | 国产偷国产偷精品高清尤物 | 午夜免费福利小电影 | 亚洲乱码国产乱码精品精 | 亚洲乱码国产乱码精品精 | 色诱久久久久综合网ywww | 少妇的肉体aa片免费 | 97无码免费人妻超级碰碰夜夜 | 少妇激情av一区二区 | 国产精品.xx视频.xxtv | 日产精品高潮呻吟av久久 | 一二三四在线观看免费视频 | 国产精品无码成人午夜电影 | 国产精品第一国产精品 | 丰满少妇弄高潮了www | 亚洲人亚洲人成电影网站色 | 激情内射日本一区二区三区 | 图片区 小说区 区 亚洲五月 | 天天爽夜夜爽夜夜爽 | 99视频精品全部免费免费观看 | 成人aaa片一区国产精品 | 亚洲国产精品美女久久久久 | 97精品人妻一区二区三区香蕉 | 51国偷自产一区二区三区 | 欧美国产亚洲日韩在线二区 | 无码帝国www无码专区色综合 | 乱码av麻豆丝袜熟女系列 | 永久黄网站色视频免费直播 | 欧美日韩亚洲国产精品 | 国产精品a成v人在线播放 | 初尝人妻少妇中文字幕 | 日日麻批免费40分钟无码 | 成人片黄网站色大片免费观看 | 少妇被粗大的猛进出69影院 | 香港三级日本三级妇三级 | 中文字幕无码日韩专区 | 妺妺窝人体色www在线小说 | 亚洲色大成网站www | 国产精品igao视频网 | 成人一在线视频日韩国产 | 人人澡人人透人人爽 | 国产无套内射久久久国产 | 亚无码乱人伦一区二区 | 无码中文字幕色专区 | 装睡被陌生人摸出水好爽 | 一本久久a久久精品亚洲 | 国内精品久久毛片一区二区 | 国产电影无码午夜在线播放 | 999久久久国产精品消防器材 | 一个人免费观看的www视频 | 偷窥日本少妇撒尿chinese | 国产人妻久久精品二区三区老狼 | 欧洲美熟女乱又伦 | 人人澡人人妻人人爽人人蜜桃 | 久久综合香蕉国产蜜臀av | 精品夜夜澡人妻无码av蜜桃 | 精品无码成人片一区二区98 | 欧美兽交xxxx×视频 | 国产精品久久久久久亚洲毛片 | 欧美老妇交乱视频在线观看 | 午夜熟女插插xx免费视频 | 日日摸天天摸爽爽狠狠97 | 久久99久久99精品中文字幕 | 秋霞成人午夜鲁丝一区二区三区 | 国产精品久久久久无码av色戒 | 久久精品国产日本波多野结衣 | 欧美日本免费一区二区三区 | 亚洲啪av永久无码精品放毛片 | 久久久国产精品无码免费专区 | 亚洲精品一区二区三区四区五区 | 久久亚洲精品中文字幕无男同 | 成人aaa片一区国产精品 | 自拍偷自拍亚洲精品10p | 无码av中文字幕免费放 | 亚洲成在人网站无码天堂 | 亚洲无人区一区二区三区 | 精品国产一区av天美传媒 | a国产一区二区免费入口 | 又黄又爽又色的视频 | 精品午夜福利在线观看 | 色窝窝无码一区二区三区色欲 | 色婷婷欧美在线播放内射 | 午夜福利试看120秒体验区 | 久久人妻内射无码一区三区 | 装睡被陌生人摸出水好爽 | 国产精品嫩草久久久久 | 东京热无码av男人的天堂 | 亚洲一区二区三区四区 | 久久久久成人精品免费播放动漫 | 亚洲国产精品一区二区第一页 | 特黄特色大片免费播放器图片 | 中文精品久久久久人妻不卡 | 奇米影视7777久久精品人人爽 | 国产做国产爱免费视频 | 国产精品沙发午睡系列 | 色欲久久久天天天综合网精品 | 老头边吃奶边弄进去呻吟 | 成人免费视频视频在线观看 免费 | 国产成人精品优优av | 色婷婷综合中文久久一本 | 亚洲欧美日韩成人高清在线一区 | 一本久久a久久精品vr综合 | 国产精品丝袜黑色高跟鞋 | 国产午夜精品一区二区三区嫩草 | 四十如虎的丰满熟妇啪啪 | 无码人中文字幕 | 日日摸日日碰夜夜爽av | 日产精品高潮呻吟av久久 | 亚洲精品午夜无码电影网 | 性史性农村dvd毛片 | 亚洲va欧美va天堂v国产综合 | 亚洲欧美色中文字幕在线 | 亚洲色欲色欲欲www在线 | 亚洲娇小与黑人巨大交 | 亚洲日韩av片在线观看 | 国产亚洲精品久久久闺蜜 | 青青草原综合久久大伊人精品 | 国产后入清纯学生妹 | 一本大道伊人av久久综合 | 亚洲高清偷拍一区二区三区 | 中文字幕无码日韩欧毛 | 精品久久综合1区2区3区激情 | 无码毛片视频一区二区本码 | 黑人玩弄人妻中文在线 | 一本色道久久综合亚洲精品不卡 | 国产 浪潮av性色四虎 | 国产成人精品优优av | 无遮挡国产高潮视频免费观看 | 中国大陆精品视频xxxx | 亚洲一区二区三区在线观看网站 | 国产精品久久久久久亚洲影视内衣 | 九九久久精品国产免费看小说 | 成在人线av无码免观看麻豆 | 好屌草这里只有精品 | 澳门永久av免费网站 | 夜夜高潮次次欢爽av女 | 熟女体下毛毛黑森林 | 亚洲国产欧美日韩精品一区二区三区 | 欧美日韩久久久精品a片 | 色欲综合久久中文字幕网 | 欧美 日韩 人妻 高清 中文 | 无码吃奶揉捏奶头高潮视频 | 亚洲精品国产品国语在线观看 | 午夜精品久久久久久久久 | 51国偷自产一区二区三区 | 国产亚av手机在线观看 | 牲欲强的熟妇农村老妇女视频 | 亚洲精品一区二区三区婷婷月 | 日韩欧美成人免费观看 | 国产在线精品一区二区三区直播 | 欧美国产日产一区二区 | 少妇性俱乐部纵欲狂欢电影 | 天堂а√在线地址中文在线 | 亚洲日本在线电影 | 亚洲热妇无码av在线播放 | 人人妻人人藻人人爽欧美一区 | 国产亚洲精品久久久闺蜜 | 性生交大片免费看女人按摩摩 | 对白脏话肉麻粗话av | 中文字幕乱码亚洲无线三区 | 亚洲国产精品美女久久久久 | 日韩av无码一区二区三区不卡 | 亚洲中文字幕va福利 | 日本免费一区二区三区最新 | 亚洲一区二区三区在线观看网站 | 成人精品天堂一区二区三区 | 十八禁真人啪啪免费网站 | 午夜不卡av免费 一本久久a久久精品vr综合 | 狂野欧美激情性xxxx | 中文亚洲成a人片在线观看 | 人人超人人超碰超国产 | 亚洲乱亚洲乱妇50p | 欧美日韩在线亚洲综合国产人 | 亚洲色无码一区二区三区 | av在线亚洲欧洲日产一区二区 | 亚洲色www成人永久网址 | 日韩精品a片一区二区三区妖精 | 日韩人妻少妇一区二区三区 | 久久久久成人片免费观看蜜芽 | 狠狠躁日日躁夜夜躁2020 | 老子影院午夜精品无码 | 亚洲人成影院在线观看 | 综合人妻久久一区二区精品 | 国产疯狂伦交大片 | 毛片内射-百度 | 色五月五月丁香亚洲综合网 | 亚洲中文字幕va福利 | 亚洲乱码中文字幕在线 | 国产精品第一区揄拍无码 | 一本精品99久久精品77 | 黄网在线观看免费网站 | 亚洲中文字幕va福利 | 日本一卡二卡不卡视频查询 | 欧美 亚洲 国产 另类 | 东京热男人av天堂 | 亚洲精品欧美二区三区中文字幕 | 久久久久国色av免费观看性色 | 夫妻免费无码v看片 | 老熟女重囗味hdxx69 | 福利一区二区三区视频在线观看 | 精品夜夜澡人妻无码av蜜桃 | 亚洲高清偷拍一区二区三区 | 日产国产精品亚洲系列 | 国产人妖乱国产精品人妖 | 国产乱人无码伦av在线a | 精品国产av色一区二区深夜久久 | 狠狠噜狠狠狠狠丁香五月 | 国产av人人夜夜澡人人爽麻豆 | 国产香蕉尹人视频在线 | 乱人伦人妻中文字幕无码久久网 | 国产欧美精品一区二区三区 | 麻豆国产丝袜白领秘书在线观看 | 人妻与老人中文字幕 | 精品日本一区二区三区在线观看 | 亚洲精品欧美二区三区中文字幕 | 亚洲日本一区二区三区在线 | 国内精品一区二区三区不卡 | 少妇被黑人到高潮喷出白浆 | 中文无码精品a∨在线观看不卡 | 水蜜桃色314在线观看 | 国产肉丝袜在线观看 | 国产乱人伦av在线无码 | 亚洲中文字幕无码中文字在线 | 欧美日韩综合一区二区三区 | 久久久久久av无码免费看大片 | 国内精品人妻无码久久久影院 | 一个人看的视频www在线 | 久久精品国产大片免费观看 | 成人av无码一区二区三区 | 欧美性生交xxxxx久久久 | 亚洲一区二区三区无码久久 | 免费无码一区二区三区蜜桃大 | 国产av人人夜夜澡人人爽麻豆 | 国产精品人人爽人人做我的可爱 | 成人无码视频在线观看网站 | 日本一区二区三区免费播放 | 激情五月综合色婷婷一区二区 | 亚洲成a人片在线观看无码3d | 国精产品一品二品国精品69xx | 久久久久99精品成人片 | 国产黄在线观看免费观看不卡 | 成人精品天堂一区二区三区 | 俄罗斯老熟妇色xxxx | 欧美野外疯狂做受xxxx高潮 | 久久www免费人成人片 | 妺妺窝人体色www婷婷 | 日本熟妇大屁股人妻 | 免费视频欧美无人区码 | 亚洲区小说区激情区图片区 | 色一情一乱一伦一区二区三欧美 | 日韩av无码中文无码电影 | 欧美老妇与禽交 | 国产精品爱久久久久久久 | 亚洲の无码国产の无码影院 | 天堂亚洲免费视频 | 久久久久免费精品国产 | 国产三级久久久精品麻豆三级 | 99久久精品无码一区二区毛片 | 亚洲成色www久久网站 | 亚洲gv猛男gv无码男同 | 久久精品无码一区二区三区 | 亚洲国产综合无码一区 | 国产精品igao视频网 | aⅴ亚洲 日韩 色 图网站 播放 | 一二三四在线观看免费视频 | 中文字幕无码乱人伦 | 乱中年女人伦av三区 | 亚洲 a v无 码免 费 成 人 a v | 欧美熟妇另类久久久久久多毛 | 无遮挡啪啪摇乳动态图 | 男人的天堂av网站 | 久久亚洲国产成人精品性色 | 欧美熟妇另类久久久久久不卡 | 久久99精品久久久久婷婷 | 国产成人综合色在线观看网站 | 欧美日韩亚洲国产精品 | 亚洲精品国产第一综合99久久 | 国产人妻精品一区二区三区不卡 | 国内精品人妻无码久久久影院蜜桃 | 性啪啪chinese东北女人 | 中文字幕日韩精品一区二区三区 | 少妇无码一区二区二三区 | 激情爆乳一区二区三区 | 国产精品a成v人在线播放 | 永久免费精品精品永久-夜色 | 久久久久99精品国产片 | 亚洲熟女一区二区三区 | 荫蒂添的好舒服视频囗交 | 国产成人人人97超碰超爽8 | 少妇被粗大的猛进出69影院 | 国产超碰人人爽人人做人人添 | 国产熟妇另类久久久久 | 377p欧洲日本亚洲大胆 | 久久精品人人做人人综合 | 永久黄网站色视频免费直播 | 亚洲中文字幕乱码av波多ji | 精品久久久久久人妻无码中文字幕 | 亚洲成av人综合在线观看 | 国产人妖乱国产精品人妖 | 国产午夜手机精彩视频 | 欧美熟妇另类久久久久久不卡 | 中文字幕无码乱人伦 | 日本免费一区二区三区最新 | 日本熟妇人妻xxxxx人hd | 国产精品久久久久7777 | 久久99精品国产.久久久久 | 成人影院yy111111在线观看 | 国产精品内射视频免费 | 国产精品久久久久久久影院 | 久久人妻内射无码一区三区 | 无遮挡啪啪摇乳动态图 | 蜜桃无码一区二区三区 | 撕开奶罩揉吮奶头视频 | 少妇的肉体aa片免费 | 久久久久成人精品免费播放动漫 | 在线观看欧美一区二区三区 | www一区二区www免费 | 男女超爽视频免费播放 | 97无码免费人妻超级碰碰夜夜 | 激情五月综合色婷婷一区二区 | 亚洲娇小与黑人巨大交 | 欧美国产亚洲日韩在线二区 | 中文精品无码中文字幕无码专区 | 国产午夜手机精彩视频 | 精品国产aⅴ无码一区二区 | 给我免费的视频在线观看 | 日韩精品无码一本二本三本色 | 一本色道久久综合狠狠躁 | 无码人妻精品一区二区三区下载 | 天堂亚洲2017在线观看 | 欧美怡红院免费全部视频 | 97夜夜澡人人爽人人喊中国片 | 精品欧美一区二区三区久久久 | 天天拍夜夜添久久精品大 | 无码人妻av免费一区二区三区 | 狂野欧美性猛交免费视频 | 一本大道伊人av久久综合 | 国产综合久久久久鬼色 | 中文字幕色婷婷在线视频 | 欧美日本日韩 | 欧美日本精品一区二区三区 | 久久久www成人免费毛片 | 美女张开腿让人桶 | 亚洲阿v天堂在线 | 97久久精品无码一区二区 | 中文无码成人免费视频在线观看 | 欧美丰满老熟妇xxxxx性 | 国产极品美女高潮无套在线观看 | 少妇性荡欲午夜性开放视频剧场 | 娇妻被黑人粗大高潮白浆 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 国产综合色产在线精品 | 亚洲综合另类小说色区 | 久久久久av无码免费网 | 国产九九九九九九九a片 | 成人亚洲精品久久久久软件 | 国内精品久久久久久中文字幕 | 久久99精品久久久久久动态图 | 国产精品美女久久久久av爽李琼 | 无码人妻久久一区二区三区不卡 | 麻豆成人精品国产免费 | 欧美日韩色另类综合 | 国产在线一区二区三区四区五区 | 免费乱码人妻系列无码专区 | 国产成人一区二区三区别 | 亚洲娇小与黑人巨大交 | 日本一区二区更新不卡 | 国产色在线 | 国产 | 国产精品va在线观看无码 | 夜先锋av资源网站 | 亚洲国产精品久久人人爱 | 国产人妻精品一区二区三区不卡 | 国产亚洲视频中文字幕97精品 | 亚洲成av人影院在线观看 | 小sao货水好多真紧h无码视频 | 成人无码精品一区二区三区 | 四虎国产精品免费久久 | a国产一区二区免费入口 | 日本精品高清一区二区 | 无遮无挡爽爽免费视频 | 亚洲人成网站色7799 | 大色综合色综合网站 | 亚欧洲精品在线视频免费观看 | 亚洲中文字幕乱码av波多ji | 日本精品人妻无码免费大全 | 97色伦图片97综合影院 | 亚洲小说春色综合另类 | 大乳丰满人妻中文字幕日本 | 国产偷国产偷精品高清尤物 | 国产精品内射视频免费 | 性做久久久久久久免费看 | 中文字幕人妻无码一区二区三区 | 国产精品无码永久免费888 | 狠狠色噜噜狠狠狠狠7777米奇 | 欧美高清在线精品一区 | 又湿又紧又大又爽a视频国产 | 搡女人真爽免费视频大全 | 久久久成人毛片无码 | 东京热一精品无码av | 亚洲gv猛男gv无码男同 | 亚洲欧美中文字幕5发布 | 久久久亚洲欧洲日产国码αv | 久久久久久国产精品无码下载 | 精品国偷自产在线视频 | 午夜福利一区二区三区在线观看 |