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

相关文章

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关