欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用vis-timeline繪制甘特圖并實(shí)現(xiàn)時(shí)間軸的中文化(案例代碼)

 更新時(shí)間:2023年02月16日 15:06:32   作者:從不講道理  
這篇文章主要介紹了使用vis-timeline繪制甘特圖并實(shí)現(xiàn)時(shí)間軸的中文化(案例代碼),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

使用vis-timeline繪制甘特圖并實(shí)現(xiàn)時(shí)間軸的中文化

最終實(shí)現(xiàn)效果

在這里插入圖片描述

安裝vis-timeline及相關(guān)依賴包

cnpm install -S vis-linetime
cnpm install -S vis-data
cnpm install -S moment

在這里插入圖片描述

組件中引入使用

// 國際化時(shí)間軸時(shí)必選在先引入moment在引入vis相關(guān)依賴包
const moment = require('moment')
import { DataSet } from 'vis-data/peer'
import { Timeline } from 'vis-timeline/peer'
import 'vis-timeline/styles/vis-timeline-graph2d.css'

visGantt組件

<template>
  <div class="visGantt" id="visualization"></div>
</template>

<script>
const moment = require('moment')
import { DataSet } from 'vis-data/peer'
import { Timeline } from 'vis-timeline/peer'
import 'vis-timeline/styles/vis-timeline-graph2d.css'
export default {
  name: 'VisGantt',
  props: {
    ganntData: {
      type: Object,
      default: () => {}
    }
  },
  data() {
    return {
      timeline: null
    }
  },
  computed: {
    startTime() {
      return this.$store.state.startTime
    },
    endTime() {
      return this.$store.state.endTime
    }
  },
  watch: {
    ganntData: {
      deep: true,
      immediate: true,
      handler(newVal) {
        if (newVal && newVal.trackTimeWindows && newVal.trackTimeWindows.length > 0) {
          this.$nextTick(() => {
            this.initChart()
          })
        }
      }
    }
  },
  beforeDestroy() {
    this.timeline.destroy()
    this.timeline = null
  },
  methods: {
    computedData() {
      const trackTimeWindows = []
      const timeWindows = []
      this.ganntData.trackTimeWindows.forEach(
        (trackTimeWindow, trackTimeWindowIndex) => {
          trackTimeWindows.push({
            content: trackTimeWindow.deviceId,
            id: `${trackTimeWindow.deviceId}-${trackTimeWindowIndex}-trackTimeWindows`,
            value: trackTimeWindowIndex + 1,
            className: `visGantt-item${trackTimeWindowIndex % 10}`
          })
          trackTimeWindow.timeWindows.forEach((timeWindow, timeWindowIndex) => {
            timeWindows.push({
              start: new Date(timeWindow.startTime),
              startTime: timeWindow.startTime,
              end: new Date(timeWindow.stopTime),
              stopTime: timeWindow.stopTime,
              topTime: timeWindow.topTime,
              group: `${trackTimeWindow.deviceId}-${trackTimeWindowIndex}-trackTimeWindows`,
              className: `visGantt-item${trackTimeWindowIndex % 10}`,
              id: `${trackTimeWindow.deviceId}-${timeWindowIndex}-timeWindows`,
              deviceId: trackTimeWindow.deviceId
            })
          })
        }
      )
      return {
        trackTimeWindows,
        timeWindows
      }
    },
    initChart() {
      const { timeWindows, trackTimeWindows } = this.computedData()
      const groups = new DataSet(trackTimeWindows)
      const items = new DataSet(timeWindows)
      const container = document.getElementById('visualization')
      const options = {
        groupOrder: function(a, b) {
          return a.value - b.value
        },
        groupOrderSwap: function(a, b, groups) {
          var v = a.value
          a.value = b.value
          b.value = v
        },
        height: '300px', // 高度
        verticalScroll: true, // 豎向滾動(dòng)
        orientation: 'top', // 時(shí)間軸位置
        editable: false,
        groupEditable: false,
        min: new Date(this.startTime), // 最小可見范圍
        max: new Date(this.endTime), // 最大可見范圍
        tooltip: {
          followMouse: true,
          template: (originalItemData, parsedItemData) => {
            return `<div>
              <p>
                <span>設(shè)備名稱:</span>
                <span>${originalItemData.deviceId}</span>
              </p><br/>
              <p>
                <span>開始時(shí)間:</span>
                <span>${originalItemData.startTime}</span>
              </p><br/>
              <p>
                <span>頂點(diǎn)時(shí)間:</span>
                <span>${originalItemData.topTime}</span>
              </p><br/>
              <p>
                <span>結(jié)束時(shí)間:</span>
                <span>${originalItemData.stopTime}</span>
              </p>
            </div>`
          }
        },
        locale: moment.locale('zh-cn')  // 時(shí)間軸國際化
      }
      this.timeline = new Timeline(container)
      this.timeline.setOptions(options)
      this.timeline.setGroups(groups)
      this.timeline.setItems(items)
    }
  }
}
</script>
<style lang="less" scoped>
/deep/ .vis-item {
  &.visGantt-item0 {
    background-color: #b0e2ff;
  }
  &.visGantt-item1 {
    background-color: #4B7CF3;
  }
  &.visGantt-item2 {
    background-color: #cb7bf4;
  }
  &.visGantt-item3 {
    background-color: #2acd72;
  }
  &.visGantt-item4 {
    background-color: #f5cb29;
  }
  &.visGantt-item5 {
    background-color: #fc4354;
  }
  &.visGantt-item6 {
    background-color: #0DC3FD;
  }
  &.visGantt-item7 {
    background-color: #4962FC;
  }
  &.visGantt-item8 {
    background-color: #12E78C;
  }
  &.visGantt-item9 {
    background-color: #ff458c;
  }
}
</style>

visgantt組件調(diào)用

<visGantt :ganntData="ganttData"></visGannt>

ganttData數(shù)據(jù)結(jié)構(gòu)

const ganttData = [
  {
    norad: '11',
    name: 'test',
    trackTimeWindows: [
      {
        deviceId: '1',
        norad: '11',
        timeWindows: []
      },
      {
        deviceId: '2',
        norad: '11',
        timeWindows: [
          {
            startTime: '2021-12-27 01:08:52.078',
            topTime: '2021-12-27 01:16:33.890',
            stopTime: '2021-12-27 01:25:39.348'
          },
          {
            startTime: '2021-12-27 02:58:23.369',
            topTime: '2021-12-27 03:06:43.634',
            stopTime: '2021-12-27 03:16:40.093'
          },
          {
            startTime: '2021-12-27 04:51:49.123',
            topTime: '2021-12-27 04:59:29.729',
            stopTime: '2021-12-27 05:07:35.948'
          },
          {
            startTime: '2021-12-27 06:46:29.836',
            topTime: '2021-12-27 06:52:31.410',
            stopTime: '2021-12-27 07:00:44.944'
          },
          {
            startTime: '2021-12-27 08:38:38.974',
            topTime: '2021-12-27 08:46:32.009',
            stopTime: '2021-12-27 08:56:08.154'
          },
          {
            startTime: '2021-12-27 10:29:15.739',
            topTime: '2021-12-27 10:38:46.837',
            stopTime: '2021-12-27 10:49:21.807'
          },
          {
            startTime: '2021-12-27 12:20:19.620',
            topTime: '2021-12-27 12:28:32.563',
            stopTime: '2021-12-27 12:38:19.473'
          }
        ]
      },
      {
        deviceId: '3',
        norad: '11',
        timeWindows: [
          {
            startTime: '2021-12-27 01:15:23.202',
            topTime: '2021-12-27 01:23:35.571',
            stopTime: '2021-12-27 01:33:29.289'
          },
          {
            startTime: '2021-12-27 03:08:37.247',
            topTime: '2021-12-27 03:16:30.791',
            stopTime: '2021-12-27 03:25:29.077'
          },
          {
            startTime: '2021-12-27 05:01:16.372',
            topTime: '2021-12-27 05:09:31.747',
            stopTime: '2021-12-27 05:19:10.258'
          },
          {
            startTime: '2021-12-27 06:52:23.550',
            topTime: '2021-12-27 07:01:40.460',
            stopTime: '2021-12-27 07:12:14.800'
          },
          {
            startTime: '2021-12-27 08:43:09.779',
            topTime: '2021-12-27 08:52:29.847',
            stopTime: '2021-12-27 09:02:14.450'
          },
          {
            startTime: '2021-12-27 10:36:05.721',
            topTime: '2021-12-27 10:40:30.733',
            stopTime: '2021-12-27 10:46:36.962'
          },
          {
            startTime: '2021-12-27 20:50:54.626',
            topTime: '2021-12-27 20:54:30.970',
            stopTime: '2021-12-27 20:59:47.993'
          },
          {
            startTime: '2021-12-27 22:35:23.180',
            topTime: '2021-12-27 22:43:34.324',
            stopTime: '2021-12-27 22:52:55.141'
          }
        ]
      },
      {
        deviceId: '4',
        norad: '11',
        timeWindows: [
          {
            startTime: '2021-12-27 01:10:24.156',
            topTime: '2021-12-27 01:18:41.379',
            stopTime: '2021-12-27 01:28:32.674'
          },
          {
            startTime: '2021-12-27 03:04:19.430',
            topTime: '2021-12-27 03:11:29.859',
            stopTime: '2021-12-27 03:19:08.712'
          },
          {
            startTime: '2021-12-27 05:00:02.244',
            topTime: '2021-12-27 05:05:30.335',
            stopTime: '2021-12-27 05:12:02.853'
          },
          {
            startTime: '2021-12-27 06:52:18.641',
            topTime: '2021-12-27 06:59:31.398',
            stopTime: '2021-12-27 07:08:27.886'
          },
          {
            startTime: '2021-12-27 08:42:43.928',
            topTime: '2021-12-27 08:52:29.816',
            stopTime: '2021-12-27 09:02:39.878'
          },
          {
            startTime: '2021-12-27 10:33:37.149',
            topTime: '2021-12-27 10:42:31.607',
            stopTime: '2021-12-27 10:52:20.241'
          },
          {
            startTime: '2021-12-27 22:32:58.494',
            topTime: '2021-12-27 22:39:31.527',
            stopTime: '2021-12-27 22:47:20.576'
          }
        ]
      },
      {
        deviceId: '5',
        norad: '11',
        timeWindows: [
          {
            startTime: '2021-12-27 01:09:12.876',
            topTime: '2021-12-27 01:17:37.260',
            stopTime: '2021-12-27 01:27:14.041'
          },
          {
            startTime: '2021-12-27 03:03:39.186',
            topTime: '2021-12-27 03:09:31.323',
            stopTime: '2021-12-27 03:17:19.877'
          },
          {
            startTime: '2021-12-27 05:01:11.549',
            topTime: '2021-12-27 05:04:30.401',
            stopTime: '2021-12-27 05:09:12.335'
          },
          {
            startTime: '2021-12-27 06:53:22.576',
            topTime: '2021-12-27 06:59:30.808',
            stopTime: '2021-12-27 07:07:12.153'
          },
          {
            startTime: '2021-12-27 08:43:22.844',
            topTime: '2021-12-27 08:52:33.154',
            stopTime: '2021-12-27 09:02:50.568'
          },
          {
            startTime: '2021-12-27 10:33:59.368',
            topTime: '2021-12-27 10:43:30.340',
            stopTime: '2021-12-27 10:53:26.558'
          },
          {
            startTime: '2021-12-27 12:29:03.756',
            topTime: '2021-12-27 12:32:29.993',
            stopTime: '2021-12-27 12:36:16.023'
          },
          {
            startTime: '2021-12-27 22:32:03.275',
            topTime: '2021-12-27 22:38:30.839',
            stopTime: '2021-12-27 22:45:49.477'
          }
        ]
      },
      {
        deviceId: '6',
        norad: '11',
        timeWindows: [
          {
            startTime: '2021-12-27 01:06:14.969',
            topTime: '2021-12-27 01:13:31.700',
            stopTime: '2021-12-27 01:21:58.220'
          },
          {
            startTime: '2021-12-27 08:48:54.328',
            topTime: '2021-12-27 08:56:31.731',
            stopTime: '2021-12-27 09:05:48.776'
          },
          {
            startTime: '2021-12-27 10:38:08.985',
            topTime: '2021-12-27 10:47:48.913',
            stopTime: '2021-12-27 10:58:29.609'
          },
          {
            startTime: '2021-12-27 12:32:19.706',
            topTime: '2021-12-27 12:37:30.557',
            stopTime: '2021-12-27 12:43:55.833'
          },
          {
            startTime: '2021-12-27 22:26:18.655',
            topTime: '2021-12-27 22:33:33.141',
            stopTime: '2021-12-27 22:42:05.879'
          }
        ]
      },
      {
        deviceId: '7',
        norad: '11',
        timeWindows: [
          {
            startTime: '2021-12-27 01:11:47.926',
            topTime: '2021-12-27 01:19:33.909',
            stopTime: '2021-12-27 01:29:01.687'
          },
          {
            startTime: '2021-12-27 03:07:21.243',
            topTime: '2021-12-27 03:12:31.043',
            stopTime: '2021-12-27 03:19:40.506'
          },
          {
            startTime: '2021-12-27 05:02:51.128',
            topTime: '2021-12-27 05:07:30.785',
            stopTime: '2021-12-27 05:14:03.538'
          },
          {
            startTime: '2021-12-27 06:53:57.067',
            topTime: '2021-12-27 07:01:32.228',
            stopTime: '2021-12-27 07:11:08.049'
          },
          {
            startTime: '2021-12-27 08:44:11.019',
            topTime: '2021-12-27 08:53:53.826',
            stopTime: '2021-12-27 09:04:24.510'
          },
          {
            startTime: '2021-12-27 10:35:37.826',
            topTime: '2021-12-27 10:43:31.288',
            stopTime: '2021-12-27 10:52:38.118'
          },
          {
            startTime: '2021-12-27 22:31:58.385',
            topTime: '2021-12-27 22:39:34.323',
            stopTime: '2021-12-27 22:48:38.986'
          }
        ]
      },
      {
        deviceId: '8',
        norad: '11',
        timeWindows: [
          {
            startTime: '2021-12-27 01:23:58.104',
            topTime: '2021-12-27 01:27:59.422',
            stopTime: '2021-12-27 01:32:00.740'
          },
          {
            startTime: '2021-12-27 03:16:02.997',
            topTime: '2021-12-27 03:19:44.654',
            stopTime: '2021-12-27 03:23:26.310'
          },
          {
            startTime: '2021-12-27 05:06:53.787',
            topTime: '2021-12-27 05:07:38.631',
            stopTime: '2021-12-27 05:13:32.618'
          },
          {
            startTime: '2021-12-27 06:58:19.500',
            topTime: '2021-12-27 06:59:38.674',
            stopTime: '2021-12-27 07:01:43.165'
          },
          {
            startTime: '2021-12-27 22:48:25.157',
            topTime: '2021-12-27 22:49:49.709',
            stopTime: '2021-12-27 22:51:14.261'
          }
        ]
      },
      {
        deviceId: '9',
        norad: '11',
        timeWindows: []
      }
    ]
  }
]

到此這篇關(guān)于使用vis-timeline繪制甘特圖并實(shí)現(xiàn)時(shí)間軸的中文化的文章就介紹到這了,更多相關(guān)vis-timeline繪制甘特圖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue實(shí)現(xiàn)登錄頁背景粒子特效

    vue實(shí)現(xiàn)登錄頁背景粒子特效

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)登錄頁背景粒子特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • nuxt 自定義 auth 中間件實(shí)現(xiàn)令牌的持久化操作

    nuxt 自定義 auth 中間件實(shí)現(xiàn)令牌的持久化操作

    這篇文章主要介紹了nuxt 自定義 auth 中間件實(shí)現(xiàn)令牌的持久化操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • vue自定義鍵盤實(shí)現(xiàn)車牌號(hào)的示例代碼

    vue自定義鍵盤實(shí)現(xiàn)車牌號(hào)的示例代碼

    本文主要介紹了vue自定義鍵盤實(shí)現(xiàn)車牌號(hào)的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • Vue無限滑動(dòng)周選擇日期的組件的示例代碼

    Vue無限滑動(dòng)周選擇日期的組件的示例代碼

    這篇文章主要介紹了Vue無限滑動(dòng)周選擇日期的組件的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-07-07
  • Vue設(shè)置提示和警告彈出框?qū)崙?zhàn)案例

    Vue設(shè)置提示和警告彈出框?qū)崙?zhàn)案例

    頁面中會(huì)有很多時(shí)候需要彈窗提示,下面這篇文章主要給大家介紹了關(guān)于Vue設(shè)置提示和警告彈出框的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-02-02
  • 基于Vue2.X的路由和鉤子函數(shù)詳解

    基于Vue2.X的路由和鉤子函數(shù)詳解

    下面小編就為大家分享一篇基于Vue2.X的路由和鉤子函數(shù)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • Vue的route-view子頁面調(diào)用父頁面的函數(shù)詳解

    Vue的route-view子頁面調(diào)用父頁面的函數(shù)詳解

    這篇文章主要介紹了Vue的route-view子頁面調(diào)用父頁面的函數(shù)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 在Vue開發(fā)過程中解決和預(yù)防內(nèi)存泄漏問題的方法詳解

    在Vue開發(fā)過程中解決和預(yù)防內(nèi)存泄漏問題的方法詳解

    Vue作為一款流行的前端框架,已經(jīng)在許多項(xiàng)目中得到廣泛應(yīng)用,然而,隨著我們?cè)赩ue中構(gòu)建更大規(guī)模的應(yīng)用程序,我們可能會(huì)遇到一個(gè)嚴(yán)重的問題,那就是內(nèi)存泄漏,因此,我們需要認(rèn)識(shí)到在Vue開發(fā)過程中,內(nèi)存泄漏問題的重要性,本文將給大家介紹如何解決和預(yù)防內(nèi)存泄漏問題
    2023-10-10
  • Vue實(shí)現(xiàn)簡易購物車頁面

    Vue實(shí)現(xiàn)簡易購物車頁面

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)簡易購物車頁面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • 解決VUEX的mapState/...mapState等取值問題

    解決VUEX的mapState/...mapState等取值問題

    這篇文章主要介紹了解決VUEX的mapState/...mapState等取值問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07

最新評(píng)論