甘特图
手动封装简版甘特图,纯展示功能,无其他操作
文章目录
- 甘特图
- 前言
- 效果图
- 组件
- 使用
- 总结
前言
开始的思路是使用echarts 瀑布图来体现,但是试验后发现,头部时间功能不满足,然未找到其他组件,于是手动封装一个,比较简陋,凑乎看。
echarts效果
效果图
组件
<template><div class="gantt_chart"><ul class="title" :style="{height}"><li v-for="i in 24" :key="i"><p class="title_font">{{ i.toString().length == 1 ? `0${i}` : i }}</p><p class="title_node"></p></li></ul><div class="gantt_chart_columns" v-for="v,i in chartData" :key="i" :style="{height}"><p class="time_value" :style="{width:getWidth(v),left:getLeft(v)}"></p></div></div></template><script setup>import {computed,toRefs } from 'vue';let props = defineProps({chartData:{type:Object,default:() => {return []}},height:{type:String,default:() => {return ''}}
})const { chartData } = toRefs(props);const getWidth = computed(() =>{return function (val) {if (val.length == 2) {if (val[0] > val[1]) {let num = ((val[0] - val[1]) / 24 * 100).toString() + '%'return num} else {let num = ((val[1] - val[0]) / 24 * 100).toString() + '%'return num}}}})const getLeft = computed(() =>{return function (val) {if (val.length == 2) {if (val[0] > val[1]) {let num = (val[1] / 24 * 100).toString() + '%'return num} else {let num = (val[0] / 24 * 100).toString() + '%'return num}}}
})</script>
<style scoped lang="scss">.gantt_chart{width: 100%;height: 100%;border: 1px solid #2e5c80;overflow: auto;.title{width: 100%;// height: 16.6666%;overflow: hidden;display: flex;justify-content: space-evenly;overflow: hidden;border-bottom: 1px solid #2e5c80;margin: 0;padding: 0;li {width: 4%;position: relative;text-align: center;list-style:none;box-sizing: border-box;}.title_font {display: inline-block;height: 22px;margin: 0;position: absolute;left: 50%;top: 50%;transform: translate(-50%, -50%);}.title_node {width: 1px;height: 10px;margin: 0;background: #1ea9fa;position: absolute;left: 50%;bottom: 0;transform: translateX(-50%);}}.gantt_chart_columns {width: 100%;// height: 16.6666%;overflow: hidden;border-bottom: 1px solid #2e5c80;.time_value {height: 50%;position: relative;top: 50%;transform: translateY(-50%);margin: 0;background-color: #00ccff;}}.gantt_chart_columns:last-child {border-bottom:none;}}
</style>
使用
import GanttChart from '@/components/GanttChart.vue';<GanttChart style="width:50%;height:30%; margin-top: 1.1%;" :chartData="chartData" height="16.3%"/>import { ref } from 'vue';
let chartData = ref([[1.2,16.4],[5.5,10.8],[1,6.2],[5.2,9],[8.3,10.8],
])
总结
简单使用,至于数据需要处理后传入
感谢各位大佬观看