日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

【xlsx-chart】Vue项目中导出Excel表格并带上图表

發布時間:2023/12/20 vue 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【xlsx-chart】Vue项目中导出Excel表格并带上图表 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Vue項目中導出Excel表格并帶上圖表

1.需求場景:

我們在開發過程中會遇到一些需求就是將表格中的數據導出到excel文件中并下載至本地,但目前基本上下載的excel文件只有簡單的表格數據,沒有相關的圖表(如餅圖,柱狀圖等),當我們excel文件中帶上了這些圖表,可以幫助用戶更加簡潔明了地看到數據間的關系;

2.使用工具:

xslx-chart插件,由于xslx-chart是一個node環境下的一個插件所以我們可以使用兩種方法來使用它,下文就如何使用xslx-cahrt進行介紹(著重介紹方法二)

3.開始使用:

方法一:基于node環境使用xslx-chart工具;
注意:由于xslx-chart是在nodejs環境下運行的,所以我們要在項目本地跑一個node服務來使用xslx-cahrt,
思路:
1.我們在運行項目的同時,在本地跑一個nodejs服務(xlsx-chart-serve),在該nodejs服務中處理表格的操作,處理完之后再將文件發送到前端,前端再進行文件下載;

如圖:我們跑項目時直接執行

npm run dev

就會同時執行serve和xlsx;xlsx作用就是將導出表格的服務跑起來;
注意:
同時執行多個指令需要concurrently這個工具,使用 && 連接兩個指令是串行的,會中斷執行命令
2.我們服務跑起來之后,前端需要導出表格時,將數據發送給nodejs服務,交由xlsx這個服務處理,處理完之后將文件發給前端
注意:
由于node服務和我們項目自身的端口不一致,所以會導致跨域的問題,這個需要注意

方法二(推薦):基于xlsx-chart進行二次開發,直接在前端中使用
思路:
我們看xlsx-chart工具的源碼不難發現,它生成的圖表是在本地讀取模板文件然后再拿最新的數據去替換模板表格中的數據生成的新表格和新圖表,它在node環境中使用的是fs工具讀取文件,那我們可以在前端使用axios請求本地文件,只要讀取文件內容和類型一致就可以了
重點: axios請求中響應數據類型需要配置;將responseType設置為’arraybuffer’


然后生成的最新文件使用file-saver下載下來即可

修改后的源碼文件如下:

第一步:準備源碼:
base.js

var _ = require("underscore"); var Backbone = require("backbone"); var JSZip = require("jszip"); var xml2js = require("xml2js"); var VError = require("verror"); var axios = require('axios'); // var fs = require ("fs"); var async = require("async"); var Chart = Backbone.Model.extend({/*Read XML file from xlsx as object*/read: function (opts, cb) {var me = this;var t = me.zip.file(opts.file).asText();var parser = new xml2js.Parser({ explicitArray: false });parser.parseString(t, function (err, o) {if (err) {return new VError(err, "getXML");}cb(err, o);});},/*Build XML from object and write to zip*/write: function (opts) {var me = this;var builder = new xml2js.Builder();var xml = builder.buildObject(opts.object);me.zip.file(opts.file, new Buffer(xml), { base64: true });},/*Get column name*/getColName: function (n) {var abc = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";n--;if (n < 26) {return abc[n];} else {return abc[(n / 26 - 1) | 0] + abc[n % 26];}},/*Get shared string index*/getStr: function (s) {var me = this;if (!me.str.hasOwnProperty(s)) {throw new VError("getStr: Unknown string: " + s);}return me.str[s];},/*Write table*/writeTable: function (cb) {var me = this;me.read({ file: "xl/worksheets/sheet2.xml" }, function (err, o) {if (err) {return cb(new VError(err, "writeTable"));}o.worksheet.dimension.$.ref = "A1:" + me.getColName(me.titles.length + 1) + (me.fields.length + 1);var rows = [{$: {r: 1,spans: "1:" + (me.titles.length + 1)},c: _.map(me.titles, function (t, x) {return {$: {r: me.getColName(x + 2) + 1,t: "s"},v: me.getStr(t)}})}];_.each(me.fields, function (f, y) {var r = {$: {r: y + 2,spans: "1:" + (me.titles.length + 1)}};var c = [{$: {r: "A" + (y + 2),t: "s"},v: me.getStr(f)}];_.each(me.titles, function (t, x) {c.push({$: {r: me.getColName(x + 2) + (y + 2)},v: me.data[t][f]});});r.c = c;rows.push(r);});// table的數據o.worksheet.sheetData.row = rows;console.log('o',o,rows)me.write({ file: "xl/worksheets/sheet2.xml", object: o });cb();});},/*Write strings*/writeStrings: function (cb) {var me = this;me.read({ file: "xl/sharedStrings.xml" }, function (err, o) {if (err) {return cb(new VError(err, "writeStrings"));}o.sst.$.count = me.titles.length + me.fields.length;o.sst.$.uniqueCount = o.sst.$.count;var si = [];_.each(me.titles, function (t) {si.push({ t: t });});_.each(me.fields, function (t) {si.push({ t: t });});me.str = {};_.each(si, function (o, i) {me.str[o.t] = i;});o.sst.si = si;me.write({ file: "xl/sharedStrings.xml", object: o });cb();});},/*Remove unused charts*/removeUnusedCharts: function (o) {var me = this;if (me.tplName != "charts") {return;};var axId = [];function addId (o) {_.each(o["c:axId"], function (o) {axId.push(o.$.val);});};_.each(["line", "radar", "area", "scatter", "pie"], function (chart) {if (!me.charts[chart]) {delete o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:" + chart + "Chart"];} else {addId(o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:" + chart + "Chart"]);};});if (!me.charts["column"] && !me.charts["bar"]) {delete o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"];} elseif (me.charts["column"] && !me.charts["bar"]) {o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"] = o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"][0];addId(o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"]);} elseif (!me.charts["column"] && me.charts["bar"]) {o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"] = o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"][1];addId(o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"]);} else {addId(o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"][0]);addId(o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"][1]);};var catAx = [];_.each(o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:catAx"], function (o) {if (axId.indexOf(o["c:axId"].$.val) > -1) {catAx.push(o);};});o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:catAx"] = catAx;var valAx = [];_.each(o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:valAx"], function (o) {if (axId.indexOf(o["c:axId"].$.val) > -1) {valAx.push(o);};});o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:valAx"] = valAx;},/*Write chart*/writeChart: function (cb) {var me = this;var chart;me.read({ file: "xl/charts/chart1.xml" }, function (err, o) {if (err) {return cb(new VError(err, "writeChart"));}var ser = {};_.each(me.titles, function (t, i) {var chart = me.data[t].chart || me.chart;var r = {"c:idx": {$: {val: i}},"c:order": {$: {val: i}},"c:tx": {"c:strRef": {"c:f": "Table!$" + me.getColName(i + 2) + "$1","c:strCache": {"c:ptCount": {$: {val: 1}},"c:pt": {$: {idx: 0},"c:v": t}}}},"c:cat": {"c:strRef": {"c:f": "Table!$A$2:$A$" + (me.fields.length + 1),"c:strCache": {"c:ptCount": {$: {val: me.fields.length}},"c:pt": _.map(me.fields, function (f, j) {return {$: {idx: j},"c:v": f};})}}},"c:val": {"c:numRef": {"c:f": "Table!$" + me.getColName(i + 2) + "$2:$" + me.getColName(i + 2) + "$" + (me.fields.length + 1),"c:numCache": {"c:formatCode": "General","c:ptCount": {$: {val: me.fields.length}},"c:pt": _.map(me.fields, function (f, j) {return {$: {idx: j},"c:v": me.data[t][f]};})}}}};if (chart == "scatter") {r["c:xVal"] = r["c:cat"];delete r["c:cat"];r["c:yVal"] = r["c:val"];delete r["c:val"];r["c:spPr"] = {"a:ln": {$: {w: 28575},"a:noFill": ""}};};ser[chart] = ser[chart] || [];ser[chart].push(r);});/*var tag = chart == "column" ? "bar" : chart;o ["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"][0]["c:ser"] = ser;*/_.each(ser, function (ser, chart) {if (chart == "column") {if (me.tplName == "charts") {o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"][0]["c:ser"] = ser;} else {o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"]["c:ser"] = ser;};} elseif (chart == "bar") {if (me.tplName == "charts") {o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"][1]["c:ser"] = ser;} else {o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"]["c:ser"] = ser;};} else {o["c:chartSpace"]["c:chart"]["c:plotArea"]["c:" + chart + "Chart"]["c:ser"] = ser;};});me.removeUnusedCharts(o);/*if (me.showVal) {o ["c:chartSpace"]["c:chart"]["c:plotArea"]["c:" + tag + "Chart"]["c:dLbls"]["c:showVal"] = {$: {val: "1"}};};*/if (me.chartTitle) {me.writeTitle(o, me.chartTitle);};/*o ["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"] = o ["c:chartSpace"]["c:chart"]["c:plotArea"]["c:barChart"][0];o ["c:chartSpace"]["c:chart"]["c:plotArea"]["c:catAx"] = o ["c:chartSpace"]["c:chart"]["c:plotArea"]["c:catAx"][0];o ["c:chartSpace"]["c:chart"]["c:plotArea"]["c:valAx"] = o ["c:chartSpace"]["c:chart"]["c:plotArea"]["c:valAx"][0];delete o ["c:chartSpace"]["c:chart"]["c:plotArea"]["c:lineChart"];delete o ["c:chartSpace"]["c:chart"]["c:plotArea"]["c:areaChart"];*/// me.write({ file: "xl/worksheets/sheet2.xml/", object: o });me.write({ file: "xl/charts/chart1.xml", object: o });cb();});},/*Chart title*/writeTitle: function (chart, title) {var me = this;chart["c:chartSpace"]["c:chart"]["c:title"] = {"c:tx": {"c:rich": {"a:bodyPr": {},"a:lstStyle": {},"a:p": {"a:pPr": {"a:defRPr": {}},"a:r": {"a:rPr": {$: {lang: "ru-RU"}},"a:t": title}}}},"c:layout": {},"c:overlay": {$: {val: "0"}}};chart["c:chartSpace"]["c:chart"]["c:autoTitleDeleted"] = {$: {val: "0"}};},/*Set template name*/setTemplateName: function () {var me = this;var charts = {};_.each(me.data, function (o) {charts[o.chart || me.chart] = true;});me.charts = charts;if (charts["radar"]) {me.tplName = "radar";return;};if (charts["scatter"]) {me.tplName = "scatter";return;};if (charts["pie"]) {me.tplName = "pie";return;};if (_.keys(charts).length == 1) {me.tplName = _.keys(charts)[0];return;};me.tplName = "charts";},/*Generate XLSX with chartchart: column, bar, line, radar, area, scatter, pietitles: []fields: []data: {title: {field: value, ...}, ...}*/generate: function (opts, cb) {var me = this;opts.type = opts.type || "nodebuffer";_.extend(me, opts);async.series([function (cb) {me.zip = new JSZip();me.setTemplateName();let path = me.templatePath ? me.templatePath : (__dirname + "template/" + me.tplName + ".xlsx");console.log("path:", path);axios({url: path, //your urlmethod: 'GET',responseType: 'arraybuffer', // important}).then((response) => {console.log('response',response)me.zip.load(response.data);cb();});//也可以使用fetch代替axios //window.fetch(path).then((response) => {// response.arrayBuffer().then(function (buffer) {// // do something with buffer// console.log('response.arraybuffer()', buffer)// me.zip.load(buffer);// cb();// })//});// fs.readFile(path, function (err, data) {// if (err) {// console.error(`Template ${path} not read: ${err}`);// return cb (err);// };// me.zip.load (data);// cb ();// });// fs.readFile(path, function (err, data) {// if (err) {// console.error(`Template ${path} not read: ${err}`);// return cb (err);// };// me.zip.load (data);// cb ();// });},function (cb) {me.writeStrings(cb);},function (cb) {_.each(me.titles, function (t) {me.data[t] = me.data[t] || {};_.each(me.fields, function (f) {me.data[t][f] = me.data[t][f] || 0;});});me.writeTable(cb);},function (cb) {me.writeChart(cb);}], function (err) {if (err) {return cb(new VError(err, "build"));}var result = me.zip.generate({ type: me.type });cb(null, result);});} }); module.exports = Chart;

注意事項:
由于我們發送axios請求修改了responseType:‘arraybuffer’,所以我們需要保證此項配置成功,如果項目中使用了mock并引用了就要注意了,因為mock會將全局的axios的responseType設置為 ’ ';導致我們發請求無法獲取excel的模板文件內容,所以我們需要保證項目中沒有使用mock
第二步:準備模板文件
我們將所有的模板文件都放到項目中的public目錄下即可通過axios直接請求到了(模板文件可以在先安裝xlsx-chart,然后在node_modules中里面拿出來,然后把xlsx-chart卸載掉) ;模板我們只需要基礎的即可(columnAvg.xlsx,columnGroup.xlsx,columnGroupAvg.xlsx用不上)

第三步:在vue中使用
xxx.vue文件

<template><div id="app"><img alt="Vue logo" src="./assets/logo.png" /><br /><button @click="getChartExcel" style="margin: 0 auto">導出帶圖標的excel表格</button></div> </template><script> // xlsx-chart修改后的源碼文件 import XLSXChart from "./utils/base"; import FileSaver from "file-saver";export default {name: "App",methods: {getChartExcel () {let xlsxChart = new XLSXChart();let opts = {chart: "bar",titles: ["Price"],fields: ["Apple", "Blackberry", "Strawberry", "Cowberry", "jasonchen"],data: {Price: {Apple: 10,Blackberry: 5,Strawberry: 15,Cowberry: 20,jasonchen: 2000},},chartTitle: "Area chart",};xlsxChart.generate(opts, function (err, data) {if (err) {console.error(err);} else {let blob = new Blob([data]);FileSaver.saveAs(blob, "chart.xlsx");}});}}, };</script><style> #app {font-family: Avenir, Helvetica, Arial, sans-serif;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;text-align: center;color: #2c3e50;margin-top: 60px; } </style>

第四步:最終效果

第五步: 進階使用:
思路:我們使用過后不難了解到,xlsx-chart這個工具的實現思路就是在需要導出excel時,通過讀取本地的excel模板文件,然后使用我們想要展示的數據去替換模板中表格的數據,最終達到圖表生成的效果;但是我們能不能在已有模板的基礎上多加幾個圖表呢,答案是可以的而且非常簡單
1.我們打開其中一個模板文件column.xlsx;選中我們想要生成圖表的列(第一列必選),注意要選中全列

2.生成圖表

3.重復上述操作生成多個圖表后,把這些生成的圖表剪切到Chart的sheet中,并保存

4.再次導出表格(使用保存后的模板)

文章項目源碼地址:
https://github.com/Jason-chen-coder/Xlsx-EasyExportExcelWithChars
寫在最后:

1.以上就是基于xlsx-chart開發excel導出表格數據帶圖表的功能,及簡單的拓展,如果你有更好的思路可以直接修改base.js的源碼和修改excel模板的圖表樣式甚至往模板中新增excel相關的更多功能等等;
2.文檔中的項目鏈接:https://github.com/Jason-chen-coder/exportExcelForChart
3.xlsx-chart非常強大,我只是基于他base的源碼修改了一下,大佬們可以修改他完整版的源碼來開發更多的功能

總結

以上是生活随笔為你收集整理的【xlsx-chart】Vue项目中导出Excel表格并带上图表的全部內容,希望文章能夠幫你解決所遇到的問題。

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

成人av资源 | 国产精品久久久久久一区二区三区 | 欧美aaaxxxx做受视频 | 亚洲成av人片一区二区梦乃 | 嫩草伊人久久精品少妇av | av在线网站免费观看 | 六月天综合网 | 操操日 | 丁五月婷婷 | 夜夜夜夜操 | 国产一级免费在线观看 | 久久久免费播放 | 国产一级片直播 | 91精品久久久久久综合乱菊 | 中文字幕高清有码 | 91精品国自产在线 | 91精品在线播放 | 欧美日韩另类视频 | 免费欧美精品 | 国产精品第7页 | 人人射人人爱 | 亚洲第一久久久 | 天堂av色婷婷一区二区三区 | 精品亚洲一区二区 | 九九九免费视频 | www.天天操 | 色综合天天综合网国产成人网 | 国产精品剧情在线亚洲 | 97视频在线观看播放 | 久久激五月天综合精品 | 亚洲激情网站免费观看 | 超碰人人干人人 | 日韩最新在线 | 在线之家免费在线观看电影 | 日韩免费高清在线 | 国产精品女人网站 | 国产精品18久久久久久久 | 国产亚洲精品久久久久久网站 | 最新超碰在线 | 久久激情日本aⅴ | 91麻豆国产福利在线观看 | 欧美乱码精品一区 | 久久成人国产精品入口 | 最新影院 | 国产第一页在线观看 | 国产精品99久久久久 | 日韩精品一区二区三区水蜜桃 | 国产无套视频 | 人人草天天草 | 国产一区二区精品 | 免费在线观看av网站 | 亚洲 中文 在线 精品 | 欧美色操| 久久综合九色九九 | 精品女同一区二区三区在线观看 | av软件在线观看 | 五月开心综合 | 日韩综合一区二区 | 亚洲电影一级黄 | 亚洲综合网站在线观看 | 久久优| 日韩欧美xx | 91超级碰 | 在线日韩精品视频 | 日韩一区二区三区高清免费看看 | 欧日韩在线 | 久久婷亚洲五月一区天天躁 | 特级西西444www高清大视频 | 欧美先锋影音 | 四虎免费av | 亚洲在线视频观看 | 国产一区在线播放 | 黄色的片子 | 欧美最猛性xxxxx免费 | 亚洲最新av网址 | 开心丁香婷婷深爱五月 | 成人午夜电影在线观看 | 操夜夜操 | 丁香六月综合网 | 黄a在线看| 亚洲精品久久久久久久不卡四虎 | 夜夜骑日日操 | 黄污网站在线 | 日韩高清一二区 | 久草爱 | 伊人影院得得 | 中文字幕观看视频 | 一二区av | 少妇超碰在线 | 国产精品久久久久久久av大片 | 日韩在线观看一区二区三区 | 午夜999 | 国产精品综合久久久 | 亚洲国产中文字幕 | 欧美精品在线免费 | 亚洲区另类春色综合小说校园片 | 国产高清免费在线观看 | 国产视频一区精品 | 中国老女人日b | 中文字幕日本电影 | 久久手机免费观看 | 日韩一区二区三区免费电影 | 99精品国产高清在线观看 | 日本精品视频一区二区 | 香蕉视频最新网址 | 91免费高清 | 中文字幕视频观看 | 97中文字幕 | 18+视频网站链接 | 亚洲成av片人久久久 | 亚洲精品国产成人 | 五月激情综合婷婷 | 日韩欧美精品免费 | 国产一级免费观看 | 最近中文字幕mv免费高清在线 | 国产美女精品在线 | 久久 国产一区 | 免费美女av| 国产美女黄网站免费 | 日韩欧美大片免费观看 | 免费亚洲片 | 97在线精品国自产拍中文 | 欧美一区二区日韩一区二区 | 黄色av成人在线观看 | 午夜视频黄 | 国产精品69久久久久 | 日日夜夜操操操操 | 国内精品国产三级国产aⅴ久 | 亚洲日本一区二区在线 | www色片| 视频在线一区二区三区 | 婷婷资源站 | 偷拍福利视频一区二区三区 | 在线91精品 | 中日韩在线视频 | 国内视频在线 | 久久精品视频播放 | 国产成人一区三区 | 青青草国产精品视频 | 国产96视频| 五月天激情综合 | 国偷自产中文字幕亚洲手机在线 | 欧美高清成人 | 欧美日韩免费一区二区三区 | 国产成人在线综合 | 美女视频黄色免费 | 九草在线视频 | 91精品久久久久久综合乱菊 | 久久久久美女 | 精品视频免费看 | www免费 | 在线免费av电影 | 国产亚洲成av人片在线观看桃 | 午夜av免费 | 久久综合精品国产一区二区三区 | 久草免费在线观看视频 | 久久这里只有精品23 | 国产精品视频久久 | 国产精品伦一区二区三区视频 | 婷婷久久综合九色综合 | 国产日产精品一区二区三区四区的观看方式 | 国产资源在线免费观看 | 夜夜高潮夜夜爽国产伦精品 | 水蜜桃亚洲一二三四在线 | 国产精品网红福利 | 在线观看日韩免费视频 | 人成午夜视频 | 激情小说网站亚洲综合网 | 成人黄色小说网 | 麻豆影视在线播放 | 91视频国产高清 | 欧美天天综合网 | 国产精品久久久久久影院 | 亚洲精品国产精品久久99 | 欧美久久久久久久 | 超碰免费公开 | 国产99在线 | 五月天免费网站 | 天天激情天天干 | 在线免费高清一区二区三区 | 蜜桃视频在线视频 | 91色九色 | 国产精品一区二区精品视频免费看 | 日韩精品免费在线视频 | 国产三级视频在线 | 久在线观看 | 99久热在线精品视频观看 | 亚洲国产操 | 亚洲撸撸 | 五月婷婷在线观看 | 午夜视频日本 | 在线只有精品 | 免费看特级毛片 | 2024av在线播放| 国产天天综合 | 欧美精品久久久久久久久久丰满 | 国产一卡二卡在线 | 久草免费手机视频 | 视频一区二区三区视频 | 永久免费精品视频 | 草久在线观看视频 | 久热精品国产 | 国产视频 亚洲视频 | 在线国产一区二区 | 免费看的黄色小视频 | 国产一级特黄毛片在线毛片 | 国产视频高清 | 久久久久激情电影 | 免费视频a | 国产免费观看av | 色中文字幕在线观看 | 欧美精品黑人性xxxx | 久久精品影片 | 免费三及片 | av片在线看 | 国产一区二区在线观看视频 | 久久国产精品久久国产精品 | 亚洲日本在线视频观看 | www.久久久com | 午夜丁香视频在线观看 | av高清一区二区三区 | 在线 国产 亚洲 欧美 | 午夜少妇 | 精品国产伦一区二区三区 | 久草在线综合 | 嫩小bbbb摸bbb摸bbb | 韩日精品在线 | 亚洲成人黄 | 激情开心站| 天海冀一区二区三区 | 中文字幕视频观看 | 在线观看不卡的av | 人人草在线视频 | 在线视频18在线视频4k | 欧美少妇影院 | 欧美日韩国产亚洲乱码字幕 | 久久久久久国产精品亚洲78 | 亚洲激情综合网 | 精品国产伦一区二区三区观看方式 | 日韩色高清 | 九九九热 | 久久视频一区二区 | 亚洲免费在线观看视频 | 综合久久久久久久 | 日本午夜在线观看 | 在线观看亚洲a | 国产无遮挡又黄又爽在线观看 | 天天爽夜夜爽精品视频婷婷 | 欧美日韩性生活 | 99这里只有久久精品视频 | se婷婷 | 成人a级网站 | 免费看黄色小说的网站 | 天天操天天舔天天干 | 午夜精品久久久久久久99婷婷 | 久草视频免费在线观看 | 精品成人久久 | 精品久久久久一区二区国产 | 综合色站 | 奇米导航 | 精品日韩在线 | 91| 国产精品一区二区av影院萌芽 | 人成午夜视频 | av一区在线 | 亚洲人av免费网站 | 日日干 天天干 | 天天搞天天干天天色 | 人人玩人人添人人澡超碰 | 日韩成人免费在线 | 亚洲精品一区二区网址 | 97**国产露脸精品国产 | 中文字幕免费国产精品 | 91综合久久一区二区 | 精品久久久久久国产偷窥 | 午夜久久久精品 | 国产黄大片 | 国产香蕉久久 | 久久人人爽爽人人爽人人片av | 中文字幕一区二 | 午夜视频免费 | 丁香高清视频在线看看 | 在线播放一区二区三区 | 夜夜躁狠狠躁日日躁视频黑人 | av丝袜在线 | 亚洲精品国产成人av在线 | 九九导航 | 九九热久久久 | 很黄很污的视频网站 | 狠狠艹夜夜干 | 免费试看一区 | 亚洲人成免费 | 久久国产精品成人免费浪潮 | 怡春院av| 免费av 在线 | 成人a视频在线观看 | 99久久综合精品五月天 | 99精品热视频只有精品10 | 麻花豆传媒mv在线观看网站 | 在线小视频 | 国产精品18久久久久久不卡孕妇 | 欧美日韩精品网站 | 欧美性生活久久 | 欧美成人精品三级在线观看播放 | 久久国产精品色婷婷 | 成人免费大片黄在线播放 | 欧美精品久久久久久久免费 | 一区二区视频免费在线观看 | 超碰在线观看99 | 丁香五婷 | 欧美黄色成人 | 中文字幕九九 | 91在线视频免费91 | 探花在线观看 | 91视频在线 | 99在线观看精品 | 天天干天天射天天操 | 91精品天码美女少妇 | 色a综合 | 免费高清在线视频一区· | 中文字幕a∨在线乱码免费看 | 国产精品久久久久久久久久久免费看 | av在线免费在线观看 | 欧美欧美 | 国产精品系列在线播放 | 狠狠色噜噜狠狠狠合久 | 五月天视频网站 | 最近中文字幕mv免费高清在线 | 久久综合成人网 | 激情丁香婷婷 | 久久精品视频在线 | 久久综合之合合综合久久 | 中文字幕在线播放日韩 | 国产最新精品视频 | 天天爽天天碰狠狠添 | 最近更新好看的中文字幕 | 国产美女精品人人做人人爽 | 成人黄色在线电影 | 成人蜜桃网 | 国产经典 欧美精品 | 日韩最新在线 | 在线播放 日韩专区 | 亚洲精品男人天堂 | 在线色吧 | 欧美最爽乱淫视频播放 | av一级网站 | 欧美日韩高清免费 | 日韩美视频 | 在线 国产 亚洲 欧美 | 亚洲做受高潮欧美裸体 | 亚洲精品永久免费视频 | 色午夜| 四虎国产精品成人免费4hu | 久久天天操| 午夜99| 成人av电影免费观看 | 人人精品 | 国产成人亚洲在线观看 | 国产福利91精品 | 日韩色在线观看 | 欧美一区二区三区四区夜夜大片 | 97超碰人人在线 | 99久久99久久免费精品蜜臀 | 天天做夜夜做 | 欧美日韩国产一区二区三区 | 精品一区精品二区高清 | 国模视频一区二区三区 | 欧美日韩综合在线观看 | 亚洲欧美激情精品一区二区 | 亚洲电影久久久 | 精品国产大片 | 色搞搞 | 婷婷深爱网 | 精品国产一区二区三区av性色 | 亚洲精品美女久久久久网站 | 国产一级做a爱片久久毛片a | 黄色小说视频网站 | 国产精品久久久久久久久久三级 | 黄色国产精品 | 欧洲黄色片| 欧美日韩有码 | www操操操 | 区一区二区三区中文字幕 | 久久精品韩国 | 国产自产在线视频 | 91香蕉视频 mp4 | av成年人电影| 国产精品久久久久久久久久久不卡 | 国产精品高清一区二区三区 | 久久99九九99精品 | 久久久久久久综合色一本 | 色视频国产直接看 | 成年人免费在线看 | 久久精品草| 日本久久精| 欧美色综合天天久久综合精品 | 天天色天天操天天爽 | 夜夜澡人模人人添人人看 | 最新免费中文字幕 | 中文字幕 国产专区 | 色综合久久66| 色视频网站在线观看一=区 a视频免费在线观看 | 日韩精品在线视频免费观看 | 国产精品久久久久久久久久久久午夜片 | 国产一线二线三线在线观看 | 日韩精品网址 | 一二三区高清 | 天天操天天草 | 国产品久精国精产拍 | 五月激情亚洲 | www.香蕉视频在线观看 | 久久国产美女视频 | 国产一区二区三区高清播放 | 欧美精品xx | 亚洲经典视频在线观看 | 在线直播av | 一区二区精品视频 | 国产破处在线视频 | 成年人在线免费看视频 | 日韩三级av | 久久国产精品99久久久久久丝袜 | 婷婷夜夜 | 国产小视频网站 | 国产不卡免费视频 | 9999激情 | 81国产精品久久久久久久久久 | h动漫中文字幕 | 99视频 | 天天干,天天射,天天操,天天摸 | 国产特级毛片 | 色综合天天狠狠 | 精品视频一区在线观看 | 91成人精品一区在线播放69 | 久操视频在线 | 婷婷社区五月天 | 久久免费久久 | 久久久91精品国产一区二区精品 | 国产视频2021| 在线之家免费在线观看电影 | 久久一区国产 | 91精品国产成人www | 亚洲成人黄色网址 | 国产人成看黄久久久久久久久 | 99这里只有精品99 | 久久久久久国产精品美女 | 九热在线 | 婷婷性综合 | 特级黄色一级 | 日日狠狠 | 超碰资源在线 | 婷婷黄色片 | 中文字幕av一区二区三区四区 | 国产精品9999久久久久仙踪林 | 伊人五月天综合 | 日本高清xxxx | 欧美在线不卡一区 | 中文字幕av在线 | 精品国模一区二区三区 | 嫩小bbbb摸bbb摸bbb | 视频在线观看日韩 | 中文字幕在线看视频 | 久久午夜视频 | 一级c片| 亚洲午夜精品久久久久久久久久久久 | 久久天天躁夜夜躁狠狠躁2022 | 亚洲国产精品第一区二区 | 久久不射电影院 | 麻豆视频成人 | 九色91在线视频 | 亚洲免费在线观看视频 | 九九涩涩av台湾日本热热 | 97电影网手机版 | 成人福利av| 波多野结衣在线观看一区二区三区 | 亚洲毛片视频 | 国产亚洲久一区二区 | 91成人小视频 | 亚洲手机天堂 | 国产999精品视频 | 特黄特色特刺激视频免费播放 | 国产一级免费观看视频 | 国产精品综合在线观看 | 色91av | 91精品国产综合久久婷婷香蕉 | 久久九九精品久久 | 超碰在线97观看 | 在线精品视频免费播放 | 色偷偷888欧美精品久久久 | 日韩高清av在线 | 丁香五月亚洲综合在线 | 中文字幕一区二区三区四区 | 久久久免费国产 | 精品毛片一区二区免费看 | 黄色av电影免费观看 | 欧美性视频网站 | 99精品免费久久久久久日本 | 国产精品一区二区免费视频 | 亚洲天堂网在线观看视频 | www.色在线| 999久久久久久久久久久 | 高清日韩一区二区 | av一级片 | 国产成人一区二区三区影院在线 | 九色91福利 | 日韩视频图片 | 久久精品国产免费 | 五月天堂色 | 欧美热久久 | 免费日韩电影 | 亚洲精品黄色片 | 97人人模人人爽人人喊中文字 | 在线观看 国产 | 69xxxx欧美| 国产精品成人国产乱 | 丁香六月在线观看 | 久久免费国产电影 | 成人午夜电影网站 | 国产日韩精品一区二区三区在线 | 99在线观看视频 | 亚洲国产中文字幕在线观看 | 视频福利在线观看 | 91精品久久久久久粉嫩 | 亚洲美女精品 | 国产又粗又猛又黄又爽的视频 | 国产高清中文字幕 | 久久这里有精品 | 日韩手机在线 | 国产精品视频永久免费播放 | 欧美日韩国产精品一区 | 亚洲国产成人精品在线观看 | 国产精品大片在线观看 | 黄色国产大片 | 啪啪肉肉污av国网站 | 国产一区二区精品久久91 | 91av美女| 色在线免费 | 亚洲在线色| 日韩中文字幕视频在线 | 日韩三区在线 | 综合网伊人 | 碰超在线97人人 | 久久久久久久久久电影 | 国产第页 | 国产视频69| 国产日产精品一区二区三区四区 | 亚洲成人精品久久久 | 久久av免费观看 | 美女视频黄免费的 | 在线免费观看黄色大片 | 人人爱夜夜操 | 美女视频久久黄 | 不卡中文字幕av | 天天色天天 | 国产一区不卡在线 | 中文字幕在线中文 | 超碰大片 | 国产成人精品av在线 | 午夜精品久久久久久久久久久久 | 欧美aa级 | 久久久免费看视频 | 日韩剧| 经典三级一区 | 欧美福利视频一区 | 日女人免费视频 | 最新高清无码专区 | 18国产精品福利片久久婷 | 成人久久久久久久久久 | japanesexxxhd奶水 国产一区二区在线免费观看 | 亚洲精品免费看 | 色的网站在线观看 | 亚洲精品免费看 | 亚洲黄电影 | 国产99久久精品一区二区300 | 伊人永久在线 | 黄色大片视频网站 | 久久久久成人精品免费播放动漫 | 在线观看免费高清视频大全追剧 | 青草视频在线播放 | 国产黑丝一区二区 | 免费的黄色av | 日韩高清免费电影 | 久久视频中文字幕 | 欧美日韩在线观看视频 | 激情综合网五月 | 欧洲精品在线视频 | 麻豆一区二区三区视频 | 日韩精品一区二区久久 | 久久人操 | 国产一级特黄毛片在线毛片 | 欧美日韩免费观看一区=区三区 | 主播av在线 | 久久天| 日本最新一区二区三区 | 国产1区2区 | www国产精品com | 69国产在线观看 | 亚洲综合成人在线 | 亚洲人精品午夜 | 免费视频在线观看网站 | 特级免费毛片 | 免费无遮挡动漫网站 | 国产伦理一区二区三区 | 亚洲综合导航 | 精品在线一区二区三区 | 成人在线视频免费看 | 国产老熟 | 日韩欧美在线一区二区 | 亚洲三级网| 欧美黄色免费 | 国产成人三级在线观看 | 夜夜爱av | 日韩在线短视频 | 一区 二区电影免费在线观看 | 国产免费中文字幕 | 摸bbb搡bbb搡bbbb | 日本aaaa级毛片在线看 | 久久嗨| 久久久久亚洲精品 | 96在线| 国产丝袜网站 | 国产精品一区二区免费 | 欧美日韩中文国产一区发布 | 99久久网站 | 久久人人爽爽 | 久久永久免费 | 日韩综合一区二区 | av电影中文字幕 | 国产在线免费 | 国产免费午夜 | 高清精品在线 | 深夜视频久久 | 亚州精品在线视频 | 久久久久福利视频 | 亚洲精品在线资源 | 91精品免费在线观看 | 免费看精品久久片 | 狠狠色网 | 一区二区三区四区五区在线 | 亚洲国产精品va在线 | 在线天堂亚洲 | 五月天久久久 | 国产成a人亚洲精v品在线观看 | 狠狠躁夜夜躁人人爽视频 | 狠狠操狠狠干天天操 | 日韩一二区在线 | 韩国一区在线 | av三级在线看 | 五月天激情开心 | 欧美黄色成人 | 成人在线视频一区 | 国产一区在线播放 | 久久av电影 | 欧美日韩在线电影 | 97电影院在线观看 | 亚洲九九影院 | 亚洲精品麻豆视频 | 成人免费视频免费观看 | 91精品国产九九九久久久亚洲 | 国产91全国探花系列在线播放 | 99精品国产aⅴ | 国产.精品.日韩.另类.中文.在线.播放 | www黄色com| 国产精品一区二区 91 | 成年人在线观看视频免费 | 午夜久久福利 | 欧美午夜a | 一级做a视频| 97精品国产97久久久久久久久久久久 | 狠狠干狠狠艹 | 中文字幕精品一区二区三区电影 | 91xav| 91看片淫黄大片91 | 久草免费在线观看视频 | 在线免费三级 | 亚洲视屏一区 | 丁香婷婷亚洲 | 久久这里只有精品首页 | 99精品亚洲 | 国产精品一区二区av麻豆 | 国产精品2019 | 婷婷开心久久网 | freejavvideo日本免费 | 国产福利91精品一区二区三区 | 色视频成人在线观看免 | 国产精品黑丝在线观看 | 888av| 婷婷综合导航 | 国产视频97 | 国产亚洲在线视频 | 国产成人精品aaa | 一区二区三区四区在线免费观看 | 久久免费资源 | 色噜噜噜噜 | 欧美极品一区二区三区 | 国产手机在线视频 | 色婷婷视频在线观看 | 中文字幕在线观看免费高清完整版 | 一区二区三区精品久久久 | 欧美日韩一区二区在线 | 国产精品一区二区三区久久久 | 国产黄色特级片 | 1024久久 | 久久精品视频4 | 亚洲国产网站 | 91视频链接 | 在线观看中文字幕一区二区 | 欧美地下肉体性派对 | 亚洲视频在线观看 | 91麻豆精品国产自产在线游戏 | 91天天操 | 亚洲国产午夜精品 | 欧美成年网站 | 亚洲自拍偷拍色图 | 国产精品久久久久久一区二区三区 | 久久人人爽人人 | 日韩精品短视频 | 麻豆视频大全 | 午夜黄网 | 国产精品精品国产 | 蜜臀一区二区三区精品免费视频 | 成人av免费在线观看 | 一级大片在线观看 | 丁香五香天综合情 | 在线天堂中文www视软件 | 中文字幕精品www乱入免费视频 | 欧美激情综合色 | 日韩啪啪小视频 | 日韩国产在线观看 | 亚洲精品国久久99热 | 日韩一区二区三区高清免费看看 | 色噜噜噜| 亚洲国产高清在线 | 亚洲免费在线播放视频 | 欧美一二在线 | 国产精品99爱 | 亚洲国产精品激情在线观看 | 九九久久婷婷 | 国产精品中文字幕在线观看 | 精品视频在线视频 | 中国一级片在线 | 中文字幕乱码一区二区 | 成年人视频在线观看免费 | h动漫中文字幕 | 五月婷婷六月丁香在线观看 | 免费看国产黄色 | 99在线精品观看 | 久久久久久网址 | 国产精品美女毛片真酒店 | www.在线看片.com | 97av色| 在线看片中文字幕 | 天天色成人网 | 日韩三级视频在线观看 | 国产亚洲激情视频在线 | 亚洲精品在线网站 | 欧美视频国产视频 | 中文字幕 国产专区 | 久草视频在线免费 | 视频在线在亚洲 | 99热这里只有精品在线观看 | 美女在线免费观看视频 | 91视频免费| 成人黄色大片在线免费观看 | 亚洲精品视频在线观看免费视频 | 亚洲精品国偷拍自产在线观看蜜桃 | 成人在线黄色电影 | 久久国产一二区 | 国产精品第一页在线 | 久久久久久久电影 | 成人在线电影观看 | 国产黄色精品视频 | 色综久久 | 国内丰满少妇猛烈精品播 | 国产午夜精品免费一区二区三区视频 | 一区二区三区四区久久 | 黄色一级网 | 精品理论片 | 国产日韩精品在线观看 | 人人爽人人射 | 日本精品视频免费 | 日日夜日日干 | 中文字幕一区三区 | 国产视频在线看 | 久草在线免费新视频 | 日韩精品视频在线免费观看 | 久久五月婷婷丁香社区 | 黄色亚洲免费 | 日韩系列在线观看 | 日韩欧美成人网 | 在线观看免费成人 | 成人午夜剧场在线观看 | 国产一级h | 亚洲粉嫩av | 国产一级视频免费看 | 在线中文字幕av观看 | 999久久| 国产精品久久久久久久久久久久冷 | 人人爽人人爽人人片 | 日韩一区二区免费视频 | 中文字幕在线有码 | 亚洲 精品在线视频 | 午夜狠狠操 | 日本精品二区 | 91最新网址 | 欧美日韩国产mv | 91精品国产一区 | 天天操天天射天天插 | 精品一区欧美 | 欧美一区中文字幕 | 久久久久夜色 | 欧美在线观看视频 | 91视频电影| 亚洲国产欧美在线人成大黄瓜 | 国产亚洲精品bv在线观看 | 中文字幕在线观看资源 | 狠狠干夜夜操天天爽 | 欧洲性视频 | 久久久久综合 | 免费看一级 | 操操日日 | 最近最新中文字幕视频 | 香蕉视频4aa | 国产亚洲精品久久久久久大师 | 青青河边草手机免费 | 国产精品2018 | 四虎国产精品成人免费4hu | 久久极品 | 亚洲伊人色 | 国产精品原创 | 国产探花 | 免费合欢视频成人app | 亚洲国产精品电影 | 久久精品99国产精品日本 | 精品a级片 | 伊人亚洲精品 | 欧美人体xx| 久草在线免费在线观看 | 日韩大陆欧美高清视频区 | 欧美日韩国产色综合一二三四 | 亚洲成人一区 | 国产精品嫩草影院123 | 欧美日韩大片在线观看 | 国产91免费看 | 国产在线免费 | 久久精品5| 人人澡人人干 | 亚洲激情校园春色 | 国产成人综合在线观看 | 色综合久久久久综合体桃花网 | 精品a级片 | 毛片网在线观看 | 黄色在线观看网站 | a视频在线观看免费 | 久久6精品 | 视频直播国产精品 | 久久亚洲二区 | 国产高清黄 | 中文字幕亚洲欧美 | 色全色在线资源网 | 96久久久 | 国产高清中文字幕 | 九九九在线观看视频 | 99久久久久久久久 | 日p在线观看 | 美女视频网站久久 | 亚洲国产成人在线 | 国产手机精品视频 | 99久久国产免费,99久久国产免费大片 | 色综合久久综合 | 欧美性大胆 | 黄色免费大片 | 69视频网站| 亚洲精品国偷拍自产在线观看蜜桃 | 亚洲区另类春色综合小说校园片 | 欧美va日韩va | 天天se天天cao天天干 | 黄色免费大全 | 黄色国产在线观看 | 欧美色伊人 | 欧美成人播放 | 免费在线一区二区 | 黄色国产区 | 99久热在线精品视频观看 | 中文在线a√在线 | 国产精品视频免费观看 | 99精品视频99 | 欧美黄色特级片 | 四虎影视成人永久免费观看亚洲欧美 | 又长又大又黑又粗欧美 | 999久久a精品合区久久久 | 成人影音在线 | www亚洲精品 | 亚洲天堂va | 四虎海外影库www4hu | 超碰日韩在线 | 色综合色综合色综合 | 又湿又紧又大又爽a视频国产 | 午夜精品一区二区三区在线 | www.久久com| av福利第一导航 | 国产老妇av| 亚洲成人中文在线 | 日韩免费看 | 999成人国产 | 五月黄色| 久久久在线免费观看 | 中文字幕色站 | 亚洲精区二区三区四区麻豆 | 欧美日韩国产精品一区二区亚洲 | 欧美va电影 | 2019天天干天天色 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 视频在线日韩 | 精品久久在线 | 亚洲国产一区在线观看 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 国产女v资源在线观看 | 97人人人人 | 97福利在线观看 | 国产91区 | 久久九九精品久久 | 亚洲精品一区中文字幕乱码 | 欧洲精品在线视频 | 久久精品艹 | 免费看的黄色片 | 日韩午夜网站 | 午夜视频二区 | 97电影网站 | 免费看黄在线观看 | 国产亚洲精品久久网站 | 国产亚洲午夜高清国产拍精品 | 狠狠色综合网站久久久久久久 | 天天天色综合a | 亚洲va欧美va国产va黑人 | 国产精品免费看久久久8精臀av | 精品中文字幕在线 | 一区二区精品视频 | 中文字幕成人 | 九九热在线精品 | 久久精品99国产精品酒店日本 | 夜夜操天天干, | 国产精品三级视频 | 亚洲精品视频在线观看免费视频 | 中文字幕在线观看视频一区二区三区 | 久久精品老司机 | a电影免费看 | 亚洲精品在 | 午夜视频不卡 | www.黄色片.com| 黄色国产高清 | 国产精品入口a级 | 久久精品99北条麻妃 | 久久久天天操 | 亚洲国产黄色片 | 欧美另类交在线观看 | 精品免费视频 | 激情五月在线 | 毛片黄色一级 | 天天操天天摸天天爽 | 精品久久久久久久久久久久久久久久久久 | 992tv在线观看| 亚洲我射av| 日韩理论在线播放 | 亚洲另类人人澡 | 色99中文字幕 | 怡红院久久 | 欧美日韩成人 | 久黄色| 午夜丁香网 | 精品欧美在线视频 | 四虎国产精 | 成人黄色免费观看 | 免费高清在线观看成人 | 日韩视频一区二区在线观看 | 久久特级毛片 | 午夜电影久久久 | 欧美日bb | 日韩精品免费一区二区在线观看 | 亚洲jizzjizz日本少妇 | 日韩精品一区二区在线观看 | 欧美日韩国产区 | 久久久久欧美精品999 | 亚洲色综合 | 亚洲欧美国产精品 | 日本中文字幕在线播放 | 91日韩在线 | 久久免费视频这里只有精品 | 久草在线最新 | 国产精品网站一区二区三区 | 四虎国产精品永久在线国在线 | 懂色av一区二区三区蜜臀 | 国产中文字幕视频在线观看 | 九九交易行官网 | 正在播放日韩 | 亚洲一级特黄 | 国产精品久久久亚洲 | 亚洲精品视频在线 | 91豆麻精品91久久久久久 |