vue3使用echarts做树图tree

vue3使用echarts做树图tree

在这里插入图片描述

1.安装echarts

npm install echarts --save

2.在main.js引入

import * as echarts from 'echarts'
// 全局方法
app.config.globalProperties.$echarts = echarts

3.使用

<div id="myChart" :style="{ width: '1000px', height: '1000px' }"></div>
。。。
onMounted(() => {
    initTree();
})
const { proxy } = getCurrentInstance()
const initTree = () => {

    var myChart = proxy.$echarts.init(document.getElementById('myChart'));
    if (myChart != null && myChart != "" && myChart != undefined) {
        myChart.dispose(); //销毁
    }
    var myChart = proxy.$echarts.init(document.getElementById('myChart'))
    let src1 =
        "";
    let src3 =
        "";
    let src4 =
        "";
    let src5 =
        "";
    let src6 =
        "";
    var data2 = [
        {
            name: "深圳供电局",
            money: "800",
            label: {
                width: 180,
                height: 80,
                backgroundColor: {
                    image: src1,
                },
            },
            children: [
                {
                    //子集
                    name: "全资(2家)",
                    money: "800",
                    label: {
                        width: 111,
                        height: 54,
                        backgroundColor: {
                            image: src3,
                        },
                    },
                    children: [
                        {
                            //子集
                            name: "深圳产投",
                            percent: "1.43%",
                            money: "800",
                            label: {
                                width: 94,
                                height: 54,
                                backgroundColor: {
                                    image: src5,
                                },
                            },
                            children: [
                                {
                                    //子集
                                    name: "能源科技",
                                    percent: "1.43%",
                                    money: "800",
                                    label: {
                                        width: 94,
                                        height: 54,
                                        backgroundColor: {
                                            image: src5,
                                        },
                                    },
                                },
                            ],
                        },
                        {
                            //子集
                            name: "能源技术",
                            percent: "1.43%",
                            money: "800",
                            label: {
                                width: 94,
                                height: 54,
                                backgroundColor: {
                                    image: src5,
                                },
                            },
                        },
                    ],
                },
                {
                    name: "控股(1家)",
                    money: "800",
                    label: {
                        width: 111,
                        height: 54,
                        backgroundColor: {
                            image: src3,
                        },
                    },
                    children: [
                        {
                            //子集
                            name: "低碳城",
                            percent: "1.43%",
                            money: "800",
                            label: {
                                width: 94,
                                height: 54,
                                backgroundColor: {
                                    image: src4,
                                },
                            },
                        },
                    ],
                },
                {
                    name: "参股(6家)",
                    money: "800",
                    label: {
                        width: 111,
                        height: 54,
                        backgroundColor: {
                            image: src3,
                        },
                    },
                    children: [
                        {
                            name: "南网电动",
                            percent: "1.43%",
                            money: "800",
                            label: {
                                width: 94,
                                height: 54,
                                backgroundColor: {
                                    image: src5,
                                },
                            },
                        },
                        {
                            name: "科技开发",
                            percent: "1.43%",
                            money: "800",
                            label: {
                                width: 94,
                                height: 54,
                                backgroundColor: {
                                    image: src5,
                                },
                            },
                        },
                        {
                            name: "深研院",
                            percent: "1.43%",
                            money: "800",
                            label: {
                                width: 94,
                                height: 54,
                                backgroundColor: {
                                    image: src5,
                                },
                            },
                        },
                        {
                            name: "前海供电",
                            percent: "1.43%",
                            money: "800",
                            label: {
                                width: 94,
                                height: 54,
                                backgroundColor: {
                                    image: src4,
                                },
                            },
                        },
                        {
                            name: "南网财务",
                            percent: "1.43%",
                            money: "800",
                            label: {
                                width: 94,
                                height: 54,
                                backgroundColor: {
                                    image: src6,
                                },
                            },
                        },
                        {
                            name: "混改基金",
                            percent: "1.43%",
                            money: "800",
                            label: {
                                width: 94,
                                height: 54,
                                backgroundColor: {
                                    image: src6,
                                },
                            },
                        },
                    ],
                },
            ],
        },
    ];
    function searchSpotBg(type) {
        return type === 1
            ? "linear-gradient(-90deg, #0168CE, #27AFE0)"
            : type === 2
                ? "linear-gradient(-90deg, #008C4F, #44F093)"
                : "linear-gradient(270deg, #CB6000, #FFAB1A)";
    }
    var option = {
        tooltip: {
            show: "true",
            trigger: "item",
            formatter: function (params) {
                let data = params.data;
                let str = `  <div
    style="background:#333;display: flex;justify-content: space-between;color: #FFFFFF;line-height: 20px;">
    <div>
      <p>全称</p>
      <p>业务板块</p>
      <p>累计投资金额</p>
    </div>
    <div>
      <p>${data.fullName || "--"}</p>
      <p><span style="display:inline-block;margin-right:5px;width:10px;height:10px;background:${searchSpotBg(
                    data.type
                )}"></span>新兴业务</p>
      <p>${data.money || "--"}${data.cell || "万元"}</p>
    </div>
  </div>`;
                return str;
            },
        },
        series: [
            {
                type: "tree",
                orient: "vertical",
                name: "自然资源厅",
                edgeShape: "polyline", //链接线是折现还是曲线
                data: data2,
                width: 1100, //树形图宽
                height: 547, //树形图高
                top: "20%",
                left: "10%",
                symbolSize: [60, 38], //设置自己选择区域的宽高

                symbol: "rect", //子级选择区域的形状默认circle(圆形),rect矩形
                roam: true, //鼠标移到区块时会显示一个灰色背景的title,移动不同区域时是否开启滑动动画
                initialTreeDepth: 10,
                itemStyle: {
                    //symbol的样式
                    color: "#333",
                    borderColor: "#333",
                },
                label: {
                    normal: {
                        position: [30, 15],
                        verticalAlign: "middle",
                        align: "center",
                        backgroundColor: "#99d97c",
                        color: "#fff",
                        padding: 3,
                        formatter: function (params) {
                            let money = params.data.money ? "" + params.data.money : "";
                            let percent = params.data.percent ? params.data.percent : "";
                            let name =
                                params.name.substring(0, 11) + "\n" + params.name.substring(11);
                            let konggu = params.value ? params.value : "";
                            if (konggu) {
                                return [
                                    `{percent|${percent}}`,
                                    `{name|${name}}`,
                                    `{money|${money}}`,
                                ].join("\n");
                            } else {
                                return [
                                    `{konggu|${konggu}}`,
                                    `{percent|${percent}}`,
                                    `{name|${name}}`,
                                    `{money|${money}}`,
                                ].join("\n");
                            }
                        },
                        rich: {
                            percent: {
                                color: "#FFF",
                                padding: [-40, 0],
                                height: 18,
                                distance: 10,
                                align: "left",
                                verticalAlign: "top",
                                fontSize: 12,
                                borderWidth: 1,
                                fontWeight: "normal",
                            },
                            name: {
                                height: 18,
                                color: "#FFF",
                                padding: [2, 0],
                                align: "center",
                                fontSize: 12,
                            },
                            money: {
                                height: 18,
                                color: "#fff",
                                padding: [-20, 0],
                                align: "center",
                                fontSize: 12,
                                borderWidth: 2,
                                fontWeight: "normal",
                            },
                        },
                    },
                },
                leaves: {
                    label: {
                        normal: {
                            position: [30, 15],
                            verticalAlign: "middle",
                            align: "center",
                            backgroundColor: "#f3857c",
                            // formatter: ['{box|{b}}'].join('\n'),
                            // rich: {
                            //     box: {
                            //         height: 18,
                            //         color: '#fff',
                            //         padding: [20, 20],
                            //         align: 'center',
                            //     },
                            // },
                            formatter: function (params) {
                                console.log(params);
                                let money = params.data.money;
                                let percent = params.data.percent;
                                let name =
                                    params.name.substring(0, 11) + "\n" + params.name.substring(11);

                                return [
                                    `{percent|${percent}}`,
                                    `{name|${name}}`,
                                    `{money|${money}}`,
                                ].join("\n");
                            },
                            rich: {
                                percent: {
                                    color: "#FFF",
                                    padding: [-30, 0],
                                    height: 18,
                                    distance: 10,
                                    align: "left",
                                    verticalAlign: "top",
                                    fontSize: 12,
                                    borderWidth: 1,
                                    fontWeight: "normal",
                                },
                                name: {
                                    height: 22,
                                    color: "#FFF",
                                    padding: [13, 0, 0, 0],
                                    align: "center",
                                    fontSize: 12,
                                },
                                money: {
                                    height: 18,
                                    color: "#fff",
                                    padding: [-20, 0],
                                    align: "center",
                                    fontSize: 12,
                                    borderWidth: 2,
                                    fontWeight: "normal",
                                },
                            },
                        },
                    },
                },
                lineStyle: {
                    color: {
                        type: "linear",
                        x: 0,
                        y: 0,
                        x2: 0,
                        y2: 1,
                        colorStops: [
                            {
                                offset: 0,
                                color: "#0E769D", // 0% 处的颜色
                            },
                            {
                                offset: 1,
                                color: "#939597", // 100% 处的颜色
                            },
                        ],
                        global: false, // 缺省为 false
                    },
                },
                expandAndCollapse: true,
                animationDuration: 550,
                animationDurationUpdate: 750,
            },
        ],
    };

    // 使用刚指定的配置项和数据显示图表。
    myChart.setOption(option)
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/580706.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

如何设置“mumu模拟器”使用fiddler抓取APP包?

1、打开fiddler-->tools-->optinons,设置如下信息https信息和connections 2、下载证书tools-->optinons-->https-->actions->Export Root Certificate to Desktop到桌面 3、mumu模拟器&#xff0c;安装证书 1)mumu进入桌面有个文件共享&#xff0c;打开后将桌…

python—字符串与正则表达式

1、编写程序&#xff0c;生成一个由15个不重复的大小写字母组成的列表。 &#xff08;1&#xff09;源代码&#xff1a; import random import string list1 [] while len(list1) < 15: x random.choice(string.ascii_letters) if x not in list1: list1.append(x) print…

pycharm-ieda-phpstorm超级好用插件,一键解释代码

功能&#xff1a;解释你看不懂的代码 当你在写python和Java代码的时候&#xff0c;总有你看不懂的代码&#xff0c;怎么办&#xff1f;csdn搜&#xff1f;那不麻烦&#xff0c;直接插件解决。 来安装&#xff1a;文件-设置 点击插件-Marketplace-搜索通义灵码 安装完成后&…

Qt Creator中变量与函数的注释 - 鼠标悬浮可显示

Qt Creator中变量与函数的注释 - 鼠标悬浮可显示 引言一、变量注释二、函数注释三、参考链接 引言 代码注释在软件开发中起着至关重要的作用。它们不仅有助于开发者理解和维护代码&#xff0c;还能促进团队协作&#xff0c;提高代码的可读性和可维护性。适当的注释应该是简洁明…

VoxAtnNet:三维点云卷积神经网络

VoxAtnNet:三维点云卷积神经网络 摘要IntroductionProposed VoxAtnNet 3D Face PAD3D face point cloud presentation attack Dataset (3D-PCPA) VoxAtnNet: A 3D Point Clouds Convolutional Neural Network for 摘要 面部生物识别是智能手机确保可靠和可信任认证的重要组件。…

16册 | 移动机器人(自动驾驶)系列

此文档整理推荐了16本移动机器人&#xff08;自动驾驶&#xff09;相关的书籍&#xff0c;内容包括&#xff1a;ROS、机器人基础开发、分布式机器人控制、集群机器人控制、嵌入式机器人、多传感器融合等等。 学习&#xff0c;切勿急于求成&#xff0c;读书自学&#xff0c;需多…

栈和队列总结

文章目录 前言一、栈和队列的实现1.栈的具体实现2.循环顺序队列的具体实现 二、栈和队列总结总结 前言 T_T此专栏用于记录数据结构及算法的&#xff08;痛苦&#xff09;学习历程&#xff0c;便于日后复习&#xff08;这种事情不要啊&#xff09;。所用教材为《数据结构 C语言版…

【启明智显技术分享】ESP32系列WiFi无线空中抓包指南

前言&#xff1a; 本文档旨在介绍 windows10 系统下网卡抓包工具(AC-1200)的驱动安装过程、Omnipeek 软件安装过程及Omnipeek软件与网卡抓包工具配合抓包的演示过程。 1、抓包工具(AC-1200)驱动安装 1.1 准备好抓包工具及厂家提供的抓包工具驱动文件 1.2 插上 USB 网卡&…

Linux——socket套接字与udp通信

目录 一、理解IP地址与端口 二、socket套接字 三、TCP与UDP的关系 四、网络字节序 五、socket编程 1.socket()创建套接字 2.填充sockaddr_in 结构体 3.bind() 绑定信息 4.recvfrom()接收消息 5.sendto()发送消息 六、UdpServer代码 一、理解IP地址与端口 IP地址是In…

Leetcode—1256. 加密数字【中等】Plus(bitset、find_first_not_of、erase)

2024每日刷题&#xff08;120&#xff09; Leetcode—1256. 加密数字 实现代码 class Solution { public:string encode(int num) {string ans;num 1;while(num ! 0) {ans to_string(num & 1);num num >> 1;}if(ans.empty()) {return "";} else {stri…

17 如何设计一锤子买卖的SDK

在前三个模块里&#xff0c;我将微服务根据目的性划分为三大类&#xff1a;读、写与扣减类&#xff0c;并针对每一大类涉及的各项技术问题讲解了应对方案。其实&#xff0c;每一类微服务除了本身业务特点涉及的技术问题外&#xff0c;在纯技术维度也有很多共性问题&#xff0c;…

房产中介小程序高效开发攻略:从模板到上线一站式服务

对于房产中介而言&#xff0c;拥有一个高效且用户友好的小程序是提升业务、增强客户黏性的关键。而采用直接复制模板的开发方式&#xff0c;无疑是实现这一目标的最佳途径&#xff0c;不仅简单快捷&#xff0c;而且性价比极高。 在众多小程序模板开发平台中&#xff0c;乔拓云网…

docker容器通俗理解

前言 如果大家没使用过Docker,就在电脑上下载一个VMware Workstation Pro&#xff0c;创建一个虚拟机安装一个windows操作一下感受一下,为什么我的电脑上还以再安装一台windows主机&#xff1f;其实你可以理解为Docker就是Linux系统的一个虚拟机软件。 我的Windows也可以安装…

WMS仓库库存管理软件如何优化工厂的仓库管理-亿发

如果一家工厂没有专业的WMS仓储软件支撑&#xff0c;管理原材料、辅料、半成品和产成品等环节可能会面临诸多问题。 在仓库管理方面&#xff0c;缺乏安全库存的管理会导致库存不足或过剩&#xff0c;而没有及时的缺货分析可能会导致生产中断。全凭人工核算剩余库存和订单质检的…

金价大跳水,美梦变噩梦!2024真正适合普通人的靠谱创业项目!2024适合30-40岁轻资产小生意

4月22日晚间&#xff0c;向上“狂飙”了一个多月的金价突然就“大跳水”。当日&#xff0c;每克金价均下调14块。在这次跳水中&#xff0c;有人欢喜有人愁&#xff1a;有投资者自报做空金价一夜狂赚14万&#xff0c;也有投资者哭诉&#xff0c;头晚进货到早上就净亏损2万&#…

Android 11 bindService 流程分析

我们可以使用bindService来跨进程通信&#xff0c;其使用方法如下 Intent intent new Intent("xxx"); intent.setPackage("xxx"); boolean result bindService(intent,new ServiceConn(),BIND_AUTO_CREATE);private class ServiceConn implements Servi…

STM32入门_江协科技_1~2_OB记录的自学笔记_STM32简介

1.综述 1.1. 课程简介 手打代码是加入了实操&#xff0c;增加学习效果&#xff1b; STM最小系统板面包板的硬件平台&#xff1b; 配套0.96寸的显示屏&#xff0c;便于调试&#xff1b; 因为使用面板板&#xff0c;所以如果程序现象不出来也有可能是硬件连接的问题&#xff1b; …

Allegro画PCB时如何只删除走线的一部分

如何只删除走线的一部分 1、第一步&#xff1a; 2、第二步&#xff1a; 3、第三步&#xff0c;点击相应的走线段就能删除了。 说明&#xff1a;上面的Cline和Line只的是电线和线,您按下删除后,就可以删除这两种东西,但删除的是一整条折线.把这两个取消掉,换成Cline Segs和Ot…

【代码随想录刷题记录】LeetCode283移动零

题目地址 1. 思路 1.1 基本思路及假设 拿到这个题&#xff0c;首先想到&#xff0c;这是类似删除元素的方法&#xff0c;因为删除元素也是移动元素&#xff0c;但是移动的方向和删除元素的方法刚好相反&#xff0c;我们都知道&#xff0c;如果在数组中删除某个元素&#xff…

【Docker】docker部署lnmp和wordpress网站

环境准备 docker&#xff1a;192.168.67.30 虚拟机&#xff1a;4核4G systemctl stop firewalld systemctl disable firewalld setenforce 0 安装docker #安装依赖包 yum -y install yum-utils device-mapper-persistent-data lvm2 #设置阿里云镜像 yum-config-manager --add…