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

相关文章

springboot项目中集成shiro+jwt完整实例代码

《springboot项目中集成shiro+jwt完整实例代码》本文详细介绍如何在项目中集成Shiro和JWT,实现用户登录校验、token携带及接口权限管理,涉及自定义Realm、ModularRe... 目录简介目的需要的jar集成过程1.配置shiro2.创建自定义Realm2.1 LoginReal

gorm乐观锁使用小结

《gorm乐观锁使用小结》本文主要介绍了gorm乐观锁使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言grom乐观锁机制gorm乐观锁依赖安装gorm乐观锁使用创建一个user表插入数据版本号更新总结前言乐观锁,顾名

Python 函数详解:从基础语法到高级使用技巧

《Python函数详解:从基础语法到高级使用技巧》本文基于实例代码,全面讲解Python函数的定义、参数传递、变量作用域及类型标注等知识点,帮助初学者快速掌握函数的使用技巧,感兴趣的朋友跟随小编一起... 目录一、函数的基本概念与作用二、函数的定义与调用1. 无参函数2. 带参函数3. 带返回值的函数4.

MySQL中DATE_FORMAT时间函数的使用小结

《MySQL中DATE_FORMAT时间函数的使用小结》本文主要介绍了MySQL中DATE_FORMAT时间函数的使用小结,用于格式化日期/时间字段,可提取年月、统计月份数据、精确到天,对大家的学习或... 目录前言DATE_FORMAT时间函数总结前言mysql可以使用DATE_FORMAT获取日期字段

Go语言使用sync.Mutex实现资源加锁

《Go语言使用sync.Mutex实现资源加锁》数据共享是一把双刃剑,Go语言为我们提供了sync.Mutex,一种最基础也是最常用的加锁方式,用于保证在任意时刻只有一个goroutine能访问共享... 目录一、什么是 Mutex二、为什么需要加锁三、实战案例:并发安全的计数器1. 未加锁示例(存在竞态)

idea Maven Springboot多模块项目打包时90%的问题及解决方案

《ideaMavenSpringboot多模块项目打包时90%的问题及解决方案》:本文主要介绍ideaMavenSpringboot多模块项目打包时90%的问题及解决方案,具有很好的参考价值,... 目录1. 前言2. 问题3. 解决办法4. jar 包冲突总结1. 前言之所以写这篇文章是因为在使用Mav

setsid 命令工作原理和使用案例介绍

《setsid命令工作原理和使用案例介绍》setsid命令在Linux中创建独立会话,使进程脱离终端运行,适用于守护进程和后台任务,通过重定向输出和确保权限,可有效管理长时间运行的进程,本文给大家介... 目录setsid 命令介绍和使用案例基本介绍基本语法主要特点命令参数使用案例1. 在后台运行命令2.

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

使用Redis快速实现共享Session登录的详细步骤

《使用Redis快速实现共享Session登录的详细步骤》在Web开发中,Session通常用于存储用户的会话信息,允许用户在多个页面之间保持登录状态,Redis是一个开源的高性能键值数据库,广泛用于... 目录前言实现原理:步骤:使用Redis实现共享Session登录1. 引入Redis依赖2. 配置R

使用Python的requests库调用API接口的详细步骤

《使用Python的requests库调用API接口的详细步骤》使用Python的requests库调用API接口是开发中最常用的方式之一,它简化了HTTP请求的处理流程,以下是详细步骤和实战示例,涵... 目录一、准备工作:安装 requests 库二、基本调用流程(以 RESTful API 为例)1.