Vue3使用echarts树图(tree)

Vue2使用echarts树图(tree)

本文使用echarts版本:v5.4.2

参考文档:Documentation - Apache ECharts

可自定义设置以下属性:

  • 树图数据源(treeData),类型:object,默认 {}

  • 容器宽度(width),类型:string|number,默认 '100%'

  • 容器高度(height),类型:string|number,默认 '100%'

效果如下图:在线预览

 

 ①安装echarts:yarn add echarts

②创建树图组件TreeChart.vue:

<script setup lang="ts">
import { ref, onMounted, computed } from 'vue'
// 使用 ECharts 提供的按需引入的接口来打包必须的组件
// 引入 echarts 核心模块,核心模块提供了 echarts 使用必须要的接口
import * as echarts from 'echarts/core'
// 引入树图图表,图表后缀都为 Chart
import { TreeChart } from 'echarts/charts'
// 引入提示框,组件后缀都为 Component
import { TooltipComponent } from 'echarts/components'
// 引入 Canvas 渲染器,注意引入 CanvasRenderer 或者 SVGRenderer 是必须的一步
import { CanvasRenderer } from 'echarts/renderers'
// 注册必须的组件
echarts.use([TreeChart, TooltipComponent, CanvasRenderer])
/*
  需要注意的是为了保证打包的体积是最小的,ECharts 按需引入的时候不再提供任何渲染器,
  所以需要选择引入 CanvasRenderer 或者 SVGRenderer 作为渲染器。这样的好处是假如
  你只需要使用 svg 渲染模式,打包的结果中就不会再包含无需使用的 CanvasRenderer 模块
*/
const chart = ref()
const treeChart = ref()
var option

interface Props {
  treeData: object // 树图数据源
  width?: string|number // 容器宽度
  height?: string|number // 容器高度
}
const props = withDefaults(defineProps<Props>(), {
  treeData: () => { return {} },
  width: '100%',
  height: '100%'
})
const chartWidth = computed(() => {
  if (typeof props.width === 'number') {
    return props.width + 'px'
  } else {
    return props.width
  }
})
const chartHeight = computed(() => {
  if (typeof props.height === 'number') {
    return props.height + 'px'
  } else {
    return props.height
  }
})
onMounted(() => {
  initChart() // 初始化图标示例
  // 监听树图节点的点击事件
  treeChart.value.on('click', onClick)
})
const emit = defineEmits(['clickNode'])
function onClick (e: any) {
  emit('clickNode', e.data)
}
function initChart () {
  // 等价于使用 Canvas 渲染器(默认):echarts.init(containerDom, null, { renderer: 'canvas' })
  treeChart.value = echarts.init(chart.value)
  option = {
    tooltip: { // 提示框浮层设置
      trigger: 'item',
      triggerOn: 'mousemove', // 提示框触发条件
      enterable: true, // 鼠标是否可进入提示框浮层中,默认false
      confine: true, // 是否将tooltip框限制在图表的区域内
      formatter: function (params: any) { // 提示框浮层内容格式器,支持字符串模板和回调函数两种形式
        // console.log('params:', params)
        return params.marker + params.name + '<br/>' + '$ ' + (params.value || '--')
      },
      // valueFormatter: function (value) { // tooltip 中数值显示部分的格式化回调函数
      //   return '$' + value.toFixed(2)
      // },
      backgroundColor: '#FFF', // 提示框浮层的背景颜色
      borderColor: '#1890FF', // 提示框浮层的边框颜色
      borderWidth: 1, // 提示框浮层的边框宽
      borderRadius: 8, // 提示框浮层圆角
      padding: [6, 8], // 提示框浮层的内边距
      textStyle: { // 提示框浮层的文本样式
        color: '#333', // 文字颜色
        fontWeight: 400, // 字体粗细
        fontSize: 16, // 字体大小
        lineHeight: 20, // 行高
        width: 60, // 文本显示宽度
        // 文字超出宽度是否截断或者换行;只有配置width时有效
        overflow: 'breakAll', // truncate截断,并在末尾显示ellipsis配置的文本,默认为...;break换行;breakAll换行,并强制单词内换行
        ellipsis: '...'
      },
      extraCssText: 'box-shadow: 0 0 9px rgba(0, 0, 0, 0.3); text-align: right;' // 额外添加到浮层的css样式
    },
    series: [
      {
        type: 'tree',
        data: [props.treeData],
        name: '树图',
        top: '1%', // 组件离容器上侧的距离,像素值20,或相对容器的百分比20%
        left: '7%', // 组件离容器左侧的距离
        bottom: '1%', // 组件离容器下侧的距离
        right: '20%', // 组件离容器右侧的距离
        layout: 'orthogonal', // 树图的布局,正交orthogonal和径向radial两种
        orient: 'LR', // 树图中正交布局的方向,'LR','RL','TB','BT',只有布局是正交时才生效
        edgeShape: 'curve', // 树图边的形状,有曲线curve和折线polyline两种,只有正交布局下生效
        roam: false, // 是否开启鼠标缩放或平移,默认false
        initialTreeDepth: 2, // 树图初始的展开层级(深度),根节点是0,不设置时全部展开
        // symbol: 'arrow', // 标记的图形,默认是emptyCircle;circle,rect,roundRect,triangle,diamond,pin,arrow,none
        // symbolRotate: 270, // 配合arrow图形使用效果较好
        symbolSize: 16, // 大于0时是圆圈,等于0时不展示,标记的大小
        itemStyle: { // 树图中每个节点的样式
          color: '#1890FF', // 节点未展开时的填充色
          borderColor: 'rgba(255, 144, 0, 1)', // 图形的描边颜色
          borderWidth: 1, // 描边线宽,为0时无描边
          borderType: 'dotted', // 描边类型
          borderCap: 'square', // 指定线段末端的绘制方式butt方形结束,round圆形结束,square
          shadowColor: 'rgba(0,121,221,0.3)', // 阴影颜色
          shadowBlur: 16, // 图形阴影的模糊大小
          opacity: 1 // 图形透明度
        },
        label: { // 每个节点对应的文本标签样式
          show: true, // 是否显示标签
          distance: 8, // 文本距离图形元素的距离
          position: 'left', // 标签位置
          verticalAlign: 'middle', // 文字垂直对齐方式,默认自动,top,middle,bottom
          align: 'center', // 文字水平对齐方式,默认自动,left,right,center
          fontSize: 16, // 字体大小
          color: '#333', // 字体颜色
          backgroundColor: '#F0F5FA', // 文字块的背景颜色
          borderColor: '#1890FF', // 文字块边框颜色
          borderWidth: 1, // 文字块边框宽度
          borderType: 'solid', // 文字块边框描边类型 solid dashed dotted
          borderRadius: 4, // 文字块的圆角
          padding: [6, 12], // 文字块内边距
          shadowColor: 'rgba(0,121,221,0.3)', // 文字块的背景阴影颜色
          shadowBlur: 6, // 文字块的背景阴影长度
          width: 60,
          // 文字超出宽度是否截断或者换行;只有配置width时有效
          overflow: 'truncate', // truncate截断,并在末尾显示ellipsis配置的文本,默认为...;break换行;breakAll换行,并强制单词内换行
          ellipsis: '...'
        },
        lineStyle: { // 树图边的样式
          color: 'rgba(0,0,0,.35)', // 树图边的颜色
          width: 2, // 树图边的宽度
          curveness: 0.5, // 树图边的曲度
          shadowColor: 'rgba(0, 0, 0, 0.5)', // 阴影颜色
          shadowBlur: 10 // 图形阴影的模糊大小
        },
        emphasis: { // 树图中图形和标签高亮的样式
          disabled: false, // 是否关闭高亮状态,默认false
          // 在高亮图形时,是否淡出其它数据的图形已达到聚焦的效果
          focus: 'self', // none不淡出其他图形(默认);self只聚焦当前高亮的数据图形;series聚焦当前高亮的数据所在系列的所有图形;ancestor聚焦所有祖先节点;descendant聚焦所有子孙节点;relative聚焦所有子孙和祖先节点
          blurScope: 'coordinateSystem', // 开启focus时,配置淡出的范围,coordinateSystem淡出范围为坐标系(默认);series淡出范围为系列;global淡出范围为全局
          itemStyle: { // 该节点的样式
            color: '#1890FF', // 图形的颜色
            // borderColor: 'rgba(255, 144, 0, 1)', // 图形的描边颜色
            borderWidth: 1, // 描边线宽,为0时无描边
            borderType: 'solid', // 描边类型 solid dashed dotted
            borderCap: 'square', // 指定线段末端的绘制方式butt方形结束,round圆形结束,square
            shadowColor: 'rgba(0,121,221,0.3)', // 阴影颜色
            shadowBlur: 12, // 图形阴影的模糊大小
            opacity: 1 // 图形透明度
          },
          lineStyle: { // 树图边的样式
            color: 'rgba(0,0,0,.45)', // 树图边的颜色
            width: 2, // 树图边的宽度
            curveness: 0.5, // 树图边的曲度
            shadowColor: 'rgba(0, 0, 0, 0.5)', // 阴影颜色
            shadowBlur: 6 // 图形阴影的模糊大小
          },
          label: { // 高亮标签的文本样式
            color: '#333',
            fontWeight: 600
          }
        },
        blur: { // 淡出状态的相关配置,开启emphasis.focus后有效
          itemStyle: {}, // 节点的样式
          lineStyle: {}, // 树图边的样式
          label: {} // 淡出标签的文本样式
        },
        leaves: { // 叶子节点的特殊配置
          label: { // 叶子节点的文本标签样式
            distance: 8,
            // color: '#1890FF',
            position: 'right',
            verticalAlign: 'middle',
            align: 'left'
          },
          itemStyle: {}, // 叶子节点的样式
          emphasis: {}, // 叶子节点高亮状态的配置
          blur: {}, // 叶子节点淡出状态的配置
          select: {} // 叶子节点选中状态的配置
        },
        animation: true, // 是否开启动画
        expandAndCollapse: true, // 子树折叠和展开的交互,默认打开
        animationDuration: 550, // 初始动画的时长
        animationEasing: 'linear', // 初始动画的缓动效果
        animationDelay: 0, // 初始动画的延迟
        animationDurationUpdate: 750, // 数据更新动画的时长
        animationEasingUpdate: 'cubicInOut', // 数据更新动画的缓动效果
        animationDelayUpdate: 0 // 数据更新动画的延迟
      }
    ]
  }
  option && treeChart.value.setOption(option)
}
</script>
<template>
  <div ref="chart" :style="`width: ${chartWidth}; height: ${chartHeight};`"></div>
</template>

③在要使用的页面引入: 

<script setup lang="ts">
import TreeChart from './TreeChart.vue'
import { ref } from 'vue'
const treeData = ref({
  name: 'tree',
  children: [
    {
      name: '比较',
      value: 29,
      children: [
        {
          name: '折线图',
          value: 1
        },
        {
          name: '面积图',
          value: 2
        },
        {
          name: '柱状图',
          value: 3
        }
      ]
    },
    {
      name: '趋势趋势趋势趋势趋势趋势趋势趋势趋势趋势',
      value: 9,
      children: [
        {
          name: '折线图',
          value: 1
        },
        {
          name: '阶梯图',
          value: 2
        },
        {
          name: '面积图',
          value: 3
        },
        {
          name: '堆叠面积图',
          value: 4
        }
      ]
    },
    {
      name: '组成'
    }
  ]
})
function onClickNode (data: any) {
  console.log('data:', data)
}
</script>
<template>
  <div>
    <h1>TreeChart 参考文档</h1>
    <ul class="m-list">
      <li>
        <a class="u-file" href="https://echarts.apache.org/handbook/zh/get-started" target="_blank">使用手册</a>
      </li>
      <li>
        <a class="u-file" href="https://echarts.apache.org/handbook/zh/basics/import" target="_blank">在项目中引入 ECharts</a>
      </li>
      <li>
        <a class="u-file" href="https://echarts.apache.org/zh/option.html#series-tree.type" target="_blank">tree 配置项</a>
      </li>
      <li>
        <a class="u-file" href="https://echarts.apache.org/zh/builder.html" target="_blank">ECharts 在线定制</a>
      </li>
    </ul>
    <TreeChart
      :treeData="treeData"
      :height="500"
      @click-node="onClickNode" />
  </div>
</template>
<style lang="less" scoped>
</style>
  • 4
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在 Vue使用 echarts ,你需要先安装 echarts。 可以使用 npm 安装 echarts: ``` npm install echarts --save ``` 安装完成后,你可以在 Vue 组件中引入 echarts: ```javascript import echarts from 'echarts' ``` 然后,在 Vue使用 echarts ,你可以按照以下步骤: 1. 在模板中添加一个 div 容器,用于显示 echarts : ```html <template> <div ref="chart" style="width: 100%; height: 400px;"></div> </template> ``` 2. 在 Vue 组件的 mounted 钩子中初始化 echarts 实例,并配置的数据和样式: ```javascript mounted() { // 基于准备好的dom,初始化echarts实例 const myChart = echarts.init(this.$refs.chart); // 配置的数据和样式 const option = { tooltip: { trigger: 'item', triggerOn: 'mousemove' }, series: [ { type: 'tree', data: [ { name: '节点1', children: [ { name: '节点1.1', children: [ { name: '节点1.1.1' }, { name: '节点1.1.2' } ] }, { name: '节点1.2', children: [ { name: '节点1.2.1' } ] } ] } ], top: '1%', left: '7%', bottom: '1%', right: '20%', symbolSize: 7, label: { position: 'left', verticalAlign: 'middle', align: 'right', fontSize: 9 }, leaves: { label: { position: 'right', verticalAlign: 'middle', align: 'left' } }, expandAndCollapse: true, animationDuration: 550, animationDurationUpdate: 750 } ] }; // 使用刚指定的配置项和数据显示表。 myChart.setOption(option); } ``` 这样,你就可以在 Vue使用 echarts 了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值