欧美亚洲韩国_av电影院在线看_久久久久97_台湾佬中文娱乐网欧美电影

站長資訊網
最全最豐富的資訊網站

聊聊vue3中echarts用什么形式封裝最好?(代碼詳解)

項目中經常用到echarts,不做封裝直接拿來使用也行,但不可避免要寫很多重復的配置代碼,封裝稍不注意又會過度封裝,丟失了擴展性和可讀性。始終沒有找到一個好的實踐,偶然看到一篇文章,給了靈感。找到了一個目前認為用起來很舒服的封裝。

思路

  1. 結合項目需求,針對不同類型的圖表,配置基礎的默認通用配置,例如x/y,label,圖例等的樣式
  2. 創建圖表組件實例(不要使用id,容易重復,還需要操作dom,直接用ref獲取當前組件的el來創建圖表),提供type(圖表類型),和options(圖表配置)兩個必要屬性
  3. 根據傳入type,加載默認的圖表配置
  4. 深度監聽傳入的options,變化時更新覆蓋默認配置,更新圖表
  5. 提供事件支持,支持echart事件按需綁定交互

注意要確保所有傳入圖表組件的options數組都是shallowReactive類型,避免數組量過大,深度響應式導致性能問題

目錄結構

├─v-charts │  │  index.ts     // 導出類型定義以及圖表組件方便使用 │  │  type.d.ts    // 各種圖表的類型定義 │  │  useCharts.ts // 圖表hooks │  │  v-charts.vue // echarts圖表組件 │  │ │  └─options // 圖表配置文件 │          bar.ts │          gauge.ts │          pie.ts
登錄后復制


組件代碼

v-charts.vue

<template>   <div ref="chartRef" /> </template> <script setup> import { PropType } from "vue"; import * as echarts from "echarts/core"; import { useCharts, ChartType, ChartsEvents } from "./useCharts";  /**  * echarts事件類型  * 截至目前,vue3類型聲明參數必須是以下內容之一,暫不支持外部引入類型參數  * 1. 類型字面量  * 2. 在同一文件中的接口或類型字面量的引用  * // 文檔中有說明:https://cn.vuejs.org/api/sfc-script-setup.html#typescript-only-features  */ interface EventEmitsType {   <T extends ChartsEvents.EventType>(e: `${T}`, event: ChartsEvents.Events[Uncapitalize<T>]): void; }  defineOptions({   name: "VCharts" });  const props = defineProps({   type: {     type: String as PropType<ChartType>,     default: "bar"   },   options: {     type: Object as PropType<echarts.EChartsCoreOption>,     default: () => ({})   } });  // 定義事件,提供ts支持,在組件使用時可獲得友好提示 defineEmits<EventEmitsType>();  const { type, options } = toRefs(props); const chartRef = shallowRef(); const { charts, setOptions, initChart } = useCharts({ type, el: chartRef });  onMounted(async () => {   await initChart();   setOptions(options.value); }); watch(   options,   () => {     setOptions(options.value);   },   {     deep: true   } ); defineExpose({   $charts: charts }); </script> <style scoped> .v-charts {   width: 100%;   height: 100%;   min-height: 200px; } </style>
登錄后復制

useCharts.ts

import { ChartType } from "./type"; import * as echarts from "echarts/core"; import { ShallowRef, Ref } from "vue";  import {   TitleComponent,   LegendComponent,   TooltipComponent,   GridComponent,   DatasetComponent,   TransformComponent } from "echarts/components";  import { BarChart, LineChart, PieChart, GaugeChart } from "echarts/charts";  import { LabelLayout, UniversalTransition } from "echarts/features"; import { CanvasRenderer } from "echarts/renderers";  const optionsModules = import.meta.glob<{ default: echarts.EChartsCoreOption }>("./options/**.ts");  interface ChartHookOption {   type?: Ref<ChartType>;   el: ShallowRef<HTMLElement>; }  /**  *  視口變化時echart圖表自適應調整  */ class ChartsResize {   #charts = new Set<echarts.ECharts>(); // 緩存已經創建的圖表實例   #timeId = null;   constructor() {     window.addEventListener("resize", this.handleResize.bind(this)); // 視口變化時調整圖表   }   getCharts() {     return [...this.#charts];   }   handleResize() {     clearTimeout(this.#timeId);     this.#timeId = setTimeout(() => {       this.#charts.forEach(chart => {         chart.resize();       });     }, 500);   }   add(chart: echarts.ECharts) {     this.#charts.add(chart);   }   remove(chart: echarts.ECharts) {     this.#charts.delete(chart);   }   removeListener() {     window.removeEventListener("resize", this.handleResize);   } }  export const chartsResize = new ChartsResize();  export const useCharts = ({ type, el }: ChartHookOption) => {   echarts.use([     BarChart,     LineChart,     BarChart,     PieChart,     GaugeChart,     TitleComponent,     LegendComponent,     TooltipComponent,     GridComponent,     DatasetComponent,     TransformComponent,     LabelLayout,     UniversalTransition,     CanvasRenderer   ]);   const charts = shallowRef<echarts.ECharts>();   let options!: echarts.EChartsCoreOption;   const getOptions = async () => {     const moduleKey = `./options/${type.value}.ts`;     const { default: defaultOption } = await optionsModules[moduleKey]();     return defaultOption;   };    const setOptions = (opt: echarts.EChartsCoreOption) => {     charts.value.setOption(opt);   };   const initChart = async () => {     charts.value = echarts.init(el.value);     options = await getOptions();     charts.value.setOption(options);     chartsResize.add(charts.value); // 將圖表實例添加到緩存中     initEvent(); // 添加事件支持   };    /**    * 初始化事件,按需綁定事件    */   const attrs = useAttrs();   const initEvent = () => {     Object.keys(attrs).forEach(attrKey => {       if (/^on/.test(attrKey)) {         const cb = attrs[attrKey];         attrKey = attrKey.replace(/^on(Chart)?/, "");         attrKey = `${attrKey[0]}${attrKey.substring(1)}`;         typeof cb === "function" && charts.value?.on(attrKey, cb as () => void);       }     });   };    onBeforeUnmount(() => {     chartsResize.remove(charts.value); // 移除緩存   });    return {     charts,     setOptions,     initChart,     initEvent   }; };  export const chartsOptions = <T extends echarts.EChartsCoreOption>(option: T) => shallowReactive<T>(option);  export * from "./type.d";
登錄后復制

type.d.ts

/*  * @Description:  * @Version: 2.0  * @Autor: GC  * @Date: 2022-03-02 10:21:33  * @LastEditors: GC  * @LastEditTime: 2022-06-02 17:45:48  */ // import * as echarts from 'echarts/core'; import * as echarts from 'echarts' import { XAXisComponentOption, YAXisComponentOption } from 'echarts';  import { ECElementEvent, SelectChangedPayload, HighlightPayload,  } from 'echarts/types/src/util/types'  import {   TitleComponentOption,   TooltipComponentOption,   GridComponentOption,   DatasetComponentOption,   AriaComponentOption,   AxisPointerComponentOption,   LegendComponentOption, } from 'echarts/components';// 組件 import {   // 系列類型的定義后綴都為 SeriesOption   BarSeriesOption,   LineSeriesOption,   PieSeriesOption,   FunnelSeriesOption,   GaugeSeriesOption } from 'echarts/charts';  type Options = LineECOption | BarECOption | PieECOption | FunnelOption  type BaseOptionType = XAXisComponentOption | YAXisComponentOption | TitleComponentOption | TooltipComponentOption | LegendComponentOption | GridComponentOption  type BaseOption = echarts.ComposeOption<BaseOptionType>  type LineECOption = echarts.ComposeOption<LineSeriesOption | BaseOptionType>  type BarECOption = echarts.ComposeOption<BarSeriesOption | BaseOptionType>  type PieECOption = echarts.ComposeOption<PieSeriesOption | BaseOptionType>  type FunnelOption = echarts.ComposeOption<FunnelSeriesOption | BaseOptionType>  type GaugeECOption = echarts.ComposeOption<GaugeSeriesOption | GridComponentOption>  type EChartsOption = echarts.EChartsOption;  type ChartType = 'bar' | 'line' | 'pie' | 'gauge'  // echarts事件 namespace ChartsEvents {   // 鼠標事件類型   type MouseEventType = 'click' | 'dblclick' | 'mousedown' | 'mousemove' | 'mouseup' | 'mouseover' | 'mouseout' | 'globalout' | 'contextmenu' // 鼠標事件類型   type MouseEvents = {     [key in Exclude<MouseEventType,'globalout'|'contextmenu'> as `chart${Capitalize<key>}`] :ECElementEvent   }   // 其他的事件類型極參數   interface Events extends MouseEvents {     globalout:ECElementEvent,     contextmenu:ECElementEvent,     selectchanged: SelectChangedPayload;     highlight: HighlightPayload;     legendselected: { // 圖例選中后的事件       type: 'legendselected',       // 選中的圖例名稱       name: string       // 所有圖例的選中狀態表       selected: {         [name: string]: boolean       }     };     // ... 其他類型的事件在這里定義   }     // echarts所有的事件類型   type EventType = keyof Events }  export {   BaseOption,   ChartType,   LineECOption,   BarECOption,   Options,   PieECOption,   FunnelOption,   GaugeECOption,   EChartsOption,   ChartsEvents }
登錄后復制

options/bar.ts

import { BarECOption } from "../type"; const options: BarECOption = {   legend: {},   tooltip: {},   xAxis: {     type: "category",     axisLine: {       lineStyle: {         // type: "dashed",         color: "#C8D0D7"       }     },     axisTick: {       show: false     },     axisLabel: {       color: "#7D8292"     }   },   yAxis: {     type: "value",     alignTicks: true,     splitLine: {       show: true,       lineStyle: {         color: "#C8D0D7",         type: "dashed"       }     },     axisLine: {       lineStyle: {         color: "#7D8292"       }     }   },   grid: {     left: 60,     bottom: "8%",     top: "20%"   },   series: [     {       type: "bar",       barWidth: 20,       itemStyle: {         color: {           type: "linear",           x: 0,           x2: 0,           y: 0,           y2: 1,           colorStops: [             {               offset: 0,               color: "#62A5FF" // 0% 處的顏色             },             {               offset: 1,               color: "#3365FF" // 100% 處的顏色             }           ]         }       }       // label: {       //   show: true,       //   position: "top"       // }     }   ] }; export default options;
登錄后復制

項目中使用

index.vue

<template>   <div>     <section>       <div class="device-statistics chart-box">         <div>累計設備接入統計</div>         <v-charts           type="bar"           :options="statisDeviceByUserObjectOpts"           @selectchanged="selectchanged"           @chart-click="handleChartClick"         />       </div>       <div class="coordinate-statistics chart-box">         <div>坐標數據接入統計</div>         <v-charts type="bar" :options="statisCoordAccess" />       </div>     </section>   </div> </template> <script setup> import {   useStatisDeviceByUserObject, } from "./hooks"; // 設備分類統計 const { options: statisDeviceByUserObjectOpts,selectchanged,handleChartClick } = useStatisDeviceByUserObject(); </script>
登錄后復制

/hooks/useStatisDeviceByUserObject.ts

export const useStatisDeviceByUserObject = () => {   // 使用chartsOptions確保所有傳入v-charts組件的options數據都是## shallowReactive淺層作用形式,避免大量數據導致性能問題   const options = chartsOptions<BarECOption>({     yAxis: {},     xAxis: {},     series: []   });   const init = async () => {     const xData = [];     const sData = [];     const dicts = useHashMapDics<["dev_user_object"]>(["dev_user_object"]);     const data = await statisDeviceByUserObject();     dicts.dictionaryMap.dev_user_object.forEach(({ label, value }) => {       if (value === "6") return; // 排除其他       xData.push(label);       const temp = data.find(({ name }) => name === value);       sData.push(temp?.qty || 0);              // 給options賦值時要注意options是淺層響應式       options.xAxis = { data: xData };        options.series = [{ ...options.series[0], data: sData }];     });   };      // 事件   const selectchanged = (params: ChartsEvents.Events["selectchanged"]) => {     console.log(params, "選中圖例了");   };    const handleChartClick = (params: ChartsEvents.Events["chartClick"]) => {     console.log(params, "點擊了圖表");   };      onMounted(() => {     init();   });   return {     options,     selectchanged,     handleChartClick   }; };
登錄后復制

使用時輸入@可以看到組件支持的所有事件:

聊聊vue3中echarts用什么形式封裝最好?(代碼詳解)

  • 推薦學習:《vue.js視頻教程》

贊(0)
分享到: 更多 (0)
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
主站蜘蛛池模板: 色就是欧美 | 99久久亚洲精品 | 久久精品首页 | 免费黄av | 在线毛片片免费观看 | 天堂在线免费观看视频 | 精品久久不卡 | 怡红院av久久久久久久 | 久久久久色 | 6—12呦国产精品 | 99re热这里只有精品视频 | 动漫av一区 | 久久人人爽人人爽人人片966 | 免费看一级黄色大片 | 成人网一区 | 久久久精品国产sm调教网站 | 成人夜色| 精品久久久久久久久久久久久久久 | 少妇又色又紧又黄又刺激免费 | 欧美图片一区二区三区 | 日本少妇喂奶 | 又爽av | 婷婷开心激情网 | 黄av在线| 99久久99久久精品国产片果冻 | 成人午夜小视频 | 91久久精品日日躁夜夜躁国产 | 成人av日韩| 91激情捆绑调教喷水 | 91av精品| 美色视频 | 日日操夜夜操天天操 | 亚洲精品国产精品乱码不97 | 久久婷婷国产综合尤物精品 | 超碰在线资源 | 久久爱伊人 | 久久精品二区 | 欧美7777 | 久久亚洲综合 | 久久精品久久精品久久 | 欧美一级日韩一级 | 国产午夜免费视频 | 欧美日韩国产区 | 午夜a区 | 亚洲精品在线网站 | 黄色喷水视频 | 日韩蜜桃视频 | 正在播放亚洲精品 | 在线观看欧美成人 | 一级理论片 | 免费麻豆国产一区二区三区四区 | 777色| av在线片| 红桃成人网 | 中国av片 | 天堂激情网 | 91精品久久久久久粉嫩 | 日韩在线视频播放 | 女18毛片 | 日韩精品一二三四区 | 精品乱子伦一区二区 | 日韩精品一区二区在线 | 老汉av在线 | 日韩免费大片 | 日韩精品一区二区三区四区五区 | 日本少妇吞精囗交 | 朝桐光一区二区三区 | 成人永久免费 | 黄瓜视频在线免费看 | 国产一级中文字幕 | a在线播放 | 神马香蕉久久 | 黄色片视频免费 | 一区二区三区免费观看 | 久久一区二| 九九福利视频 | av日韩免费| 亚洲天堂毛片 | 四虎网站最新网址 | 怡春院国产| 自拍一区在线观看 | 伊人网伊人网 | 欧美日韩国产二区 | 日本成人免费视频 | 毛片视频免费 | 国产一区二区三区影视 | 久久久国产成人 | 日本精品一二三区 | 免费的性爱视频 | 中文字幕一区在线播放 | 久久精品欧美 | 成人午夜性视频 | 一级片久久久久久久 | 免费在线观看的黄色网址 | 欧美人性生活视频 | 69福利视频 | 日本精品久久久久久久 | 精品国产91久久 | 日韩av一区二区在线观看 | 国产日韩欧美亚洲 | 欧美激情精品久久久久久 | 亚洲综合大片 | 激情综合五月网 | 在线成人免费视频 | av日韩一区 | 亚洲天堂精品久久 | 污污视频免费观看 | 久久综合88 | 亚洲综合清纯唯美 | 国产依人在线 | 欧美大片免费高清观看 | 亚洲精品久久久久久下一站 | 德国性经典xxxx性hd | 成人毛片18女人毛片 | 午夜| 韩日av| 一本色道综合久久欧美日韩精品 | 日韩专区在线观看 | av色国产 | 91麻豆产精品久久久久久夏晴子 | 91视频影院 | 欧美亚洲天堂网 | 公与妇乱理三级xxx 中文字幕一区二区三区四区欧美 | 韩国三级中文字幕hd久久精品 | 亚洲综合视频图片 | 国产操比视频 | 日韩久久久久久久久 | 手机在线免费看av | 亚洲爽爽爽 | 国产天堂在线观看 | 99re热视频 | 亚洲乱码av | 四虎影院在线免费播放 | 天天操夜夜操视频 | 香蕉视频色版 | 97国产| xxxx日本高清| 国产成人免费在线视频 | 国产精品12 | a天堂视频| 中文在线永久免费观看 | 欧美黄色大全 | 日韩专区中文字幕 | 久久午夜神器 | 中文字幕一区在线播放 | 91精品久 | 欧美精品大片 | 欧美色啪 | 免费成人结看片 | 美女av网站| 黄色在线观看免费视频 | 在线播放免费av | 亚洲欧美另类视频 | 精品久久久久久一区二区里番 | 国产精品毛片一区视频播 | 午夜小视频免费在线观看 | 亚洲一区图片 | 奇米成人网| 清纯唯美亚洲综合 | 在线观看1区 | h网站在线观看 | 国产精品久久久久久模特 | 日本欧美一级 | 福利一区二区视频 | 婷婷久久五月 | 欧美亚洲精品在线 | 国产精品美女久久久久高潮 | av色片 | 奇米影视在线播放 | 四虎永久免费在线观看 | 久久久久亚洲精品 | 日本三级韩国三级三级a级中文 | 96精品| 国产精品海角社区 | 谁有毛片网址 | 欧美网站在线 | 亚洲精品国产一区二区三区四区在线 | 国产亚洲在线 | 综合在线观看 | 欧美 日韩 国产在线 | 天天摸天天干 | www视频在线观看网站 | 久久香蕉av | 激情五月婷婷在线 | 久久99网| 中文字幕你懂的 | 91网站在线免费看 | 婷婷综合社区 | 国产91久久婷婷一区二区 | 国产女18毛片多18精品 | 国产福利二区 | 久久精选 | 色成人免费网站 | 五月婷婷激情在线 | 一区二区三区四区中文字幕 | 成人免费观看视频 | 91五月天 | 亚洲欧洲色 | www四虎 | 九色91 | 日韩欧美视频一区二区三区 | 日韩三级在线 | 夜夜偷影视| 开心激情网站 | 草草视频在线观看 | 伊人免费在线观看 | 亚洲免费激情 | 精品国产乱码久久久久久蜜臀网站 | 91国偷自产一区二区开放时间 | 国产污污视频 | 超碰在线人人干 | 久久国产欧美日韩精品 | 国产综合视频在线 | 日本黄色片免费 | 日本成人久久 | 日韩成人一级片 | 久久久午夜影院 | 天堂资源最新在线 | 一本大道香蕉在线播放 | 在线观看污视频网站 | 91性高潮久久久久久久久 | 干爹你真棒插曲免费 | 国产精品自拍99 | 成人免费高清 | 一本色道久久88综合日韩精品 | 一级片黄色| 欧美色就是色 | 国产美女无遮挡永久免费 | 伊人网久久久 | va在线观看 | 嫩草影院污 | 色播五月激情 | 麻豆婷婷| 欧美性俱乐部 | 欧美片17c07.com | 亚洲精品国产精品国自产在线 | 国产综合精品视频 | 中文av在线播放 | 国产高潮流白浆喷水视频 | 男人激情网 | 自拍偷拍色综合 | 一级片手机在线观看 | 在线高清观看免费 | 久久精品久久久久久久 | 亚洲女人天堂 | 一区二区三区视频免费在线观看 | 91麻豆精品91久久久久同性 | 亚洲精品爱爱 | 91自啪| 国产视频你懂的 | 亚洲女人网 | 色九月婷婷 | 亚洲精品国产精品国自产网站按摩 | 在线观看国产区 | 4438x在线观看 | 蜜臀99久久精品久久久久久软件 | 啪啪av| 99成人精品 | 日日夜夜免费精品视频 | 五月婷婷俺也去 | 成年人午夜影院 | 亚洲蜜桃视频 | 91丝袜一区在线观看 | 成人私密视频 | 香蕉黄视频 | 欧美第九页 | 亚洲黄色在线播放 | 午夜精品久久久久久久久久久久久 | 永久免费看片女女 | 成人欧美一区二区 | 中文字幕一区二区三 | 成人性视频sm. | 色屁屁草草影院ccyycom | 国产成人手机在线 | 韩国av免费观看 | 欧美一区,二区 | 欧美三级一区 | 男人的网站在线观看 | 成人免费在线观看网站 | 亚洲综合1区 | 国产精品国产三级国产专播i12 | 亚洲不卡视频在线观看 | 亚洲国产日韩在线观看 | 一级特黄录像免费看 | 三级小视频在线观看 | 国产 中文 字幕 日韩 在线 | 亚洲色网址 | 国产精品日日摸天天碰 | 污片在线观看 | 毛片3| 亚洲国产综合av | 国产视频福利在线 | 中文字幕专区 | 9l视频自拍九色9l视频成人 | 黄瓜视频在线免费看 | 久操福利视频 | 亚洲成人播放 | 国产性一乱一性一伧一色 | 一级做a爰片毛片 | 午夜偷拍视频 | 中文字幕成人在线 | 特级黄色录像 | 蜜桃久久久aaaa成人网一区 | 中文在线a√在线8 | 欧美精品在线观看 | h视频在线看 | 日日夜夜网站 | 欧美视频精品 | 久久久精品999 | 日韩激情一区 | 韩国激情av | 久久久国产免费 | 性较小国产交xxxxx视频 | 在哪里看毛片 | 中文字幕无线码一区 | 国产亚洲精品久久久 | 在线91av | fc2成人免费视频 | 国产精品久久久久影院色老大 | 在线观看欧美精品 | 亚洲精品aaaa | 亚洲欧美色图片 | 久久综合国产 | 国产三级在线播放 | 欧美福利影院 | 国产奶水涨喷在线播放 | 日韩福利一区二区 | 国产激情精品 | 日韩中文在线播放 | 精品国产一级片 | 成年人在线视频 | 999久久精品 | 成人福利院 | 免费在线观看日韩av | 日韩三级在线观看 | 欧美极品在线观看 | 色综合天天综合网天天狠天天 | 二级毛片视频 | 青娱乐极品在线 | 欧美三级a做爰在线观看 | 香蕉亚洲| 国产a精品| 在线一区 | 亚洲一区网 | 91麻豆产精品久久久久久 | 色综合区 | 黄色一二三区 | 天堂在线观看视频 | 制服丝袜一区二区三区 | 91桃色视频| 超碰这里只有精品 | 国产91精品久久久久久久网曝门 | 午夜剧场成人 | 久久国产免费看 | 国产欧美日韩免费看aⅴ视频 | 丁香色网| av高清一区二区 | 综合激情久久 | 午夜影院男女 | 成人免费网站www网站高清 | 亚洲伊人av| 日本黄色大片免费 | 国产成人免费av | 在线精品亚洲欧美日韩国产 | 六月婷婷综合网 | 国产一级特黄aaa大片 | 婷婷射 | 国产精品推荐 | 韩国性猛交╳xxx乱大交 | 91一区二区视频 | 91精品婷婷国产综合久久蝌蚪 | 天天操天天干天天操 | 天天澡天天狠天天天做 | 超碰这里只有精品 | 夜夜天天操 | 亚洲国产精品久久久久婷婷老年 | 香蕉色视频| 国产亚洲精品美女久久久 | 国产视频二区 | 国产精品久久久久国产a级 欧美成人猛片aaaaaaa | 亚洲第一在线播放 | 国产wwww| 毛片毛片毛片毛片毛片毛片毛片 | 欧美另类老妇 | 国产精品欧美在线 | 超碰人人插| 五月天av网| 色四月 | 日韩一级在线 | 久久久久久久一区二区三区 | 天天干天天插 | 黄色视屏在线看 | 蜜桃麻豆视频 | 一级全黄裸体免费观看视频 | 日韩欧美黄色片 | 夜夜春夜夜爽 | 天天干,夜夜操 | 亚洲视频播放 | 91插插插影库永久免费 | 射久久 | 欧美精品在线视频观看 | 国产精品久久久久免费 | 一区二区网站 | 狼人av在线 | 日本毛片网站 | 久久aaa| 99爱视频在线观看 | 欧美成人一级视频 | 91在线观看 | 欧美激情视频在线 | 非洲黑寡妇性猛交视频 | 久久伊人一区二区 | 亚洲午夜精品久久久久久浪潮 | 免费在线一区二区三区 | 美女av网址 | 加勒比视频在线免费观看 | 欧美一区网站 | 日日夜夜精品免费视频 | 自拍偷拍精品 | 欧美日韩一区二区三区不卡视频 | 国产色| 日本中文字幕不卡 | 国产51视频| 亚洲欧美另类在线视频 | 91国偷自产一区二区三区亲奶 | 国产色综合天天综合网 | 色无极亚洲| 国产日韩欧美精品 | 深夜av在线| 亚洲天天干 | 伊人蕉久 | 久久久午夜 | 荡女精品导航 | 色四月婷婷 | 制服丝袜第一页在线观看 | 91丨九色丨黑人外教 | 久久影视一区二区 | 免费黄色av网站 | 国产毛片基地 | 国产新婚疯狂做爰视频 | 欧美日视频 | 国产精品成人一区二区 | 欧美偷拍一区二区 | 懂色tv | 超碰com| 亚洲欧美日韩一区 | 国产调教打屁股xxxx网站 | 五月天中文字幕mv在线 | 性视频黄色| 影音先锋毛片 | 奇米影视狠狠干 | 草久视频在线观看 | 久久久久久久国产精品 | 久久久水蜜桃 | 一区二区我不卡 | 蜜桃色一区二区三区 | 欧洲女同同性吃奶 | 国产乱人视频 | 精品蜜桃一区二区三区 | 欧美亚洲国产视频 | 中文字幕精品一区二区精品 | 亚洲再线 | 国产高潮在线观看 | 国产伦精品一区二区三区免费 | 国产对白国语对白 | 综合av| 夜夜天堂| 国产精品高潮呻吟久久av黑人 | 婷婷综合| 色婷婷香蕉在线一区二区 | 日韩黄色在线 | 综合婷婷久久 | 69精品人人| 亚洲五月婷 | 亚洲操操操 | 黄色工厂这里只有精品 | 99国产成人综合久久精品欧美 | 国产极品免费 | 国产免费片 | 国产噜噜噜噜噜久久久久久久久 | 在线免费观看不卡av | 97福利社 | 亚洲免费公开视频 | 亚洲第一成年人网站 | av中文天堂 | 欧洲综合视频 | 麻豆视频一区二区 | 国产任你操| 免费高清视频在线观看 | 欧美日韩一二三区 | 欧美三区四区 | 国产高清在线不卡 | 亚洲图片 激情小说 | 亚洲小视频在线观看 | 97人人人 | 午夜在线视频免费 | 一本一道久久久a久久久精品91 | 国产精品美女一区二区 | 日韩福利片在线观看 | 久久88| 波多野吉衣一区二区 | 成人毛片在线免费观看 | 天天插日日干 | 国产精品视频大全 | 伊人福利| 国产夜夜夜 | 神马久久av | av老司机在线 | 久久夜视频| 亚洲午夜精品一区二区 | 亚洲国产精品综合 | 国产女同91疯狂高潮互磨 | 日日夜夜亚洲 | 久久婷婷色 | 中文字幕视频二区 | 国产精品v欧美精品v日韩 | 在线h网| 日本99视频 | 国产a级大片 | 中文字幕在线2019 | 内地毛片 | а天堂中文在线官网 | 午夜精品福利一区二区 | 欧美自拍区 | 天天操夜夜撸 | 精品爱爱视频 | 欧美一区二区三区激情啪啪 | 亚洲欧美在线不卡 | 超碰在线影院 | 免费污片在线观看 | 在线观看免费高清在线观看 | 亚洲视频在线观看免费视频 | 国产老女人乱淫免费 | 成人交性视频免费看 | 九色精品 | 国产精品视频久久久久久久 | 欧美性大战xxxxx久久久 | 在线观看日韩免费视频 | 欧美影院一区二区三区 | 一区二区三区日韩精品 | 91亚洲国产成人精品一区 | 性生活免费大片 | 97人人模人人爽人人喊网 | 99国产精品久久久久久久日本竹 | av基地 | 日韩成人免费av | 亚洲女同av| www在线视频| 欧美日韩一区二区在线播放 | 特一级黄色片 | 热久久国产精品 | 一级黄色短片 | 天天躁日日躁狠狠躁 | 色黄啪啪网 | 欧美亚韩一区二区三区 | 永久免费看成人av的动态图 | 五月婷婷深深爱 | 亚洲日批视频 | 综合激情综合 | 亚洲国产第一 | 日韩亚洲国产欧美 | 一区二区三区四区中文字幕 | 日韩欧美国产成人 | 国产在线精品成人欧美 | 欧美激情视频一区 | 少妇又色又紧又黄又刺激免费 | 伊人色播 | 亚洲精品www久久久久久广东 | 亚洲人a| 久草一区 | 成人激情四射网 | 精品国产乱码久久久久久影片 | 伊人婷婷久久 | 人与动物毛片 | 性欧美一区 | 久久天天躁狠狠躁夜夜97 | 日本黄色一级 | 国产一级做a爱片久久毛片a | 日韩在线欧美在线 | 夜夜操狠狠操 | 日韩二三区 | 91国在线视频 | 97香蕉视频| 亚洲免费在线 | 日本在线观看网站 | 天天操天天操天天操天天操 | 少妇高潮一区二区三区99小说 | 日韩不卡高清 | 黄色在线免费网站 | 日韩久久久久 | 在线免费看a | 久久精品视频久久 | 国产一区视频观看 | 欧美福利一区二区 | 亚洲我射av| a亚洲精品| 成人免费在线播放视频 | 国产精品久久久网站 | 尤物视频在线免费观看 | 久久99久久99精品免观看粉嫩 | 成人av资源| 四虎com| 在线不卡毛片 | 91操操操 | av狠狠干 | 久久久免费精品视频 | 成年人看的视频网站 | 国产欧美精品一区二区色综合朱莉 | 国产裸体永久免费视频网站 | www亚洲天堂 | 亚洲精品乱码久久久久久蜜桃欧美 | av一区免费| 国产中文字幕在线播放 | 国产白袜脚足j棉袜在线观看 | 日本一区二区三区久久 | av男人的天堂网 | 91九色蝌蚪91por成人 | 日韩成人一级片 | 高潮毛片又色又爽免费 | 一级特黄a | 制服丝袜第一页在线观看 | 欧美天堂 | 精品久久网站 | 亚洲国产97在线精品一区 | 日韩精品一区二区视频 | 久久香蕉av | 欧美一级大片免费看 | 99久久国| 亚洲第一视频在线观看 | 2024国产精品 | 98国产精品综合一区二区三区 | 男人av的天堂 | 在线观看日韩av | 动漫精品一区一码二码三码四码 | 欧美三级久久 | 91传媒视频在线观看 | 色综合五月天 | 国产人久久人人人人爽 | 欧美青青草| 毛片毛片毛片毛片毛片毛片毛片 | 最新日韩中文字幕 | 精品在线视频观看 | 国产午夜在线播放 | 国产三级午夜理伦三级 | 深夜网站在线观看 | 成年人爱爱视频 | 1024亚洲天堂| 欧美日韩精品在线播放 | 一二三区视频在线 | 亚洲视频中文字幕 | 蜜臀av性久久久久蜜臀aⅴ四虎 | av免费观看久久 | 午夜资源| 韩国精品久久久 | 亚洲成av人片在线观看天堂无码 | 尹人综合在线 | 日韩久久久 | 九色视频偷拍少妇的秘密 | 精品国产一区二区三区性色av | 最近日韩中文字幕中文 | 免费黄色av| 深夜国产福利 | 国产手机看片 | 中文在线精品 | 亚洲午夜视频在线观看 | 懂色av一区二区三区免费观看 | 伊人网狠狠干 | 久久免费久久 | 欧美一级淫片007 | 亚洲国产精品婷婷 | 91亚洲精 | 麻豆视频在线观看免费网站黄 | 精品久久久久成人码免费动漫 | 免费在线观看av | 亚洲欧美日韩成人 | 中文字幕成人网 | 98av视频| 欧美成人小视频 | 一女三黑人理论片在线 | 久久网页 | 99国产成人综合久久精品欧美 | 精品久久久久一区二区国产 | 九九综合九九综合 | 日本人xxxⅹ18hd19hd | 久久综合在线 | 国语对白91 | 青青草公开视频 | 久久99婷婷国产精品免费 | 五月色综合 | 欧美精品一区二区视频 | 国产精品久久人 | 国产16处破外女视频在线 | 日韩精品字幕 | 最新99热 | 色很久 | 呦呦色| 男女免费视频网站 | 射黄视频 | 国产精品有码 | 91视频国内| 午夜av免费在线观看 | 精品美女久久久 | 欧美精品国产精品 | 欧美狠狠干 | 青青草97国产精品免费观看 | 国产盗摄xxxx视频xxxx | 国产香蕉久久精品综合网 | h视频在线免费观看 | 欧美一区日韩一区 | 国产情侣自拍小视频 | 亚洲草草网| a天堂在线观看视频 | 在线免费看污视频 | 在线看黄色网址 | 婷婷激情四射 | 久久一区二区三区视频 | 日韩欧美一区二区三区视频 | 91精品久久久久久久99蜜桃 | 日韩黄色av| 亚洲精品视频在线 | 97人人插 | 日韩精品中文字幕在线观看 | 久久中文字幕在线观看 | 噜噜色av | 亚洲黄色在线看 | 亚洲成人看片 | 老司机午夜剧场 | 日本一区二区精品视频 | 久久成人精品视频 | 性高湖久久久久久久久 | 欧洲国产精品 | 极品尤物在线观看 | 黄色1级毛片 | 国产一区二区三区成人 | a国产一区二区免费入口 | 午夜少妇福利 | 欧美人一级淫片a免费播放 www.日韩高清 | 国产欧美视频在线 | 日韩亚洲欧美在线观看 | 91av中文字幕 | 乱淫av| 亚洲少妇一区二区 | 精品国产一区二区三区av 性色 | 国产真实乱人偷精品视频 | 69性影院| 亚洲射图| 国语对白真实视频播放 | 快射天堂网 | 成人av综合 | 97福利影院| 一区二区三区视频观看 | 日韩精品一二 | 天堂a视频| 免费一级a毛片夜夜看 | 成人亚洲网 | 久热国产视频 | 久久精品欧美一区二区 | 久久精品大片 | 夜色视频在线观看 | 可以免费看的毛片 | 久久精品一区二区三区四区 | 亚洲日b视频 | 国产福利av在线 | 人人爽夜夜爽 | 人人爱人人艹 | 亚洲午夜久久久久久久国产 | 国产91精品久久久久久久网曝门 | 国产欧美久久久久久 | 岛国精品资源网站 | 一区二区三区视频免费看 | 久草国产在线视频 | 国产成人久久精品激情 | 日韩黄色一级片 | 国产在线视频网 | 久久精品国产77777蜜臀 | 亚洲永久精品国产 | 视频一区在线播放 | 亚洲青涩在线 | 黄色片视频免费在线观看 | 姝姝窝人体www聚色窝 | 久操精品在线 | 韩国三级做爰高潮 | 国产精品密蕾丝袜 | 国产高清成人久久 | 插综合| 九九热国产精品视频 | 亚洲一区二区二区久久成人婷婷 | 香蕉久久夜色精品国产使用方法 | 黄色一级片免费看 | 亚洲视频大全 | 久热精品视频 | 午夜欧美精品 | 一级亚洲片 | 一区二区三区在线观看av | 狠狠躁天天躁夜夜添人人 | 国产乱码在线 | 国内特级毛片 | 色婷婷精品国产一区二区三区 | 免费观看黄色av | 91网页在线观看 | 天天爽夜夜爽夜夜爽精品视频 | 欧美日韩国产一级 | 国产精品一二三四区 | 久久久精品毛片 | 2018中文字幕在线观看 | 午夜日韩视频 | 含羞草一区二区 | 亚洲福利视频导航 | 国产亚洲精品码 | 天堂色区 | 亚洲狼人精品一区二区三区 | 动漫av在线 | 4438x在线观看 | 国产精品图片 | 欧美日本在线播放 | www.天天干| 麻豆视频一区二区 | 免费国产精品视频 | 歪歪视频在线观看 | 天天拍天天射 | 在线91播放 | 日韩成人在线看 | 一色屋精品久久久久久久久久 | 91免费观看网站 | 久久综合欧美 | 亚洲伊人影院 | 免费毛片在线 | h视频在线观看网站 | 久久中文免费 | 免费视频网站在线观看入口 | 欧美在线观看免费高清 | 亚洲乱搞 | 成年人拍拍视频 | 日本男女啪啪 | 在线播放精品 | 黄色一级免费看 | 最近中文在线观看 | av资源吧首页 | 99视频在线免费观看 | 欧美成人精品欧美一级乱黄 | 亚洲黄色小说网址 | 欧亚一区二区 | 国产午夜在线视频 | 欧美日韩免费观看一区=区三区 | 最近中文字幕在线观看 | 无法忍受在线观看 | 亚洲伦理久久 | 欧美一级日韩一级 | 成人综合区 | 99精品视频在线 | 亚洲一区第一页 | 日韩乱码一区二区三区 | 国产成人在线影院 | 亚洲精品乱 | 亚洲激情免费 | 欧美一区二区高清 | 老司机午夜影院 | 国产精品久久久一区二区 | 成人免费公开视频 | 在线播放亚洲 | www天堂网 | 鲁一鲁av | 亚洲乱码一区av黑人高潮 | 图片区亚洲 | 狠狠老司机 | 国产性hd | 真实国产乱啪福利露脸 | 99re热这里只有精品视频 | 国产盗摄精品一区二区酒店 | 麻豆精品一区 | 国产精品久久9 | 毛片网站在线观看 | 久久久88 | 老司机在线看片 | 亚洲精品嫩草 | 超碰1000| 亚洲丝袜av | 中文字幕久久久久久久 | 片多多在线观看 | 欧美日本激情 | 在线免费观看a视频 | 天堂在线视频免费 | 欧美精品色呦呦 | 欧美超碰在线观看 | 亚洲午夜久久久久久久久红桃 | 欧美永久免费 | www.中文字幕在线观看 | 国产区福利 | 视频一区二区三区四区五区 | 高级家教课程在线观看 | 亚洲精品国产免费 | 51成人精品网站 | 精品欧美色视频网站在线观看 | av不卡影院| 久久久视频在线 | 国产成人精品网站 | 久久久久久久久久久久一区二区 | 日韩在观看线 | 天堂素人| 日韩小视频在线观看 | 俄罗斯女人裸体性做爰 | 夜夜撸 | 欧美第一页在线 | 国产精品久久久久久免费 | 成人免费视频一区 | 亚洲狼人精品一区二区三区 | 亚洲精品国产福利 | 日本免费黄色网址 | 天堂久久久久久 | 香蕉免费在线视频 | 99精品欧美一区二区三区综合在线 | 欧美一级黄色片 | 久久99综合| 日韩av网站在线观看 | 亚洲精品综合一区二区 | 色婷婷久久一区二区三区麻豆 | 国产免费一区二区三区四区五区 | 天天操网 | 国产亚洲欧美在线精品 | 国产精选在线观看 | 成人视屏在线观看 | 美女视频一区 | 久99精品 | 日本不卡二区 | 黄色大片免费观看 | 久草视频福利在线 | 久久久黄色 | 男女插插网站 | 日本欧美激情 | 日本一区二区三区四区视频 | 99r在线视频 | ,亚洲人成毛片在线播放 | 欧美精品一二三四区 | 特黄特色大片免费播放器使用方法 | 国产成人精品久久 | 亚洲射情| 最好看十大无码av | 丝袜一区二区三区 | 影音先锋91 | 免费网站www在线观看 | 久久久国产精品入口麻豆 | 久久黄色大片 | 国产真实乱偷精品视频 | 成年人高清视频 | 国产精品一区二 | 蜜桃精品在线 | 成人免费毛片入口 | 亚洲制服丝袜在线播放 | 最近中文字幕在线视频 | 亚洲女同一区二区 | 天天射天天爽 | 小说区图片区亚洲 | 国产不卡一区 | 操操网站| 久久中文字幕一区 | 欧美日韩亚| 视频一区亚洲 | 日韩成人在线免费视频 | 欧美高清v | 91香蕉在线看 | 一本色道久久综合亚洲精品小说 | 高h喷汁呻吟3p | 91在线观看网站 | 秋霞av影院 | 久久激情综合 | h狠狠躁死你h高h | 国产精品99久久久久久人 | 午夜有码 | 色天堂在线视频 | 性大片潘金莲裸体 | 青青国产在线视频 | 国产一区二区三区久久 | 一区二三区 | 日韩在线观看不卡 | 一区二区三区四区不卡 | 亚洲国产理论 | 亚洲精品97 | 国产女同视频 | 综合视频 | 午夜影院在线观看 | 麻豆精品国产传媒mv男同 | 色图av | 欧美另类天堂 | 在线爱情大片免费观看大全 | 男人的天堂久久 | 中文字幕在线视频观看 | 20日本xxxxxxxxx46 亚洲欧洲在线播放 | 在线看你懂 | 可以看av的网址 | 亚洲第一页在线 | 一级中国毛片 | 亚洲偷怕 | 日韩中文字幕一区二区三区 | 欧美日本一区二区三区 | 最近中文字幕大全2019 | 99久久久久久久久久久 | 日韩成人中文字幕 | 日日操天天操 | 久久夜色精品亚洲 |