当前位置: 代码网 > it编程>编程语言>Javascript > Vue echarts绘制甘特图的示例代码

Vue echarts绘制甘特图的示例代码

2024年05月18日 Javascript 我要评论
什么是甘特图甘特图(gantt chart)又称为横道图、条状图(bar chart)。其通过条状图来显示项目、进度和其他时间相关的系统进展的内在关系随着时间进展的情况。以提出者亨利·劳

什么是甘特图

甘特图(gantt chart)又称为横道图、条状图(bar chart)。其通过条状图来显示项目、进度和其他时间相关的系统进展的内在关系随着时间进展的情况。以提出者亨利·劳伦斯·甘特(henry laurence gantt)先生的名字命名。

甘特图以图示通过活动列表和时间刻度表示出特定项目的顺序与持续时间。一条线条图,横轴表示时间,纵轴表示项目,线条表示期间计划和实际完成情况。直观表明计划何时进行,进展与要求的对比。便于管理者弄清项目的剩余任务,评估工作进度。

1、不同的颜色表示不同的阶段。

2、每一行表示一个任务。

3、任务与任务之间的黑色箭头表示任务之间的依赖关系,必需完成前面的才能完成后面的。

通过这一张甘特图,能一眼看出以下信息:

  1. 今天应该做什么任务

  2. 这个任务从什么时候开始,到什么时候结束

  3. 在某一段时间有哪些任务

  4. 应该先做哪些任务再做哪些任务

  5. 哪些任务可以同时做

  6. 这个任务是否被其他任务依赖,如果是,那么这个任务就不能推迟,必需按时完成或者提前完成,否则会影响后面的任务

  7. 大任务下面有哪些子任务

  8. 可以显示任务的里程碑是什么时候

使用场景

主要用于横坐标固定,比如一天24小时,这样就可以根据y轴数据可正可负

速用示例版

可以直接将option 复制即可

option = {
  tooltip: {
    trigger: 'axis'
  },
   grid: {
    top: '10%',
    left: '3%',
    right: '4%',
    bottom: '3%',
    containlabel: true
  },
  toolbox: {
    show: true,
    feature: {
      saveasimage: {}
    }
  },
  xaxis: {
    type: 'category',
    boundarygap: false,
    splitline: {
      show: true
    },
    axislabel: {
      padding: [0, 0, 0, -20]    // 四个数字分别为上右下左与原位置距离
    },
    data: ['00:00', '01:00', '02:00', '03:00', '04:00', '05:00', '06:00','07:00', '08:00', '09:00', '10:00', '11:00', '12:00', '13:00', '14:00', '15:00', '16:00', '17:00', '18:00', '19:00', '20:00', '21:00', '22:00', '23:00', '24:00']
  },
  yaxis: {
    type: 'value',
    name: '单位(kw)',
    // scale: true,
    splitline: {
      show: false
    },
    axislabel: {
      formatter: '{value}',
      
    }
  },
  series: [
    {
      name: '',
      type: 'line',
      smooth: true,
      showsymbol: false,
      symbol: false,
      linestyle: {
        normal: {
          width: 10
        }
      },
      markpoint: {
        data: [
          {
            name: '最大值',
            type: 'max',
            valueindex: 0
          }
        ]
      },
      data: [300, 300, 300, 300, 300, 300, 300],
    },
    {
      name: '',
      type: 'line',
      smooth: true,
      showsymbol: false,
      symbol: false,
      linestyle: {
        width: 10
      },
      markpoint: {
        data: [
          {
            name: '最大值',
            type: 'max',
            valueindex: 0
          }
        ]
      },
      data: ['','','','','','', 500, 500, 500, 500, 500]
    },
    {
      name: '',
      type: 'line',
      smooth: true,
      showsymbol: false,
      symbol: false,
      linestyle: {
        normal: {
          width: 10
        }
      },
      markpoint: {
        data: [
          {
            name: '最大值',
            type: 'max',
            valueindex: 0
          }
        ]
      },
      data: ['','','','','','','', '', '','',-100, -100,-100, -100,-100]
    },
    {
      name: '',
      type: 'line',
      smooth: true,
      showsymbol: false,
      symbol: false,
      linestyle: {
        normal: {
          width: 10
        }
      },
      markpoint: {
        data: [
          {
            name: '最大值',
            type: 'max',
            valueindex: 0
          }
        ]
      },
      data: ['','','','','','','', '', '','','','','','','',200,200,200,200,200,200,200,200,200,200]
    }
  ]
};

润雨细无声版

<div ref="strategydomref"
 style="width: 800px;
        height: 600px;"
>
import * as echarts from 'echarts'
mounted() {
 let apidata = [
      {
        starttime: '00:00',
        endtime: '05:00',
        value: 200,
      },
      {
        starttime: '05:00',
        endtime: '12:00',
        value: 400,
      },
      {
        starttime: '12:00',
        endtime: '18:00',
        value: -200,
      },
      {
        starttime: '18:00',
        endtime: '20:00',
        value: 300,
      },
      {
        starttime: '20:00',
        endtime: '24:00',
        value: 500,
      },
    ]
    this.dealarr(apidata)
	this.echartsdraw()
},
methods:{
	//数据处理
	dealarr(apidata) {
      let yaxis = []
      apidata.foreach((element) => {
      let dealarr = new array(
        element.endtime == '24:00' ? 25 : parseint(element.endtime) + 1
      ).fill(number(element.value))
      let yitem = {
        name: ' ',
        type: 'line',
        showsymbol: false,
        endlabel: {
          show: true,
          formatter: '{c}',
          position: 'start',
          fontsize: 12,
        },
        linestyle: {
          width: 10,
          color: '#36cfc9',
        },
        data: dealarr.fill('', 0, parseint(element.starttime)),
      }
      yaxis.push(yitem)
    })
    this.yaxis = yaxis
    },
    //图表绘制
	echartsdraw(){
	 let charts = echarts.init(this.$refs.strategydomref)
            let option = {
        tooltip: {
          trigger: 'axis',
          formatter: function (params) {
            return '<br/> 功率 : ' + params[0].value
          },
        },
        grid: {
          top: '10%',
          left: '3%',
          right: '4%',
          bottom: '3%',
          containlabel: true,
        },
        xaxis: {
          type: 'category',
          boundarygap: false,
          splitline: {
            // 网格线
            show: true,
            linestyle: {
              //分割线
              color: '#c0c4cc',
              width: 1,
              type: 'dashed', //dotted:虚线 solid:实线
            },
          },
          axislabel: {
            padding: [0, 0, 0, -20], // 四个数字分别为上右下左与原位置距离
          },
          data: [
            '00:00',
            '01:00',
            '02:00',
            '03:00',
            '04:00',
            '05:00',
            '06:00',
            '07:00',
            '08:00',
            '09:00',
            '10:00',
            '11:00',
            '12:00',
            '13:00',
            '14:00',
            '15:00',
            '16:00',
            '17:00',
            '18:00',
            '19:00',
            '20:00',
            '21:00',
            '22:00',
            '23:00',
            '24:00',
          ],
        },
        yaxis: {
          type: 'value',
          name: '单位(kw)',
          splitline: {
            // 网格线
            show: true,
            linestyle: {
              //分割线
              color: '#c0c4cc',
              width: 1,
              type: 'dashed', //dotted:虚线 solid:实线
            },
          },
          axislabel: {
            formatter: '{value}',
          },
        },
        series: this.yaxis,
      }
      charts.setoption(option, true)
      //清空画布,防止缓存
      charts.clear()
      //使用刚指定的配置项和数据显示图表。
      charts.setoption(option, true)
      window.addeventlistener('resize', function () {
        charts.resize()
      })
	}
}

到此这篇关于vue echarts绘制甘特图的示例代码的文章就介绍到这了,更多相关vue echarts甘特图内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com