echart树状图使用细则以及注意事项以及SVG实现树形组织结构图绘制(可实现页面要求设计的树状结构图)

本文主要是介绍echart树状图使用细则以及注意事项以及SVG实现树形组织结构图绘制(可实现页面要求设计的树状结构图),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.echart绘制

1.安装echarts

npm i echarts

注意:我使用的是是5.4.3版本,版本不一致部分用法可能会有出入,关闭点击节点的伸缩行为以及默认节点圆点样式去除等用法看代码注释。节点之间的间距不用调,直接在代码增加子节点就行。

 代码如下:

import React, { useEffect } from "react";
import * as echarts from "echarts";
export default function Sunset() {useEffect(() => {var myChart = echarts.init(document.getElementById("main"));let option = {series: [{name: "树图",type: "tree",//   layout: "orthogonal",如果要调整树状显示方向此处layout和orient搭配使用可达到效果orient: "vertical", // vertical   //树状方向修改expandAndCollapse: false, //关闭点击树节点的伸缩行为rootLocation: { x: 100, y: "50%" }, // 根节点位置  {x: 'center',y: 10}edgeShape: "polyline", //使用多段折线连接节点nodePadding: 20,symbol: "circle",width: "1000px", //调整树状距离宽度symbolSize: 40,edgeStyle: {type: "solid", // 直线类型curveness: 0, // 弯曲程度,设置为0表示直线},itemStyle: {normal: {label: {show: true,position: "inside",// distance: 30, distance和position: "inside",搭配使用可调线段据文字距离textStyle: {color: "#cc9999",fontSize: 15,fontWeight: "bolder",},},lineStyle: {color: "#000",width: 1,type: "broken", // 'curve'|'broken'|'solid'|'dotted'|'dashed'},},emphasis: {label: {show: true,},},},data: [{name: "手机",value: 6,symbolSize: [90, 150],symbol:"image://http://www.iconpng.com/png/ecommerce-business/iphone.png",itemStyle: {normal: {label: {show: false,},},},children: [{name: "小米",value: 4,symbol:"image://",symbolSize: [60, 60], //调整图片宽高children: [{name: "红米",symbolSize: 20,value: 4,itemStyle: {color: "none", //通过设置none树状圆点可以去掉},},{name: "小米",value: 4,itemStyle: {color: "none",},symbolSize: 20,},{name: "笔记本",value: 2,itemStyle: {color: "none",},symbolSize: 20,},],},{name: "苹果",symbol:"image://http://www.viastreaming.com/images/apple_logo2.png",symbolSize: [60, 60],value: 4,children: [{name: "苹果12",symbolSize: 20,value: 4,itemStyle: {color: "none", //通过设置none可将默认树状圆点可以去掉},},{name: "苹果13",value: 4,itemStyle: {color: "none",},symbolSize: 20,},{name: "苹果14",value: 2,itemStyle: {color: "none",},symbolSize: 20,},],},{name: "华为",symbol:"image://http://market.huawei.com/hwgg/logo_cn/download/logo.jpg",symbolSize: [60, 60],value: 2,},{name: "联想",symbol:"image://http://www.lenovo.com.cn/HomeUpload/Home001/6d94ee9a20140714.jpg",symbolSize: [100, 40],value: 2,},],},],},],};myChart.setOption(option);});return (<divid="main"style={{ width: "100vw", height: "100vh", background: "pink" }}></div>);
}

效果如下:

二.SVG绘制(更多图形绘制主要考虑SVG进行使用,如果使用echarts和canvas能实现也可),更多SVG使用请参考其他文档,此处不做赘述。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><svg xmlns="http://www.w3.org/2000/svg" width="500" height="300"  style="background-color: aqua;"><!-- 直线 --><rect x="81" y="180" width="100" height="1" fill="#000" />     <text x="70" y="183" font-size="12" text-anchor="end">根节点</text> <!-- 根节点的文本标签 --><!-- 竖上直线 --><rect x="180" y="80" width="1" height="100" fill="#000" /> <!-- 竖下直线 --><rect x="180" y="181" width="1" height="100" fill="#000" /><!--Node 2对应直线  --><rect x="180" y="281" width="100" height="1" fill="#000" /><text x="330" y="283" font-size="12" text-anchor="end">子节点二</text> <rect x="180" y="80" width="100" height="1" fill="#000" /><text x="330" y="80" font-size="12" text-anchor="end">子节点一</text>  </svg></body>
</html>

这篇关于echart树状图使用细则以及注意事项以及SVG实现树形组织结构图绘制(可实现页面要求设计的树状结构图)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/228364

相关文章

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle

SpringSecurity JWT基于令牌的无状态认证实现

《SpringSecurityJWT基于令牌的无状态认证实现》SpringSecurity中实现基于JWT的无状态认证是一种常见的做法,本文就来介绍一下SpringSecurityJWT基于令牌的无... 目录引言一、JWT基本原理与结构二、Spring Security JWT依赖配置三、JWT令牌生成与

Qt spdlog日志模块的使用详解

《Qtspdlog日志模块的使用详解》在Qt应用程序开发中,良好的日志系统至关重要,本文将介绍如何使用spdlog1.5.0创建满足以下要求的日志系统,感兴趣的朋友一起看看吧... 目录版本摘要例子logmanager.cpp文件main.cpp文件版本spdlog版本:1.5.0采用1.5.0版本主要

Java中使用Hutool进行AES加密解密的方法举例

《Java中使用Hutool进行AES加密解密的方法举例》AES是一种对称加密,所谓对称加密就是加密与解密使用的秘钥是一个,下面:本文主要介绍Java中使用Hutool进行AES加密解密的相关资料... 目录前言一、Hutool简介与引入1.1 Hutool简介1.2 引入Hutool二、AES加密解密基础

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

鸿蒙中@State的原理使用详解(HarmonyOS 5)

《鸿蒙中@State的原理使用详解(HarmonyOS5)》@State是HarmonyOSArkTS框架中用于管理组件状态的核心装饰器,其核心作用是实现数据驱动UI的响应式编程模式,本文给大家介绍... 目录一、@State在鸿蒙中是做什么的?二、@Spythontate的基本原理1. 依赖关系的收集2.