电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

vue實現折線圖 可按時間查詢

瀏覽:137日期:2022-12-04 15:19:55

本文實例為大家分享了vue實現可按時間查詢的折線圖的具體代碼,供大家參考,具體內容如下

1.vue前端

//查詢條件<template><el-date-picker v-model='listQuery.toptime' :picker-options='pickerOptions' type='daterange' clearable range-separator='至' start-placeholder='開始日期' end-placeholder='結束日期'/> <el-select v-model='listQuery.xAxis' placeholder='統計粒度' clearable > <el-option v-for='(item, index) in xAxisList' :key='index' :label='item.value' :value='item.id' /> </el-select>//折線圖 <el-card class='box-card'> <div slot='header' class='clearfix'> <span>折線圖</span> </div> <div : /> </el-card></template>

2.對應script代碼

// 引入基本模板const echarts = require(’echarts/lib/echarts’)// 引入柱狀圖組件require(’echarts/lib/chart/bar’)require(’echarts/lib/chart/pie’)// 引入提示框和title組件require(’echarts/lib/component/tooltip’)require(’echarts/lib/component/title’)require(’echarts/lib/component/legend’)export default {data() { return { listQuery: { page: 0, limit: 20, toptime: null, xAxis: null }, XList: [], XListName: ’’, YList: [], YListName: ’’, xAxisList: [ { id: 1, value: ’年’ }, { id: 2, value: ’月’ }, { id: 3, value: ’周’ } ], temp: { id: undefined, } } }, methods: { handleFilter1() { const listQueryData = Object.assign({}, this.listQuery) if (listQueryData.toptime !== null) { listQueryData.toptime = JSON.stringify(this.listQuery.toptime) } else if (listQueryData.toptime === null) { const end = new Date() const start = new Date() start.setTime(start.getTime() - 3600 * 1000 * 24 * 7)//默認按周查詢 this.listQuery.toptime = [start, end] listQueryData.toptime = JSON.stringify([start, end]) } switch (listQueryData.xAxis) { case 1: { const end = new Date() const start = new Date() start.setTime(start.getTime() - 3600 * 1000 * 24 * 365)//按年查詢 this.listQuery.toptime = [start, end] listQueryData.toptime = JSON.stringify([start, end]) break } case 2: { const end = new Date() const start = new Date() start.setTime(start.getTime() - 3600 * 1000 * 24 * 30)//按月查詢 this.listQuery.toptime = [start, end] listQueryData.toptime = JSON.stringify([start, end]) break } case 3: { const end = new Date() const start = new Date() start.setTime(start.getTime() - 3600 * 1000 * 24 * 7)//按周查詢 this.listQuery.toptime = [start, end] listQueryData.toptime = JSON.stringify([start, end]) break } } getShareTripCount(listQueryData).then(response => { this.XList = response.data.data.XList this.YList = response.data.data.YList this.YListName = response.data.data.YListName this.XListName = response.data.data.XListName this.drawLine() })},//重點drawLine() { const myChart3 = echarts.init(document.getElementById(’myChart3’)) myChart3.showLoading() // 數據加載完之前先顯示一段簡單的loading動畫 myChart3.hideLoading() // 隱藏加載動畫 // 繪制折線圖 const option = { title: { text: ’分享行程數據統計’, subtext: ’’ }, // tooltip: { // trigger: ’axis’ // }, legend: { data: [’總分享次數’, ’通過分享注冊用戶數’, ’今日分享次數’, ’今日通過注冊分享數’] }, // toolbox: { // show: true, // feature: { // mark: { show: true }, // dataView: { show: true, readOnly: false }, // magicType: { show: true, type: [’line’, ’bar’] }, // restore: { show: true }, // saveAsImage: { show: true } // } // }, calculable: true, xAxis: { name: this.XListName, type: ’category’, data: this.XList }, yAxis: { name: this.YListName, type: ’value’ }, series: [ { name: ’總分享次數’, type: ’line’, data: this.YList.sharenumList // markPoint: { // data: [ // { type: ’max’, name: ’最大值’ }, // { type: ’min’, name: ’最小值’ } // ] // } // markLine: { // data: [ // { type: ’average’, name: ’平均值’ } // ] // } }, { name: ’通過分享注冊用戶數’, type: ’line’, data: this.YList.shareUserRegisterList // markPoint: { // data: [ // { type: ’max’, name: ’最大值’ }, // { type: ’min’, name: ’最小值’ } // ] // } // markLine: { // data: [ // { type: ’average’, name: ’平均值’ } // ] // } }, { name: ’今日分享次數’, type: ’line’, data: this.YList.shareNumByDayList // markPoint: { // data: [ // { name: ’周最低’, value: -2, xAxis: 1, yAxis: -1.5 } // ] // } // markLine: { // data: [ // { type: ’average’, name: ’平均值’ } // ] // } }, { name: ’今日通過注冊分享數’, type: ’line’, data: this.YList.shareUserRegisterByDayList // markPoint: { // data: [ // { name: ’周最低’, value: -2, xAxis: 1, yAxis: -1.5 } // ] // } // markLine: { // data: [ // { type: ’average’, name: ’平均值’ } // ] // } } ] } myChart3.setOption(option)} }}

3.對應后端controller代碼

@RequestMapping(value = '/getShareTripCount', method = RequestMethod.POST) @ResponseBody public JSONResult getShareTripCount(HttpServletRequest request) { try { String topTime = request.getParameter('toptime'); String xAxis = request.getParameter('xAxis'); Map map = new HashMap(); if(!StringUtils.isEmpty(xAxis)){ switch (xAxis){ case '1':{ break; } case '2':{ map= getShareTripCountByTime(topTime); break; } case '3':{ map= getShareTripCountByTime(topTime); break; } default:{ map= getShareTripCountByTime(topTime); break; } } }else{ map=getShareTripCountByTime(topTime); } return new JSONResult(map, 0, '成功', true); } catch (Exception e) { e.printStackTrace(); return new JSONResult(null, 101, '服務器獲取失敗', false); } }private Map getShareTripCountByTime(String topTime) throws ParseException { Map map=new HashMap(); Sort.Order so = new Sort.Order(Sort.Direction.DESC, 'id'); Sort sort = new Sort(so); if (!StringUtils.isEmpty(topTime)) { topTime = topTime.replace('Z', ' UTC'); Gson gson = new Gson(); List<String> timeList = gson.fromJson(topTime, new TypeToken<List<String>>() { }.getType()); SimpleDateFormat format = new SimpleDateFormat('yyyy-MM-dd’T’HH:mm:ss.SSS Z'); Date endTime = format.parse(timeList.get(1)); Date beginTime = format.parse(timeList.get(0)); List<ShareCount> shareCountList = mongoTemplate.find(Query.query(Criteria.where('createTime').gte(beginTime).lte(endTime)).with(sort), ShareCount.class); Calendar c = Calendar.getInstance(); c.setTime(beginTime); int month = c.get(Calendar.MONTH); int year = c.get(Calendar.YEAR); int day = c.get(Calendar.DATE); int dayMax = DateUtil.daysBetween(beginTime, endTime); List<String> dayList = new ArrayList<>(); int monthMaxDay = DateUtil.getDaysByYearMonth(year, month); List<String> sharenumList = new ArrayList<>(); List<String> shareUserRegisterList = new ArrayList<>(); List<String> shareNumByDayList = new ArrayList<>(); List<String> shareUserRegisterByDayList = new ArrayList<>(); int j = 1; for (int i = 1; i <= dayMax; i++) { String sub = ''; int yue; int di; if (monthMaxDay >= i + day) { di = day + i; yue = month + 1; sub = yue + '-' + di; } else { yue = month + 2; di = j; sub = yue + '-' + di; j++; } int sharenum = 0; String sharenums =''; int shareUserRegister = 0; String shareUserRegisters =''; int shareNumByDay = 0; String shareNumByDays =''; int shareUserRegisterByDay = 0; String shareUserRegisterByDays =''; for (ShareCount shareCount : shareCountList) { c.setTime(shareCount.getCreateTime()); int months = c.get(Calendar.MONTH) + 1; int years = c.get(Calendar.YEAR); int days = c.get(Calendar.DATE); if (year == years && yue == months && di == days) { sharenum = sharenum + shareCount.getShareNum(); shareUserRegister = shareUserRegister + shareCount.getShareUserRegister(); shareNumByDay=shareNumByDay+ shareCount.getShareNumByDay(); shareUserRegisterByDay=shareUserRegisterByDay+shareCount.getShareUserRegisterByDay(); } } sharenums=String.valueOf(sharenum); shareUserRegisters=String.valueOf(shareUserRegister); shareNumByDays=String.valueOf(shareNumByDay); shareUserRegisterByDays=String.valueOf(shareUserRegisterByDay); dayList.add(sub); sharenumList.add(sharenums); shareUserRegisterList.add(shareUserRegisters); shareNumByDayList.add(shareNumByDays); shareUserRegisterByDayList.add(shareUserRegisterByDays); } Map maps=new HashMap(); maps.put('sharenumList', sharenumList); maps.put('shareUserRegisterList', shareUserRegisterList); maps.put('shareNumByDayList', shareNumByDayList); maps.put('shareUserRegisterByDayList', shareUserRegisterByDayList); map.put('type', 'month'); map.put('YList', maps); map.put('YListName', '次'); map.put('XListName', '日期'); map.put('XList', dayList); } return map;}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 不锈钢复合板厂家_钛钢复合板批发_铜铝复合板供应-威海泓方金属复合材料股份有限公司 | 东莞螺杆空压机_永磁变频空压机_节能空压机_空压机工厂批发_深圳螺杆空压机_广州螺杆空压机_东莞空压机_空压机批发_东莞空压机工厂批发_东莞市文颖设备科技有限公司 | 伊卡洛斯软装首页-电动窗帘,别墅窗帘,定制窗帘,江浙沪1000+别墅窗帘案例 | 气动隔膜泵厂家-温州永嘉定远泵阀有限公司 | 南京办公用品网-办公文具用品批发-打印机耗材采购 | 工业用品一站式采购平台|南创工品汇-官网|广州南创 | AR开发公司_AR增强现实_AR工业_AR巡检|上海集英科技 | SPC工作站-连杆综合检具-表盘气动量仪-内孔缺陷检测仪-杭州朗多检测仪器有限公司 | 锻造液压机,粉末冶金,拉伸,坩埚成型液压机定制生产厂家-山东威力重工官方网站 | Trimos测长机_测高仪_TESA_mahr,WYLER水平仪,PWB对刀仪-德瑞华测量技术(苏州)有限公司 | 熔体泵_熔体出料泵_高温熔体泵-郑州海科熔体泵有限公司 | 新疆乌鲁木齐网站建设-乌鲁木齐网站制作设计-新疆远璨网络 | 泥沙分离_泥沙分离设备_泥砂分离机_洛阳隆中重工机械有限公司 | 华禹护栏|锌钢护栏_阳台护栏_护栏厂家-华禹专注阳台护栏、楼梯栏杆、百叶窗、空调架、基坑护栏、道路护栏等锌钢护栏产品的生产销售。 | 无刷电机_直流无刷电机_行星减速机-佛山市藤尺机电设备有限公司 无菌检查集菌仪,微生物限度仪器-苏州长留仪器百科 | 全国国际化学校_国际高中招生_一站式升学择校服务-国际学校网 | ph计,实验室ph计,台式ph计,实验室酸度计,台式酸度计 | 【电子厂招聘_普工招工网_工厂招聘信息平台】-工立方打工网 | 20年条刷老厂-条刷-抛光-工业毛刷辊-惠众毛刷 | 手持式线材张力计-套帽式风量罩-深圳市欧亚精密仪器有限公司 | 衡阳耐适防护科技有限公司——威仕盾焊接防护用品官网/焊工手套/焊接防护服/皮革防护手套 | 旋转/数显粘度计-运动粘度测定仪-上海平轩科学仪器 | 意大利Frascold/富士豪压缩机_富士豪半封闭压缩机_富士豪活塞压缩机_富士豪螺杆压缩机 | loft装修,上海嘉定酒店式公寓装修公司—曼城装饰 | 美能达分光测色仪_爱色丽分光测色仪-苏州方特电子科技有限公司 | 上海风淋室_上海风淋室厂家_上海风淋室价格_上海伯淋 | 全温恒温摇床-水浴气浴恒温摇床-光照恒温培养摇床-常州金坛精达仪器制造有限公司 | 安全阀_弹簧式安全阀_美标安全阀_工业冷冻安全阀厂家-中国·阿司米阀门有限公司 | MVE振动电机_MVE震动电机_MVE卧式振打电机-河南新乡德诚生产厂家 | 广东泵阀展|阀门展-广东国际泵管阀展览会 | 合肥仿石砖_合肥pc砖厂家_合肥PC仿石砖_安徽旭坤建材有限公司 | 河南凯邦机械制造有限公司 | 权威废金属|废塑料|废纸|废铜|废钢价格|再生资源回收行情报价中心-中废网 | 箱式破碎机_移动方箱式破碎机/价格/厂家_【华盛铭重工】 | 光谱仪_积分球_分布光度计_灯具检测生产厂家_杭州松朗光电【官网】 | 广州番禺搬家公司_天河黄埔搬家公司_企业工厂搬迁_日式搬家_广州搬家公司_厚道搬迁搬家公司 | 烟台金蝶财务软件,烟台网站建设,烟台网络推广 | 耐酸泵,耐酸泵厂家-淄博华舜耐腐蚀真空泵 | 企业管理培训,企业培训公开课,企业内训课程,企业培训师 - 名课堂企业管理培训网 | 固诺家居-全屋定制十大品牌_整体衣柜木门橱柜招商加盟 | 环氧乙烷灭菌器_压力蒸汽灭菌器_低温等离子过氧化氢灭菌器 _低温蒸汽甲醛灭菌器_清洗工作站_医用干燥柜_灭菌耗材-环氧乙烷灭菌器_脉动真空压力蒸汽灭菌器_低温等离子灭菌设备_河南省三强医疗器械有限责任公司 |