国产秋霞理论久久久电影-婷婷色九月综合激情丁香-欧美在线观看乱妇视频-精品国avA久久久久久久-国产乱码精品一区二区三区亚洲人-欧美熟妇一区二区三区蜜桃视频

在不同 webpack 版本的 Vue 項(xiàng)目中配置 Storybook

共 24564字,需瀏覽 50分鐘

 ·

2021-04-20 23:51

在之前的一篇文章中,介紹過組件化搭建工具 storybook 在 vue 項(xiàng)目中的安裝和配置。相比于其成文的時(shí)間,vue 項(xiàng)目依賴的工具多有發(fā)展;并且在實(shí)際應(yīng)用中,多種歷史版本的項(xiàng)目并存的狀況比比皆是,用官方提供的 npx sb init 往往會(huì)出現(xiàn)配置失敗的情況,而較新或過舊的資料都在網(wǎng)上難覓 --

所以在此特別補(bǔ)充一篇,記錄 新、舊 兩種典型配置下,storybook 可用的手動(dòng)配置方法:

1. babel7 + webpack5

1.1 安裝過程

diff --git a/.babelrc b/.babelrc
index e1f4817..71b5fe8 100644
--- a/.babelrc
+++ b/.babelrc
@@ -6,7 +6,8 @@
         "modules"false,
         "targets""last 2 years, ie > 8"
       }
-    ]
+    ],
+    "@vue/babel-preset-jsx"
   ],
   "plugins": [
     "@babel/plugin-transform-runtime",
diff --git a/.eslintignore b/.eslintignore
index e2192c5..0858135 100644
--- a/.eslintignore
+++ b/.eslintignore
@@ -2,4 +2,5 @@
+/test/*
+*.spec.js
diff --git a/.storybook/demo.css b/.storybook/demo.css
new file mode 100644
index 0000000..820f051
--- /dev/null
+++ b/.storybook/demo.css
@@ -0,0 +1,12 @@
+.demo {
+    padding: 50px;
+    display: inline-block;
+}
+.demo .block {
+    margin-bottom: 30px;
+}
diff --git a/.storybook/main.js b/.storybook/main.js
new file mode 100644
index 0000000..ceca416
--- /dev/null
+++ b/.storybook/main.js
@@ -0,0 +1,22 @@
+const path = require("path");
+const pathResolve = p => path.resolve(__dirname, "../", p);
+
+module.exports = {
+  stories: ["../src/**/*.stories.mdx""../src/**/*.stories.@(js|jsx|ts|tsx)"],
+  addons: ["@storybook/addon-links""@storybook/addon-essentials"],
+  core: {
+    builder: "webpack5"
+  },
+  webpackFinal: config => {
+    config.resolve.alias = {
+      ...config.resolve.alias,
+      "@": pathResolve("src"),
+      "~": pathResolve("node_modules")
+    };
+    config.module.rules.push({
+      test: /\.scss$/,
+      use: ["vue-style-loader""css-loader""sass-loader"]
+    });
+    return config;
+  }
+};
diff --git a/.storybook/manager-head.html b/.storybook/manager-head.html
new file mode 100644
index 0000000..c5c2955
--- /dev/null
+++ b/.storybook/manager-head.html
@@ -0,0 +1,14 @@
+<style>
+  .sidebar-header {
+    text-align: center;
+  }
+  .sidebar-header > div > a {
+    font-size: 28px;
+  }
+</style>
diff --git a/.storybook/manager.js b/.storybook/manager.js
new file mode 100644
index 0000000..c2321a4
--- /dev/null
+++ b/.storybook/manager.js
@@ -0,0 +1,10 @@
+import { addons } from "@storybook/addons";
+import { create } from "@storybook/theming";
+
+addons.setConfig({
+  theme: create({
+    base: "light",
+    brandImage: null,
+    brandTitle: "前端組件"
+  })
+});
diff --git a/.storybook/preview.js b/.storybook/preview.js
new file mode 100644
index 0000000..55d75d7
--- /dev/null
+++ b/.storybook/preview.js
@@ -0,0 +1,23 @@
+import "./demo.css";
+
+export const parameters = {
+    actions: { argTypesRegex: "^on[A-Z].*" },
+    controls: {
+        matchers: {
+            color: /(background|color)$/i,
+            date: /Date$/
+        }
+    },
+    // https://github.com/storybookjs/storybook/pull/9090/commits/2db3faa727fed585fb5d9e6db23cc3835fc88829
+    viewMode: "docs"
+};
diff --git a/package.json b/package.json
index 673f3a9..c0b7b27 100644
--- a/package.json
+++ b/package.json
@@ -1,19 +1,23 @@
+    "storybook""start-storybook -p 6006 --no-manager-cache",
+    "build-storybook""build-storybook"
   },
   "dependencies": {
+    "@babel/plugin-syntax-jsx""^7.12.13",
+    "@storybook/addon-actions""^6.2.7",
+    "@storybook/addon-essentials""^6.2.7",
+    "@storybook/addon-links""^6.2.7",
+    "@storybook/builder-webpack5""^6.2.7",
+    "@storybook/theming""^6.2.8",
+    "@storybook/vue""^6.2.7",
+    "@vue/babel-helper-vue-jsx-merge-props""^1.2.1",
+    "@vue/babel-preset-jsx""^1.2.4",
     "babel-plugin-transform-vue-jsx""~3.7.0",
diff --git a/src/utils/utils.js b/src/utils/utils.js
new file mode 100644
index 0000000..3e8413d
--- /dev/null
+++ b/src/utils/utils.js
@@ -0,0 +1,103 @@
+export const formatCode = jsCode =>
+    JSON.stringify(
+        jsCode,
+        // eslint-disable-next-line
+    (key, value) => {
+            if (typeof value === 'function') {
+                return value.toString();
+            } else {
+                return value;
+            }
+        },
+        2
+    ).replace(/\\n/g, '\n');
diff --git a/src/utils/storyUtils.js b/src/utils/storyUtils.js
new file mode 100644
index 0000000..4ad5149
--- /dev/null
+++ b/src/utils/storyUtils.js
@@ -0,0 +1,49 @@
+import {formatCode} from './utils';
+
+/**
+ * 生成 storybook 用例輔助函數(shù)
+ * @param {String} path - 組件的層級(jí)式路徑,由 `/` 分割
+ * @param {Object} storyComponent - 用于展示的用例
+ * @param {String} markdown - 文檔
+ * @param {Object} [originComponent] - 可選,如果需要從原始組件內(nèi)部的 jsdoc 自動(dòng)生成 API,則傳入原始組件
+ * @return {Object} story - {metadata, named}
+ * @see https://github.com/storybookjs/storybook/issues/8527
+ */
+export const storyOf = (path, storyComponent, markdown, originComponent) => {
+    const pathArr = path.split('/').map(p => {
+    // https://storybook.js.org/docs/vue/writing-stories/args#setting-args-through-the-url
+        if (!/^[0-9a-zA-Z]/.test(p)) {
+            return '#' + p;
+        }
+        return p;
+    });
+    const storyName = pathArr[pathArr.length - 1];
+
+    const metadata = {
+        component: originComponent || void 0,
+        title: pathArr.join('/'),
+        decorators: [
+            () => ({template: '<div class="demo"><story></story></div>'})
+        ]
+    };
+
+    const named = () => storyComponent;
+    named.storyName = storyName;
+    named.parameters = {
+        docs: {
+            description: {
+                component: markdown || '&nbsp;'
+            },
+            source: {
+                // type'dynamic'
+                type'code',
+                code: formatCode(storyComponent)
+            }
+        }
+    };
+
+    return {
+        metadata,
+        named
+    };
+};

1.2 組件和用例

用例1:

import { Meta, Preview, Description } from '@storybook/addon-docs/blocks'
import readme from './README.md'
import pathPrefix from './pathPrefix.js'

<Meta title={pathPrefix + "/API"} />

<Description markdown={readme} />

組件2:

<template functional>
<x-table
v-bind="{ ...data.attrs, ...props }"
v-on="listeners"
>
<!-- ... -->
</x-table>
</template>

<script>
export default {
props: {
/**
* 配置中增加了 __自定義 component__ 的能力,避免了在 template 中再分別寫 slot;
* 自定義組件對(duì)象會(huì)默認(rèn)接收 `row` 和 `column-config` 兩個(gè)屬性
*/
columns: {
type: Array,
default: () => []
}
},
emits: [
/**
* 自定義組件中如果發(fā)出同名事件,會(huì)被 table 的容器監(jiān)聽到;
* 參數(shù)為 `key, ...values`
*/
'column-action'
]
};
</script>

用例2:

import {storyOf} from '@/utils/storyUtils';
import Comp from '@/components/SimpleTable';

const title = 'Example/SimpleTable|全配置化表格';

const markdown = `
  > 基于 \`x-table\` 的擴(kuò)展,可以接收其原有屬性和事件
`
;

const comp = {
    template`
        <x-simple-table
            :width="600"
            :columns="columns"
            :data="list"
            @column-action="onColAction"
        />
    `
,
    data() {
        return {
            //...
        };
    },
    methods: {
        onColAction(act, value) {
            alert([act, value]);
        }
    }
};

const {metadata, named} = storyOf(title, comp, markdown, Comp);
export default metadata;
export const story = named;

2. babel6 + webpack4

2.1 安裝過程

diff --git a/.storybook/addons.js b/.storybook/addons.js
new file mode 100644
index 0000000..7106272
--- /dev/null
+++ b/.storybook/addons.js
@@ -0,0 +1,4 @@
+import 'storybook-addon-vue-info/lib/register';
+import '@storybook/addon-backgrounds/register';
+import '@storybook/addon-viewport/register';
+import '@storybook/addon-storysource/register';
diff --git a/.storybook/config.js b/.storybook/config.js
new file mode 100644
index 0000000..f84ef78
--- /dev/null
+++ b/.storybook/config.js
@@ -0,0 +1,34 @@
+import {configure, addDecorator, addParameters} from '@storybook/vue';
+import {create} from '@storybook/theming';
+import {withInfo, setDefaults} from 'storybook-addon-vue-info';
+import './demo.css';
+
+setDefaults({
+    header: false,
+    useDocgen: false
+});
+addDecorator(withInfo);
+addParameters({
+    options: {
+        theme: create({
+            base: 'light',
+            brandImage: null,
+            brandTitle: '前端組件'
+        })
+    }
+});
+const req = require.context('../src'true, /\.stories\.js$/);
+function loadStories() {
+    req.keys().forEach(filename => {
+        try {
+            req(filename);
+        } catch (ex) {
+            console.log('storybook-req', ex);
+        }
+    });
+}
+configure(loadStories, module);
diff --git a/.storybook/manager-head.html b/.storybook/manager-head.html
new file mode 100644
index 0000000..c5c2955
--- /dev/null
+++ b/.storybook/manager-head.html
@@ -0,0 +1,14 @@
+<style>
+  .sidebar-header {
+    text-align: center;
+  }
+  .sidebar-header > div > a {
+    font-size: 28px;
+  }
+</style>
diff --git a/.storybook/demo.css b/.storybook/demo.css
new file mode 100644
index 0000000..820f051
--- /dev/null
+++ b/.storybook/demo.css
@@ -0,0 +1,12 @@
+.demo {
+    padding: 50px;
+    display: inline-block;
+}
+
+.demo .block {
+    margin-bottom: 30px;
+}
diff --git a/.storybook/preview-head.html b/.storybook/preview-head.html
new file mode 100644
index 0000000..e69de29
diff --git a/.storybook/webpack.config.js b/.storybook/webpack.config.js
new file mode 100644
index 0000000..3186d15
--- /dev/null
+++ b/.storybook/webpack.config.js
@@ -0,0 +1,32 @@
+const path = require('path');
+const pathResolve = p => path.resolve(__dirname, '../', p);
+module.exports = ({config, mode}) => {
+    config.resolve.alias = {
+        ...config.resolve.alias,
+        '@': pathResolve('src'),
+        '~': pathResolve('node_modules')
+    };
+    config.module.rules.push({
+        test: /\.scss$/,
+        use: ['style-loader''css-loader''sass-loader']
+    });
+    config.module.rules.push({
+        test: /\.vue$/,
+        loader: 'storybook-addon-vue-info/loader',
+        enforce: 'post'
+    });
+    config.module.rules.push({
+        test: /\.stories\.js$/,
+        loaders: [require.resolve('@storybook/addon-storysource/loader')],
+        enforce: 'pre'
+    });
+    if (process.env.NODE_ENV === 'production') {
+        config.output.filename = 'bundle.[name].js';
+        config.optimization.splitChunks.automaticNameDelimiter = '.';
+        config.optimization.runtimeChunk = {
+            name: entrypoint => `runtime.${entrypoint.name}`
+        };
+    }
+    // console.log(config);
+    return config;
+};
diff --git a/package.json b/package.json
index d83bbba..6027c58 100644
--- a/package.json
+++ b/package.json
@@ -21,7 +21,9 @@
+        "build-storybook""build-storybook",
+        "storybook""start-storybook -p 6006"
     "devDependencies": {
+        "@storybook/addon-backgrounds""^5.3.18",
+        "@storybook/addon-info""^5.3.18",
+        "@storybook/addon-storysource""^5.3.18",
+        "@storybook/addon-viewport""^5.3.18",
+        "@storybook/addons""^5.3.18",
+        "@storybook/theming""^5.3.18",
+        "@storybook/vue""^5.3.18",
+        "storybook-addon-vue-info""^1.4.2",

2.2 用例

import {storiesOf} from '@storybook/vue';
import CustomCols from './index';

const totalColumns = [
    // ...
];

const description = {
    CustomCols: {
        props: {
            choose'用于 v-model 的值',
            totalColumns'可選擇的列',
            storageName'本地存儲(chǔ)的key',
        },
        events: {
            'on-change''選擇的列改變時(shí)觸發(fā)'
        }
    }
};

const info = {
    useDocgenfalse,
    summary'基于 xxx'
};

storiesOf('增強(qiáng)的自定義表格列'module)
    .add(
        '本機(jī)存儲(chǔ)上次選擇結(jié)果',
        () => ({
            components: {
                CustomCols
            },
            template`
            <div class="demo">
                    <div id="demo-result"></div>
                    <custom-cols
                        :storage-name="selColsStoName"
                        :total-columns="totalColumns"
                        v-model="selectedCols"
                        @on-change="onChange"
                    />
            </div>
            `
,
            data() {
                return {
                    totalColumns,
                    selColsStoName`${window.location.hostname}_overview_custom_cols`,
                    selectedCols: ['impression''click']
                };
            },
            methods: {
                onChange(v) {
                    //...
                }
            },
            description
        }),
        {
            info
        }
    );


--End--


查看更多前端好文
請(qǐng)搜索 云前端 或 fewelife 關(guān)注公眾號(hào)

轉(zhuǎn)載請(qǐng)注明出處


瀏覽 66
點(diǎn)贊
評(píng)論
收藏
分享

手機(jī)掃一掃分享

分享
舉報(bào)
評(píng)論
圖片
表情
推薦
點(diǎn)贊
評(píng)論
收藏
分享

手機(jī)掃一掃分享

分享
舉報(bào)

感谢您访问我们的网站,您可能还对以下资源感兴趣:

国产秋霞理论久久久电影-婷婷色九月综合激情丁香-欧美在线观看乱妇视频-精品国avA久久久久久久-国产乱码精品一区二区三区亚洲人-欧美熟妇一区二区三区蜜桃视频 北条麻妃高清无码| 国产欧美一区二区人妻喷水| 亚洲精品无码电影| 成人免费视频国产在线观看| 日韩做爱网站| 中文字幕永久在线视频v1.0| 一级A片免费看| 婷婷五月情| 国产伦子伦一级A片在线| 熟女人妻在线视频| 亚洲精品一区中文字幕乱码| 999精品视频| 农村乱子伦毛片国产乱| 探花无码| 女人18片毛片90分钟免费明星| 久久久久久一区| 91青青草| a视频在线免费观看| 牛牛影视av老牛影视av| 欧美啊啊啊| 午夜老司机福利一二三区| 一级a片在线免费观看| 成人黄色大片| 九九九色| 黄色成人网站在线| 日韩精品人妻中文字幕第4区| 蜜桃91在线观看| 在线A片免费观看| 中文字幕在线观看a| 91无码精品一区二区| 亚洲成人福利| 中文字幕高清无码视频| 欧美亚洲日韩在线观看| 亚洲3p| www.黄色在线| 五月天亭亭.com| 中文字幕综合网| 日日爱爱| 91人人妻人人澡人人爽人人| 亚洲逼逼| 自拍视频国产| 日韩欧美亚洲一区二区三区| 黄色草莓视频| 韩国一区二区三区在线观看| 成人av小说网站| 亚洲天堂一区| 欧美手机在线视频| 在线无码视频播放| 少妇高潮无码| 天天爱综合| 学生妹内射| 久操免费在线观看| 欧美精品国产动漫| 国产又大又粗又爽| 淫乱骚穴| 91水蜜桃| 无码成人片| 午夜成人在线观看| 中文字幕不卡在线| www.国产| 又大又粗又爽| 人妻AV无码| 无码一区视频| 一级a一级a免费观看免免黄‘/| 欧美日韩中文在线观看| 亚洲国产视频在线观看| 伊人成人视频在线观看| 黄色片免费看| 日韩国产在线观看| 毛片网站在线观看| 毛片二区| 加勒比精品| 国产黃色AAA片| 在线观看视频91| 成人在线免费网站| 国产91精品在线观看| 久久五月视频| 成人久久久久一级大黄毛片中国 | 最近中文字幕免费mv第一季歌词強上| 中国熟妇XXXX18| 性久久久久久久| 99久| 2019天天干| 国产精品久久久精品cos| 国产精品久久久久精| 熟女3P| 特级西西444WWW高清| 一区二区三区www污污污网站| 在线观看中文字幕一区| 青春草在线视频免费观看| 无码草| 国产在线观看黄| 操操操操一本到| 国产免费一区二区三区四区| 午夜操爽| 国产欧美视频在线| 伊人五月婷婷| 精品少妇3p| 一本一道久久a久久精品综合| 996热| 国产一级视频| 国产高清自拍| 搡BBB搡BBBB搡BBBB| 激情六月| 国产精品的电影| 91亚洲视频| 人妻无码| 东京热综合影院| 91麻豆大奶巨乳一区白虎| 中文字幕成人| 青草伊人网| 肉片无遮挡一区二区三区免费观看视频| 九七影院第二页| 欧美伊人| 蜜臀AV一区二区三区免费看| 中文无码精品欧美日韩| 成人免费内射视频| 操b视频免费看| 无码人妻精品一区二区50| 熟女啪啪| 97视频福利| 亚洲在线观看网站| 久久久老熟女一区二区三区91| 午夜无码久久| 久久动态图| 午夜福利无码电影| 亚洲欧洲精品视频| 人妻少妇精品无码| 天天干在线观看| 岛国无码av| 国产乱伦对白| 91免费成人| 国产黄色免费乱伦片| 欧美夜夜爽| 欧美一级婬片A片免费软件| 狼友视频在线播放| 四虎视频| 99热在线免费观看| 黄色A片约| a级黄色视频免费观看| 一级片黄色电影| 成人黄色一级| 国产一精品一aⅴ一免费| 91国内精品| 精品啪啪| 一区二区三区精品无码| 日本91| 中文字幕无码视频在线观看| 亚洲人在线| 另类图片亚洲色图| 搡BBB| 日本免费黄色视频| 欧美不卡在线视频| 91蜜臀在线| 中文一区在线观看| 成人免费乱码大片a毛片蜜芽| 国产又爽又黄免费网站在| 日韩偷拍网| 亚洲三级黄色| 岛国免费av| 青娱乐国产在线| 婷婷激情综合| 中国一级黄色A片| 女人久久久久| 久9久9久9久9久9久9| 日本中文字幕网| 成人毛片在线视频| 人人干干| 一道本一区| 国产综合激情| 乱码中文字幕日韩欧美在线| 黄色成人毛片| 久久国产精彩视频| 免费黄色视频网站在线观看| 亚洲A片V一区二区三区| 欧美成人网站在线| 日韩欧美色图| 亚洲色吧| 在线观看视频免费无码| av手机天堂网| 黄色a片视频| Japanese在线观看| 亚洲精品播放| 日韩一级二级| 午夜啪啪网站| 性爱A级视频| 秋霞福利影院| 色婷婷六月天| 久久国产劲爆∧v内射| 国产黄色免费看| 亚洲操逼无码| 久福利| 黄片日逼视频| 婷婷成人综合| 欧美精品一二三区| 成人A毛片| 中文字幕88页| 内射一区二区三区| 国产视频激情| 麻豆二区| 久久久黄色| 亚洲av性爱| 熟女视频网| 丁香激情五月少妇| 你懂的在线观看视频| 在线视频91| 国产精品HongKong麻豆| 三级成人av| 蜜桃亚洲AV无码一区二区三区| 亚洲69p| 人成在线免费视频| 无码秘蜜桃一区二区| 人妻北条麻妃在线| 国产精品久久毛片| 激情无码国产| 豆花成人社区,视频| 亚洲第一狼人综合网| 无码在线播| 七十路の高齢熟女千代子下载| 高潮国产视频| 男人的天堂在线视频| 婷婷手机在线| 亚洲精品成人网站| 久久久久久久久久国产| 毛片传媒| 欧美国产日韩欧美亚洲国产| 少妇搡BBBB搡BBB搡造水多,| 激情内射| 人妻丰满熟妇av无码| 牛牛AV在线| 天天综合天天做天天综合| 91精品婷婷国产综合久久竹菊| 亚洲国产精品成人va在线观看| 2021国产精品视频| 青青草原网站在线观看| 国产人人看| 操逼日爱| 国产欧美综合三级伦| 国产乱伦内射| 99热免费在线| 国产一区二区免费看| 亚洲天堂AV在线观看| 欧美精品日韩| 久久久国产精品视频| 狠狠狠久久久| 九九五月天| 国产精品主播| 青青青操| 日本一区二区视频在线观看| 色片无码| 黄色视频视频| 51色片| 国产乱码精品一品二品| 国产美女全裸网站| 超碰久草| 天天日天天干天天爽| 69av在线观看视频| 五月天激情影院| 欧美亚洲成人精品| 资源av| 99热热久久| 亚洲日韩在线播放| 黄色大片网址| 亚洲欧美成人电影| 日本色综合| 国产—级a毛—a毛免费视频| 伊人精品A片一区二区三区| 久久久久成人片免费观看蜜芽| 91无码视频在线观看| 黄色永久免费| 久久成人网站| 欧美一级黄色性爱视频| 天天日日日干| 亚洲av男人天堂| 免费操逼| 东京热视频网址| 熟女嗷嗷叫高潮合集91| 亚洲AV影院| 天天干婷婷五月天| 牛牛免费视频| 牛牛av| 91理伦| 亚欧成人| 久久香蕉人| 国产乱╳╳AⅤ毛片| 黄色影院在线观看| aa人人操夜夜操人人| 国产亚洲精品午夜福利巨大软件| 国产内射无码| 成人AV电影在线观看| 国产网友自拍| 国产高清一区二区| 中文字幕视频在线免费观看| 色天堂在线观看视频| 欧美三级在线视频| 免费黄色Av| 欧美成人三级精品| 一本在线| 91久久人澡人妻人人澡人人爽 | 国产熟女一区二区三区五月婷| 国产尤物| 一区二区三区无码在线观看| 成人性生活影视av| 日本中文字幕亚洲| 亚洲婷婷在线| 西西人体444www| 超碰2025| 男人天堂手机视频| 91久久久青青青青草| 久久久久久久免费视频| 六月丁香久久| 天堂a在线| 91热视频| 人人舔人人爱| 无码毛片一区二区三区人口| 亚洲av性爱| 亚洲无码免费播放| 18禁在线播放| 手机看片1024你懂的| A毛片| 久久精品视频久久| 69式荫蒂被添全过程| 自拍偷拍网站| 精品成人av| 搡BBBB| 在线观看视频免费无码| 国产成人免费视频在线| 日韩毛片在线| 豆花视频免费| 免费无码一区二区三区| 91香蕉国产成人App| 亚洲在线大香蕉| 国产精品123| 免费涩涩无遮挡18国产| 人人干人人摸人人操| 人人干AV| 豆花视频logo| 婷婷五月大香蕉| 污污污污污www网站免费观看| 免费黄色| 欧美少妇做爱| 蜜臀一区二区三区| 久久久久久久久久久久国产精品| 成人无码区免费| 国产一级性爱视频| 国产经典午夜福利视频合集| 曰本中文字幕在线视频| 在线观看www视频| 69超碰| 91高清无码视频| 成人福利网站| 久久高潮| 免费视频一二三区| 久久国产精品影院| 911精品国产一区二区在线| 久久精品禁一区二区三区四区五区 | 特级西西444WWW大精品视频| 欧美色色综合| 欧美一级特黄A片免费看视频小说 东北嫖老熟女一区二区视频网站 国产丨熟女丨国产熟女视频 | 高清无码在线看| 色中色av| 亚洲综合图区| 一级a一级a爰片免费免免中国A片| 日韩欧美午夜成人无码| 亚洲影院第一页| 91网在线| 久久久免费黄色视频| 人妻av中文字幕| 国产女人操逼视频| 日韩成人小说| 北条麻妃久久视频在线播放| 日韩欧美国产精品综合嫩V| 三级片国产| 国产成人大香蕉| 一区在线视频| 在线观看视频亚洲| 91在线观看| 激情五月婷婷色| 三级久久| 中文字幕手机在线视频| www天天操| 亚洲精品一二三| 国产欧美一区二区人妻喷水| 水蜜桃视频在线| 亭亭色| 青青草免费观看视频| 骚逼中文字幕| 欧美日韩国产精品成人| 18禁裸体美女| 精品资源成人| 国产欧美在线免费观看| 操片免费| 国产成人久久精品麻豆二区| 久久综合五月| 99久免费视频| 狠狠操av| 成人毛片av| 爽好紧别夹喷水无码| 二区三区免费| 91自摸| 亚州高清无码视频| 天堂v在线观看| 亚洲va视频| 亚洲aaaaaa| 波多野结衣亚洲无码| 99re99热| 99热最新网址| 肏屄视频网| 亚洲天堂视频在线观看| 日韩偷拍网| 亚洲东方在线| 狠狠草狠狠干| 免费人成视频观看| 江苏妇搡BBBB搡BBBB小说| 91丨PORN丨国产| 免费黄网站| 欧美自拍视频在线| 豆花网无码视频观看| 天天干人妻| 精品玖玖| 精品国产99| 无码视频在线免费播放| 国产又爽又黄免费观看视频| 久操网址| AV超碰| 玖玖国产| 欧美老女人性| 欧美操操操| 婷婷色在线观看| 黄色18禁| 国产VA| 婷婷五月天电影网| 日韩另类| 中文字幕一区二区二三区四区| 自拍偷拍一区二区三区| 黑人大香蕉| 在线播放91灌醉迷J高跟美女| 五月天婷婷激情| 亚洲成a| 中文字幕无码一区二区| 亚洲无aV在线中文字幕| 一区二区三区四区av| 一级片免费在线观看| 亚洲综合干| 国产在线观看黄| 天天做天天爱天天爽| 26uuu国产| 日本欧美操| 久久与婷婷| 国产一区在线观看视频| 午夜激情在线观看| 丁香五月婷婷久久| 亚洲成人人妻| 无码免费一区二区| 久久成人无码| 成人无码小电影| 一级黄色电影网| AV大片在线观看| 色青娱乐| 国产一级a一级a免费视频| 免费视频爱爱| 亚洲中文字幕在线观看| 91在线网址| 人妻18无码人伦一区二区三区精品 | 中文字幕视频在线播放| 污视频网站免费在线观看| 国产视频一区二区三区四区| 羞羞视频com.入口| 91豆花在线| 北条麻妃无码在线| 免费三级网| 日韩成人免费在线| mm131亚洲国产精品久久| 欧美精品第一页| 操b视频在线免费观看| 亚洲在线视频| 操逼a片| 日韩一区二区高清无码| 男女操逼视频网站免费观看| 蜜桃视频网站18| 国产高潮又爽又无遮挡又免费| 91无码成人视频| 人人澡人人添人人爽人人| 日韩专区中文字幕| 91大神免费在线观看| 日韩色网站| 青青久热| 无码人妻精品一区二区50| 欧美视频在线观看免费| 中文字幕35页| 国产a毛一级,a毛一级| 欧美操B视频| 北条麻妃无码一区二区| 97色色网站| 欧美洲成人网站| 亚洲AV无码成人精品区欧洲| 中字无码制服| 国产特黄级AAAAA片免| 东京热高清无码| 色婷婷六月天| 三级无码在线播放| 色吧综合网| 毛片视频免费观看| 精品一区二区三区免费| 艹逼逼视频| 国产无码高清| 一区二区三区精品视频| 69国产成人综合久久精品欧美| 夜夜嗨av无码一区二区三区 | 99在线免费视频| 日韩无码二区| 人人看人人摸人人草| 欧美大鸡吧视频| 无码内射视频| 青青草激情| 成人亚洲av| 亚洲另类av| 丁香婷婷色五月| 欧美丰满老熟妇XXXXX性| 亚洲最大网站| 福利黄色片:片| 在线免费看黄片| 男人天堂色男人| 影音先锋成人AV资源| 久热这里| 中文字幕在线观看第一页| 日韩精品成人在线| 久久人人超碰| 99re视频在线播放| 日韩无码人妻久久一区二区三区 | 18久久| 无码国产精品一区二区视频| 五月婷婷免费视频| 国产又黄又爽| 一道本无码在线| 四虎蜜桃| 欧美一区二区三区在线播放 | 五十路熟妇| aa人人操夜夜操人人| 欧美三级在线视频| 色五月av| 91A视频| 亚洲AV资源在线| 北条麻妃一区二区三区-免费免费高清观看 | 久热在线| 999国产精品| 日韩中文字幕在线人成网站| 91AV免费| 无码不卡视频在线观看| 国产精品久久久久毛片SUV| 国产三级午夜理伦三级| 亚洲精品久久久久毛片A级绿茶 | 国产三级视频在线| 国产又粗又长又硬又大毛苴茸图片 | 一级黄色视频免费观看| 日韩av成人| 亚洲AV无码第一区二区三区蜜桃 | 天天搞天天曰在线观看| 99色| 狠狠操狠狠操狠狠操| 国产成人av在线观看| 婷婷综合av| 精品人妻一区二区三区四区| 国产成人精品一区二区| 二区三区在线| 中文字幕成人A片| 中文字幕第一页av| 天堂在线观看AV| 白浆四溢av| 日韩天堂在线| 欧美黄色三级片| 丁香五月婷婷久久| 国产一级a免一级a免费| 天天综合网久久| 白虎高清无码大尺度免费在线观看| 婷婷五月天激情小说| 中文字幕在线日亚洲9| 黄片视频免费播放| 日本国产在线视频| 欧美日韩综合| 久久av综合| 水蜜桃在线视频| 加勒比色综合| 中文字幕777| 日韩一级片免费观看| 欧美激情一级| 少妇AAA级久久久无码精品片| 无套免费视频欧美| 欧美黄色小说| 成人A片在线观看| 亚洲五月丁香| 成人色色网站| 特黄AAAAAAAA片免费直播| 妞干网国产| 亚洲综合伊人无码| 色吧综合网| 天天综合视频| 亚洲中文无码字幕| 农村少妇久久久久久久| 亚洲黄色免费| 大香蕉在线啪啪| 走光无码一区二区三区| 日本精品在线观看视频| 国产精品毛片A√一区| 久操影视| 玉米地一级婬片A片| 亚洲三级片视频| 日韩成人一区二区| 九九九九国产| 国产videos| 欧美aaa在线| 中文字幕精品三区无码| 精品日韩在线视频| 亚洲精品成人av| 午夜乱伦| 中文字幕视频在线观看| 不卡二区| 国产成人精品一区二区三区| 亚洲制服在线观看| 欧美操人| 国产第8页| 日本黄色视频免费| 天天干91| 99热这里只有精品999| 亚洲va欧美ⅴa在线| 黄色爱爱| 成人免费视频性爱| 亲子乱婬一级A片| 蜜桃一区二区三区| 久久精品三级片| 国产伦乱| 亚洲精品成a人在线观看| 高清无码做爱视频| 安微妇搡BBBB搡BBBB| 天天躁夜夜躁狠狠躁AV| 婷婷婷色| 一区二区三区无码专区| 91天天操| 人人人射| 午夜性爱福利视频| 国产传媒av| 牛牛影视一区二区| 成人免费毛片果冻日本| 婷婷情色五月| 天堂A片电影网站在线观看| 成人喷水亚洲一区无码| 亚洲天堂在线免费观看| 18禁www| 日韩无码一级片| 亚洲有码在线观看| 亚洲AV无码电影| 国产成人精品电影| igao视频| 性满足BBWBBWBBW| 91精品免费视频| 黄色直播在线观看| 成人亚洲A片V一区二区三区蜜月 | 欧美亚洲综合在线观看| 99色播| a在线观看免费| 午夜成人亚洲| 日本50路熟女| 亚洲Japanese办公室制服| 国产精品一麻了麻了| 91视频在线| 成人免费观看的毛视频| 日韩大香蕉| 丁香六月婷婷久久综合| 午夜精品久久久久久久99老熟妇| 爽好紧别夹喷水欧美| 青草视频在线| www久久久| 性爱无码视频| 欧美怡春院| 亚洲色图狠狠撸| 免费射精一二三区| 黄色内射在线播放| 麻豆传媒在线观看| 欧美午夜精品| 黄片无码| 99成人| 德美日三级片在线观看| 国内成人精品网站| 亚洲综合一二三区| 成人手机AV| 亚洲欧美日韩性爱| 亚洲中文字幕播放| 天天色图片| 性欧美xxxx| 久久久久久久久久久久成人| 成人一级黄色电影| 在线观看AV资源| 欧美性猛交ⅩXXX乱大交| 国产自慰一区| 尤物视频在线观看视频| 国产精品日韩高清北条麻衣| 大香蕉国产在线视频| 青青草成人在线观看| 国产中文在线视频| 黄色电影a片| 国产v在线| 在线播放一区| 天天操一操| 99免费在线观看| 成人在线一区二区| 亚洲午夜AV久久乱码| 亚洲成人在线视频| 欧美综合高清| 青青草人人| 欧美成人一区二区三区片| 骚骚网站| 一道本无码视频| 久久五月亭亭| 欧性猛交ⅩXXX乱大交| 亚洲无码AV片| 在线无码不卡| 无码av免费精品一区二区三区| 亚洲网站视频| 亚洲视频免费完整版在线播放| 自拍AV在线| 免费看黄色大片| 亚洲综合激情五月久久| 综合色国产精品欧美在线观看 | 超碰97人人爱| 亚韩av| 97亚洲综合| 18岁成人毛片| 亚洲无码制服| 伊人久久久| 国产黄色免费看| 国产嫩草久久久一二三久久免费观看| 毛片天堂| 国产一级AA片| 麻豆国产91| 免费内射网站| 国产精品三级视频| 日本a片在线观看| 嘿嘿午夜| 国产成人精品一区二区| 91麻豆大奶巨乳一区白虎| 亚洲AV无码一区二区三区少妇| 韩国三级无码| 精品视频免费在线观看| 精品成人影视| 欧美A片在线| 91九色91蝌蚪91窝成人 | 99青草在线视频| av天堂手机网| 亚洲小骚逼| 成人免费A片在线观看直播96| 亚洲a√| 男人AV在线| 久久中文视频| 国产九色91回来了| 成人福利小视频| 中文无码高清在线| 在线观看操逼| 四虎成人无码A片观看| 国产精品福利小视频| 国产精品无码白浆高潮| 亚洲天堂偷拍| 久久毛久久久j| 亚洲欧洲久久| 国产精品国产三级囯产普通话2| 成人午夜精品无码区| 色五月av| 欧美一级婬片免费视频黄| 乱伦五月天| 日本高清视频www| 色噜噜狠狠一区二区三区300部| 狠狠躁日日躁夜夜躁A片男男视频 精品无码一区二区三区蜜桃李宗瑞 | 精品无码在线观看视频| 国产AV电影网| 蜜桃传媒视频| 精品人妻| 婷婷五月天激情四射| 无套影院| 亚洲无码A区| 五月丁香欧美综合| 视频一区18| 欧美性猛交XXXX乱大交蜜桃| 国产精品久久777777| 国产精品可站18| 欧美日韩国产成人在线观看| 风流老熟女一区二区三区| 丰满岳乱妇一区二区三区全文阅读| ThePorn人妻白浆| 国产精品123区| 五月婷婷免费视频| 成人自拍电影| 俺来也俺去也www色官网| 激情国产在线| 成人免费在线视频| 中国黄色一级A片| 成av人片一区二区三区久久| 人人爽久久涩噜噜噜网站| 欧美夜夜爽| 亚洲av网站| 大香蕉在线视频观看| 香蕉综合在线| 北条麻妃在线一区| av无码网站| 97人妻精品黄网站| www九九| 成人AV一区二区三区| 无码成人av| 成人亚洲| 视频一区二区免费| 中文字幕无码观看| 国产精品午夜福利视频| 91在线无码精品秘入口| 欧美色视频在线观| 亚洲区在线播放| 成人无码免费看| 久久久成人视频| 北条麻妃无码在线| 国产在线你懂得| 日韩美女免费视频| 日韩成人A片| www.久草| 怡红院麻豆| 爱爱免费看片| 婷婷色在线视频| 一区二区三区无码视频| 中文在线а√天堂8| 亚洲精品一区二区三区无码电影 | 东方成人AV| 尤物综合网| 翔田千里无码A片| 91丨PORNY丨丰满人妻网站| 91人妻无码一区二区三区| 欧美视频综合网| 国产嫩草视频| 亚洲中文字幕一| 国产一级18片视频| 五月亭亭在线视频| 毛片资源| 91精品网站| 国产欧美综合在线三区| 国产一级黄色大片| aⅴ无码| 欧美激情一区二区三区| 欧美成人一区二区三区片| 久草欧美| 久草手机视频| 99在线视频观看| 西西人体444www| 特级西西444www大精品| 国产日韩精品无码去免费专区国产| 国产无遮挡又黄又爽在线观看| 国产高潮又爽又无遮挡又免费| 国产成人无码在线| 亚洲九九九| 蜜桃精品一区二区| 色婷婷成人| 久久精品欧美| 日韩在线视频二区| 久久无码一区二区| www.51av| 四虎在线观看视频| 99久re热视频精品98| 99re在线观看视频| 三级片在线看片AV| 中国一级片| 国产精品无码天天爽视频| 丁香花在线小说免费全文| 精品无人区无码乱码毛片国产| 日韩av在线电影| 殴美老妇BBBBBBBBB| 欧美天天性| 四个熟妇搡BBBB搡BBBB| 一区二区三区亚洲| 91久久久久久久91| 北京熟妇搡BBBB搡BBBB| 人人摸人人艹| 性欧美一区二区| 亚洲视频在线免费看| 亚洲精品成人电影| 亚洲欧美日韩无码| 日韩十八禁网站| 亚洲欧洲视频| 婷婷五月18永久免费视频| 一级爱爱爱| 精品中文字幕在线观看| 先锋久久资源| 中文字幕国产AV| 安徽妇搡BBBB搡BBBB按摩小说| 啪啪成人视频| 热久在线| 亚洲色图偷拍| 亚洲国产精品尤物yw在线观看 | 婷婷99狠狠躁天天躁| 日韩性爱视频在线播放| 先锋影音资源AV| 亚洲无码影音先锋| 人人爱人人操人人爽| 亚洲www在线| 亚洲无码偷拍| 日日骚影院| 精品免费国产一区二区三区四区|