Vue整合甘特图(横道图、Gantt)实例
Vue整合甘特图(横道图、Gantt)实例
引入相应的模块:
cnpm install gantt-elastic --save
cnpm install gantt-elastic-header --save
cnpm install dayjs --save
Vue代码部分:
<template><div><!--横道图(甘特图)的相关参数说明:(1):options:相关配置信息(2):tasks:想要展示的数据信息(3)@tasks-changed:甘特图中的数据发生变化时调用的方法(4)@options-changed:opinions中的配置改变时的调用的(5)@dynamic-style-changed:样式发生改变时调用的--><!-- tasksUpdate 方法和 optionsUpdate 方法 在从后端接口中获取数据,赋值调用的同时,会出现死循环。所以要加上一个条件进行判断 --><gantt-elastic :options="options" :tasks="dataShow" @tasks-changed="tasksUpdate" @options-changed="optionsUpdate"@dynamic-style-changed="styleUpdate"><gantt-header slot="header"/></gantt-elastic></div>
</template><style>
</style><script>// 横道图(甘特图)需要的三个组件import GanttElastic from 'gantt-elastic';import GanttHeader from 'gantt-elastic-header';import dayjs from 'dayjs';export default {name: 'GanttChart',// 调用两个组件components: {GanttElastic, GanttHeader},props: {value: {default: ''}},data() {return {dataShow: [{id: 1,label: '项目一',user: "<a target='_blank' style='color:#0077c0;'>小辰哥哥</a>",start: this.getDate(-24 * 5), // 计划开始时间(-24 * 5 代表5天前)duration: 7 * 24 * 60 * 60 * 1000, // 周期(天、时、分、秒 ==== 7天)end: this.getDate(-24 * 5 + 24 * 7), // 计划完成时间(计划开始时间 + 周期)percent: 71, // 工作完成百分比(完成时间/周期)type: 'project',style: {base: {fill: '#FF6666', // 甘特图填充颜色stroke: '#000000' // 甘特图边框颜色}}collapsed: true, // 实现折叠(当有子模块时) },{id: 2,label: '项目二',user: "<a target='_blank' style='color:#0077c0;'>小辰哥哥</a>",start: this.getDate(0), // 计划开始时间(0 代表从今天开始)duration: 7 * 24 * 60 * 60 * 1000, // 周期(天、时、分、秒 ==== 7天)end: this.getDate(24 * 7), // 计划完成时间(计划开始时间 + 周期)percent: 0, // 工作完成百分比(完成时间/周期)type: 'project',style: {base: {fill: '#FF6666', // 甘特图填充颜色stroke: '#000000' // 甘特图边框颜色}}},{id: 3,label: '项目三',user: '<a target="_blank" style="color:#0077c0;">小辰哥哥</a>',start: this.getDate(-24 * 3), // 计划开始时间(-24 * 3 代表3天前)duration: 7 * 24 * 60 * 60 * 1000, // 周期(天、时、分、秒 ==== 7天)end: this.getDate(-24 * 3 + 24 * 7), // 计划完成时间(计划开始时间 + 周期)percent: 43, // 工作完成百分比(完成时间/周期)type: 'project',style: {base: {fill: '#FF6666', // 甘特图填充颜色stroke: '#000000' // 甘特图边框颜色}}},{id: 4,label: '项目四',user: '<a target="_blank" style="color:#0077c0;">小辰哥哥</a>',start: this.getDate(24 * 3), // 计划开始时间(24 * 3 代表3天后)duration: 7 * 24 * 60 * 60 * 1000, // 周期(天、时、分、秒 ==== 7天)end: this.getDate(24 * 3 + 24 * 7), // 计划完成时间(计划开始时间 + 周期)percent: 0, // 工作完成百分比(完成时间/周期)type: 'project',style: {base: {fill: '#FF6666', // 甘特图填充颜色stroke: '#000000' // 甘特图边框颜色}}},{id: 5,label: '项目五',user: '<a target="_blank" style="color:#0077c0;">小辰哥哥</a>',start: this.getDate(24 * 2), // 计划开始时间(24 * 2 代表2天后)duration: 7 * 24 * 60 * 60 * 1000, // 周期(天、时、分、秒 ==== 7天)end: this.getDate(24 * 2 + 24 * 7), // 计划完成时间(计划开始时间 + 周期)percent: 0, // 工作完成百分比(完成时间/周期)type: 'project',style: {base: {fill: '#FF6666', // 甘特图填充颜色stroke: '#000000' // 甘特图边框颜色}}},{id: 6,label: '项目六',user: '<a target="_blank" style="color:#0077c0;">小辰哥哥</a>',start: this.getDate(-24 * 2), // 计划开始时间(-24 * 2 代表2天前)duration: 7 * 24 * 60 * 60 * 1000, // 周期(天、时、分、秒 ==== 7天)end: this.getDate(-24 * 2 + 24 * 7), // 计划完成时间(计划开始时间 + 周期)percent: 29, // 工作完成百分比(完成时间/周期)type: 'project',style: {base: {fill: '#FF6666', // 甘特图填充颜色stroke: '#000000' // 甘特图边框颜色}}}],options: {taskMapping: {progress: 'percent'},maxRows: 10, // 设置最大行距maxHeight: 700, // 设置最大高度(超出高度,出现滚动条)times: {timeScale: 60 * 1000, // 设置时间尺度timeZoom: 18 // 设置甘特图进度的列宽},row: {height: 30 // 设置行的样式(甘特图的高度)},calendar: {workingDays: [1, 2, 3, 4, 5], // 设置每周的工作时间(周一、周二、周三、周四、周五)gap: 20, // 距离上方的距离(设置右侧甘特图的时、天、月)、外边距strokeWidth: 5, // 距离下方的距离(设置右侧甘特图的时、天、月)、外边距hour: {display: true // 设置小时是否出现}},chart: {grid: {horizontal: {gap: 13 // 甘特图在表格中,上下内边距}},text: {offset: 4,xPadding: 10,display: true // 甘特图右侧的文字是否显示},progress: {bar: true // 特殊标记甘特图已完成区域(绿颜色区域)、样式可以通过CSS样式修改(附件1)},expander: { // expander设置收缩icon的样式属性type: 'chart',display: true,displayIfTaskListHidden: true,offset: 4,size: 18}},taskList: { // 设置甘特图的左侧的每一列的名称等,设置图左侧要显示的那些固定内容expander: {straight: false},columns: [{id: 1,label: 'ID',value: 'id', // 要与dataShow里面的属性名相对应width: 50, // width为0时,可以实现整列消失},{id: 2,label: '项目名称',value: 'label', // 要与dataShow里面的属性名相对应width: 120, // width为0时,可以实现整列消失expander: true, // 当存在嵌套关系时,显示“+”号进行展开html: true,events: {click({data}) {alert('description clicked!\n' + data.label); // 触发点击事件}}},{id: 3,label: '责任人',value: 'user', // 要与dataShow里面的属性名相对应width: 90, // width为0时,可以实现整列消失html: true,style: {'task-list-header-label': {'text-align': 'center',width: '100%' // 表头水平居中},'task-list-item-value-container': {'text-align': 'center',width: '100%' // 表内数据水平居中}}},{id: 4,label: '开始时间',value: task => dayjs(task.start).format('YYYY-MM-DD'), // 要与dataShow里面的属性名相对应width: 90, // width为0时,可以实现整列消失style: {'task-list-header-label': {'text-align': 'center',width: '100%' // 表头水平居中},'task-list-item-value-container': {'text-align': 'center',width: '100%' // 表内数据水平居中}}},{id: 4,label: '计划完成时间',value: task => dayjs(task.end).format('YYYY-MM-DD'), // 要与dataShow里面的属性名相对应width: 100, // width为0时,可以实现整列消失style: {'task-list-header-label': {'text-align': 'center',width: '100%' // 表头水平居中},'task-list-item-value-container': {'text-align': 'center',width: '100%' // 表内数据水平居中}}},{id: 5,label: '进度',value: 'progress', // 要与dataShow里面的属性名相对应width: 45, // width为0时,可以实现整列消失style: {'task-list-header-label': {'text-align': 'center',width: '100%' // 表头水平居中},'task-list-item-value-container': {'text-align': 'center',width: '100%' // 表内数据水平居中}}}]},locale: { // 把表头设置成中文name: 'ch',Now: '配置','X-Scale': '时间','Y-Scale': '间隔','Task list width': 'Task list','Before/After': 'Expand','Display task list': 'Task list',weekdays: ['周日', '周一', '周二', '周三', '周四', '周五', '周六'],months: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月']}},task: '',dynamicStyle: {},}},mounted() {this.getListData();},methods: {/*** 计算从什么时间开始** 返回值:当前时间 + 参数(额外的天数 * 24)、时间戳** @param hours* @returns {number}* @author 小辰哥哥*/getDate(hours) {// 获取当前时间const currentDate = new Date();// 年、月、日、时、分、秒const currentYear = currentDate.getFullYear();const currentMonth = currentDate.getMonth();const currentDay = currentDate.getDate();const currentHour = currentDate.getHours();const currentMinute = currentDate.getMinutes();const currentMillisecond = currentDate.getMilliseconds();const timeStamp = new Date(currentYear, currentMonth, currentDay, currentHour, currentMinute, currentMillisecond).getTime();return new Date(timeStamp + hours * 60 * 60 * 1000).getTime();},tasksUpdate(task) {// tasksUpdate方法中要判断下,如果不进行判断会形成死循环// this.tasks = task},optionsUpdate(options) {this.options = options;},styleUpdate(style) {this.dynamicStyle = style;},async getListData() {for (let i = 0; i < this.value.length; i++) {this.value[i].duration = this.value[i].duration * 24 * 60 * 60 * 1000;this.value[i].end = this.value[i].start + this.value[i].duration;}this.tasksUpdate(this.value);}}}
</script>
附件1(修改甘特图已完成部分样式):
<style scoped>/deep/ rect.gantt-elastic__chart-row-progress-bar-solid{height: 100% !important;fill: #5E9386 !important;}
</style>
总结
每天一个提升小技巧!!!
Vue整合甘特图(横道图、Gantt)实例相关推荐
- Vue Dhtmlxgantt甘特图/横道图 baselines 含(计划、实际时间对比)树形实例实现及部分扩展
Vue Dhtmlxgantt甘特图/横道图 baselines 含(计划.实际时间对比)树形实例实现及部分扩展 背景: 需满足计划.实际时间对比需求,本人查看了很多文档和资料(对比了dhtmlxga ...
- python动态横道图_jQuery甘特图/日程图/横道图/插件
基于JQ的一款灵活高效,支持自定义拓展的甘特图/日程图插件 支持月/周/小时等显示方式 支持拖动改变时间 展开与收起 添加/删除,刷新 节假日高亮 clicked,dblClicked,changed ...
- 甘特图(别名:横道图、条状图)的画法
简介: 甘特图(Gantt chart )又叫横道图.条状图(Bar chart).它是以图示的方式通过活动列表和时间刻度形象地表示出任何特定项目的活动顺序与持续时间.在处理多道批处理系统问题时,有时 ...
- python动态横道图_Python数据可视化:甘特图画法
大家好,我是一名Python数据分析师,我想把自己转行成功之路上的经验分享给大家,由此就有了我的人工智能四部曲:<15天学会Python编程>.<每天10分钟,用Python学数据分 ...
- python动态横道图_python的matplotlib.pyplot绘制甘特图
博主本来就想简单地找一下代码,画一幅甘特图,结果百度之后发现甘特图的代码基本都不是用matplotlib库,但是像柱状图等统计图通常都是用这个库进行绘制的,所以博主就花了一些时间,自己敲了一份代码,简 ...
- wps表格l制作甘特图_WPS表格制作进度计划横道图的方法
计划横道图能让我们更能直观的了解数据,学习啦小编在这给大家介绍下WPS表格制作进度计划横道图的方法,希望大家多多学习! WPS表格制作进度计划横道图的教程 1.输入数据新建一个表格文件,按三列依次输入 ...
- 双代号网络图基础算法_最新(免锁版)网络图横道图绘制软件,内附安装教程,制图做更快...
最新(免锁版)网络图横道图绘制软件,内附安装教程,制图做更快 网络图横道图绘制可制作双代号网络计划.单代号网络图.横道图(及甘特图Gantt),是最常用的计划与控制手段之一,项目管理的必备工具,还可作 ...
- 横道图时间标尺在P6软件中的设置
卷首语 由于其直观简洁且易于管理的特性,使其成为展示项目活动顺序及时间安排的最常用的进度管理工具. 甘特图 甘特图(Gantt Chart),又称为横道图或棒条图,是最早的项目进度管理工具之一.由于其 ...
- 单代号网络图计算例题_工程人如何绘制进度计划?(双代号网络图、横道图等)...
网络图:是由箭线和节点.线路组成的,用来表示工作流程的有向.有序的网状图形,每个工作都有两个节点,用圆圈表示,和一个有方向的箭线构成,箭线的长度代表工期的长短. 横道图:又称甘特图(Gantt cha ...
- 单代号网络图计算例题_最新(免锁版)网络图横道图绘制软件,内附安装教程,制图做更快...
最新(免锁版)网络图横道图绘制软件,内附安装教程,制图做更快 网络图横道图绘制可制作双代号网络计划.单代号网络图.横道图(及甘特图Gantt),是最常用的计划与控制手段之一,项目管理的必备工具,还可作 ...
最新文章
- SSL为Windows server 2008 IIS7进行加密连接
- Inbound process in CRM
- 绵阳python培训_《绵》原文及翻译海绵翻译
- 学生分组(洛谷P1109题题解,C++语言描述)
- Java基础——Ajax(一)
- python入门代码-Python入门学习系列——Python代码测试
- [转]EVC++开发实例之浏览器窗口(by fllsoft)
- AndroidMenifest.xml file missing 报错
- mysql 原来用的引擎_MySQL 的常用引擎
- vue 设置div圆角,只设置上面两个圆角,下面两个还是正方形
- 网吧软件经典大集合.各种网管工具
- 超级APP势不可挡--20190706
- php将多张图片合并成pdf,如何简单有效的将多张图片合并成一个PDF文件
- OpenCV 3.0 高动态范围图像
- android 插屏广告代码,插屏实现说明
- 06-课堂笔记-包相关
- OJDBC版本【classes12.jar,ojdbc14.jar,ojdbc5.jar和ojdbc6.jar的区别】
- 如何安装操作系统?过程、图文。
- [R语言]{实例}车辆车架号VIN码校验函数
- vue 生命周期的11中方法详解
热门文章
- 嵌入式软件开发学习路线
- Arduino ide配置esp32硬件支持(配置esp32的arduino开发环境)
- pyautogui入门学习之消息盒子
- 大师系列之彼得•林奇层查股
- QT软件开发: 基于FFMPGE设计的流媒体播放器(rtmp/rtsp)
- python中的反三角函数_用python画所有三角函数和反三角函数图像
- C语言基础学习——编译过程
- 两台计算机和两台交换机的VLAN配置,两台交换机如何配置连接?
- android 小米pad 调试,小米平板2 开启USB调试模式
- Python爬虫爬取网页数据