vue项目使用Echarts制作项目工期甘特图

本文主要是介绍vue项目使用Echarts制作项目工期甘特图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1,前言
  • 2,布局和数据部分
  • 3,制作甘特图

1,前言


项目迭代过程中,碰上一个需求,要求用甘特图的方式显示项目的工期进度,开完会我赶紧搜索一下甘特图是啥东东,大概了解之后,做出了如下样式

Echarts版本4.5.0

vue版本2.x
甘特图

2,布局和数据部分


HTML部分

<template><div id="index"><div id="chart" /></div>
</template>

CSS部分

<style lang="less" scoped>
#chart{width: 100%;height: 500px;margin: 50px auto;
}
</style>

data部分

data() {return {chart: null, // chart实例chartData: [], // chart数据源startTime: '', // X轴起始时间endTime: '', // X轴终末时间yData: [], // Y轴项目类目dayTime: 3600 * 24 * 1000, // 一天的毫秒,因为01.01日-01.01日,也算一天initData: { // 可以认为是axios请求过来的数据res.datastartTime: '2020-12-01', // X轴起始时间endTime: '2022-01-30', // X轴终末时间value: [{itemName: '项目一', // 项目名value: [0, // 索引'2021-06-01', // 项目开始时间'2021-08-30', // 项目结束时间'2021-07-01', // 项目实际开始时间'2021-07-28' // 项目实际结束时间]},{itemName: '项目二',value: [1,'2021-06-21','2021-07-21','2021-07-18','2021-08-10']},{itemName: '项目三',value: [2,'2021-06-01','2021-06-22','2021-06-01','2021-06-22']},{itemName: '项目四',value: [3,'2021-06-22','2021-06-30','2021-06-22','2021-07-05']},{itemName: '项目五',value: [4,'2021-06-21','2021-07-06','2021-07-01','2021-07-30']},{itemName: '项目六',value: [5,'2021-07-01','2021-07-21','2021-07-02','2021-07-30']},{itemName: '项目七',value: [6,'2021-06-18','2021-09-30','2021-06-30','2021-10-10']}]}}}

3,制作甘特图


由于是demo,所以用的自己的数据,首先给需要用到的变量赋值

getData() {this.chartData = this.initData.value // chart的数据const arr = []this.chartData.forEach(item => {arr.push(item.itemName)})this.yData = arr // Y轴的类目标题this.startTime = this.initData.startTime // X轴开始值this.endTime = this.initData.endTime // X轴结束值this.setData()
}

赋值之后,根据值,定义初始参数配置

setData() {const _this = thisconst param = {title: {text: '项目执行情况',left: 'center'},tooltip: {// 自定义提示信息// params为当前点击图形元素的数据信息的对象formatter(params) {// 计划开始时间let planStartDate = params[0].value[1]// 计划结束时间let planEndDate = params[0].value[2]// 实际开始时间let practiceStartDate = params[0].value[3]// 实际结束时间let practiceEndDate = params[0].value[4]// 项目周期(毫秒值):计划结束日期 - 计划开始日期// eslint-disable-next-linelet projectCycle_millisecond = +Echarts.number.parseDate(params[0].value[2]) - +Echarts.number.parseDate(params[0].value[1])// 项目周期(天数)let projectCycle_days = projectCycle_millisecond / _this.dayTime + 1return params[0].name + '<br/>'+ '计划开始时间:' + planStartDate + '<br/>'+ '计划结束时间:' + planEndDate + '<br/>'+ '项目周期:' + projectCycle_days + '天<br/>'+ '实际开始时间:' + practiceStartDate + '<br/>'+ '实际结束时间:' + practiceEndDate}},dataZoom: [{// 区域缩放组件的类型为滑块,默认作用在x轴上type: 'slider',// 区域缩放组件的过滤模式,weakFilter:在进行区域缩放时,允许图形的一部分在坐标系上(可见),另一部分在坐标系外(隐藏)filterMode: 'weakFilter',showDataShadow: false,top: 450,height: 10,// 区域缩放组件边框颜色borderColor: 'transparent',// 区域缩放组件边框背景backgroundColor: '#e2e2e2',// 区域缩放组件上的手柄的样式// eslint-disable-next-linehandleIcon: 'M10.7,11.9H9.3c-4.9,0.3-8.8,4.4-8.8,9.4c0,5,3.9,9.1,8.8,9.4h1.3c4.9-0.3,8.8-4.4,8.8-9.4C19.5,16.3,15.6,12.2,10.7,11.9z M13.3,24.4H6.7v-1.2h6.6z M13.3,22H6.7v-1.2h6.6z M13.3,19.6H6.7v-1.2h6.6z',// 手柄大小handleSize: 20,// 为手柄设置阴影效果handleStyle: {shadowBlur: 6,shadowOffsetX: 1,shadowOffsetY: 2,shadowColor: '#aaa'},labelFormatter: ''},{// 区域缩放组件的类型为内置在坐标系中,默认作用在x轴的坐标系中type: 'inside',// 区域缩放组件的过滤模式,weakFilter:在进行区域缩放时,允许图形的一部分在坐标系上(可见),另一部分在坐标系外(隐藏)filterMode: 'weakFilter'}],// 图表底板grid: {height: 330,tooltip: {trigger: 'axis',axisPointer: {type: 'shadow'}}},xAxis: {// x轴类型为时间轴type: 'time',// 最小值min: _this.startTime,// 最大值max: _this.endTime,axisLabel: {// 强制显示所有标签interval: 0}},yAxis: {data: _this.yData},legend: {selectedMode: false,left: '70%',top: 10,data: ['计划工期', '实际工期']},series: [{type: 'custom',// 使用自定义的图形元素renderItem: _this.renderItem,name: '计划工期',itemStyle: {opacity: 0.7,color: '#409EFF'},encode: {// 将维度1和维度2的数据映射到x轴x: [1, 2],// 将维度0的数据映射到y轴y: 0},data: _this.chartData},// 没有给它设置data,只是为了通过这个系列,显示图例(legend)而已{type: 'custom',name: '实际工期',itemStyle: {color: '#F56C6C'}}]}this.init(param)}

上述参数配置中,还需定义一下自定义的图形绘制方法

// params为data中的数据项的信息对象 api是可调用的方法集合,可以对data中的数据项进行操作
renderItem(params, api) {// 取出data中数据项的第一个维度的值let categoryIndex = api.value(0)// ===============计划工期进度条// 计划开始日期(在屏幕上的像素值)// 将数据项中的数值对应的坐标系上的点,转换为屏幕上的像素值// 坐标系上的点:是数据项映射到坐标系的x轴和y轴后,对应的位置// 屏幕上的像素值:是坐标系上的点,在屏幕上的位置let planStartDate = api.coord([api.value(1), categoryIndex])// 计划结束日期(在屏幕上的像素值)let planEndDate = api.coord([api.value(2), categoryIndex])// 由于data.value中维度1和维度2的数据会被映射到x轴,而x轴的type为time,即时间轴,// 所以api.value(1)和api.value(2)获取到的值是将日期转换后的毫秒值// 设置图形的高度// 获得Y轴上数值范围为1的一段所对应的像素长度;这是官方文档的注释,对于api.size()方法,目前我还不是很理解;先做个标记??? 以后再说let height = api.size([0, 1])[1] * 0.4let width = planEndDate[0] - planStartDate[0]if (width <= 10) {width = 3}// 使用graphic图形元素组件,绘制矩形// clipRectByRect方法,在绘制矩形时,如果矩形大小超出了当前坐标系的包围盒,则裁剪这个矩形let rectShape1 = Echarts.graphic.clipRectByRect({// 矩形的位置x: planStartDate[0],y: planStartDate[1],// 矩形的宽高width,height},{// 当前坐标系的包围盒x: params.coordSys.x,y: params.coordSys.y,width: params.coordSys.width,height: params.coordSys.height})// ===============实际工期进度条let rectShape2 = null// 判断实际开始日期和结束日期是否为空if (api.value(3) !== '' && api.value(4) !== '') {// 实际开始日期(在屏幕上的像素值)let practiceStartDate = api.coord([api.value(3), categoryIndex])let practiceEndDate = api.coord([api.value(4), categoryIndex])let widthNum = practiceEndDate[0] - practiceStartDate[0]if (widthNum <= 5) {widthNum = 3}// 使用graphic图形元素组件,绘制矩形// clipRectByRect方法,在绘制矩形时,如果矩形大小超出了当前坐标系的包围盒,则裁剪这个矩形rectShape2 = Echarts.graphic.clipRectByRect({// 矩形的位置x: practiceStartDate[0],y: practiceStartDate[1],// 矩形的宽高width: widthNum,height}, {// 当前坐标系的包围盒x: params.coordSys.x,y: params.coordSys.y,width: params.coordSys.width,height: params.coordSys.height})}let lineObj = {}// 如果项目还没开始,那么只渲染计划工期的进度条if (rectShape2 === null) {// 设置绘制的矩形的元素定义lineObj = rectShape1 && {type: 'group',children: [{// 类型为矩形type: 'rect',// 具体形状shape: rectShape1,// 样式style: api.style({fill: '#409EFF'})}]}} else {// 渲染计划工期和实际工期// 设置绘制的矩形的元素定义lineObj = rectShape1 && rectShape2 && {type: 'group',children: [{// 类型为矩形type: 'rect',// 具体形状shape: rectShape1,// 样式style: api.style({fill: '#409EFF'})},{// 类型为矩形type: 'rect',// 具体形状shape: rectShape2,// 样式style: api.style({fill: '#F56C6C'})}]}}return lineObj}

这些都ok,我们就可以初始化chart了

init(param) {this.chart = Echarts.init(document.getElementById('chart'))this.chart.setOption(param)}

大功告成

如果看了觉得有帮助的,我是@鹏多多i,欢迎 点赞 关注 评论;
END

面向百度编程

公众号

公众号

往期文章

  • javaScript中try和catch的使用和跳出forEach循环
  • 细数JS中实用且强大的操作符&运算符
  • 使用nvm管理node.js版本以及更换npm淘宝镜像源
  • vue中利用.env文件存储全局环境变量,以及配置vue启动和打包命令

个人主页

  • CSDN
  • GitHub
  • 简书
  • 博客园
  • 掘金

这篇关于vue项目使用Echarts制作项目工期甘特图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/361402

相关文章

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,