前言

网上找了好久资料,没有一个完整实例,所以研究出来立马发布,共享下,希望能帮助到大家。


一、实现效果

方式1:提供视频方式大家看下符不符合要求

方式2:Demo演示地址

点击此处,可查看演示地址 https://it__distant_branch.gitee.io/echarts-tree/

二、源码提供

免费下载源码地址,点击下载 https://download.csdn.net/download/Qin_HongKun/14935641

三、代码分享

HTML代码如下:

<title>Tree</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style>#echart-id {width: 100%;height: calc(100% - 85px);padding: 20px;background-color: #fbfbfb;overflow: auto;}.search-con {width: 70%;margin: 0 auto;text-align: center;}#tip-botton {display: black;position: absolute;z-index: 999999999;pointer-events: none;}.height-auto {height: 100%;}.overflow-auto {height: calc(100% - 45px);overflow: auto;overflow-x: hidden;}
</style><body><div><input class="gxtb-echart-search-input" type="text" id="search-canves-input" name="title" required lay-verify="required" placeholder="请输入搜索内容" autocomplete="off" class="layui-input" style="width:calc(100% - 120px);display: inline-block;height:45px;border: 2px solid #06c;padding-left: 2px;"><button onclick="searchCanves()" class="layui-btn" style="width:80px;height: 42px;">搜索</button></div><div class="overflow-auto"><div id="echart-id"></div></div>
</body>
<script src="./js/jquery.js"></script>
<script src="./echarts/echarts.js"></script>
<script src="./data/data.js"></script>

JS代码如下:

<script>//存储echart对象$chart = ''/*** 判断是否存在值* @param {Object} data* @param {Object} value*/var is_exit_value = function(data, value) {var is_exit = falseif ($.isArray(data)) {$.each(data, function(index, item) {if (item == value) {is_exit = true}})}return is_exit}//获取子节点数量var getEchartNotExpandCount = function(list, options, isjs) {$.each(list, function(i, k) {var flag = true;$.each(options.data, function(i, kk) {if (kk === k) {flag = false;}})if (flag && !isjs) {options.lengthH++;options.data.push(k)}if (k.children.length) {getEchartNotExpandCount(k.children, options)}})}//获取某个节点父节点,一直递归获取var getEchartParentNode = function(item, options) {var flag = false;options[item.dataIndex] = itemif (item.parentNode) {getEchartParentNode(item.parentNode, options)}}//根据某个echart节点中所唯一索引来获取某个节点var getEchartNode = function(list, dataIndex, options) {var flag = false;$.each(list, function(i, k) {if (flag)return;if (k.dataIndex == dataIndex) {console.log(dataIndex, k)options.data = kflag = true;return} else if (k.children.length) {getEchartNode(k.children, dataIndex, options)}})}//设置点击某个节点之后选中线条变色,其他节点线条变成未选中颜色var setLineStyle = function(node) {//获取当前点击的节点,用来获取当前节点下是否存在点击的索引  存在说明是父级,则更换颜色 否则正常颜色var currentParentNode = {}getEchartParentNode(currentNode, currentParentNode)if (node.dataIndex in currentParentNode) {node.data.lineStyle = {color: '#ED143D',borderColor: '#ED143D'}} else {node.data.lineStyle = {color: '#2979ff',borderColor: '#2979ff'}}}/*** 节点点击收缩或者放大之后,获取隐藏的节点数量跟所有节点的数量,从而实现自适应高度* */var resize = function() {var id = document.getElementById('echart-id')var elesArr = $chart._chartsViews[0]._data.tree._nodesvar options = {lengthH: 0,lengthZh: 0,data: []}var lengthH = elesArr.lengthvar isTowExpand = false;$.each(elesArr, function(i, i1) {//获取点击的节点if (i1.dataIndex == currentIndex) {currentNode = i1}//获取未展开节点下的子节点数量if (!i1.isExpand && i1.children.length) {getEchartNotExpandCount([i1], options, true)}//获取所有二级节点,如果都未展示,指定固定宽度if (i1.depth === 2 && i1.isExpand) {console.log(i1)isTowExpand = true;}if (i1.isExpand) {}})//减去为展开节点数量lengthH = lengthH - options.lengthHvar height = $(".overflow-auto").height(); // 这里限制最小高var currentHeight = 35 * (lengthH - 1) || 200;var newHeight = Math.max(currentHeight, height);id.style.height = newHeight + 'px';var paramOptions = {width: $("#echart-id").width()}if (!isTowExpand) paramOptions = {width: $("#echart-id").width() / 2 + "px"}$chart.resize(paramOptions);}//保存点击后的节点值var currentIndex = ''var currentNode = {}//搜索后重新渲染echart searchCanves = function() {currentIndex = ''$chart && $chart.showLoading();//dataJson 从./data/data.js定义的setChart(dataJson, [$(".gxtb-echart-search-input").val()])}var setChart = function(data, keywords) {//echart对象存在则销毁,目的当请求后台之后,树的数据发生该百年,重新渲染树,否则会导致树的数据不正确if ($chart) {$chart.dispose();}$chart = echarts.init(document.getElementById('echart-id'));//树的节点点击事件$chart.on('click', function(params, params1) {//获取当前节点唯一索引值currentIndex = params.dataIndexif (params.componentType === 'series') {// 点击到了 series 上if (!params.value) {// 点击节点收缩放大之后,重新计算高度,实现自适应高度resize()}}//如果点击的是最后一级执行if (!params.data.children) {location.href = 'https://blog.csdn.net/Qin_HongKun?spm=1011.2124.3001.5343'}});//初始化echart 参数$chart.setOption(option = {height: "100%",backgroundColor: "#fbfbfb",series: [{//默认只展开两级,当有检索条件时全部展开initialTreeDepth: $("#search-canves-input").val().trim() ? 4 : 1,// 当此节点下还有子节点时候,设置的节点样式,用于区别 没有子节点的节点的样式itemStyle: {normal: {color: '#06c',borderColor: '#06c',},emphasis: {borderColor: '#06c',color: '#06c'}},lineStyle: {color: '#2979ff',},type: 'tree',data: [data],top: '1%',left: '200px',bottom: '1%',right: '250px',symbolSize: 18,symbol: function(params, params1, params2) {//点击之后 实现连接线变色setLineStyle(params1)//加号svg var svgAdd = 'image://'//减号svgvar svgD = 'image://'//最后一级展示圆圈图标if (!params1.data.children) {return 'emptyCircle'} elseif ($chart._chartsViews[0]._data) {//此列表中可以获取节点是否展开var treeList = $chart._chartsViews[0]._data.tree._nodes//获取唯一索引var dataIndex = params1.dataIndex;//获取节点var currentTreeNode = {}getEchartNode(treeList, dataIndex, currentTreeNode)console.log("currentTreeNode=>", currentTreeNode)if (!currentTreeNode.data.isExpand && params1.data.children.length) {return svgAdd}} else {//节点没有展开,显示+号图标if (params1.data.children.length) {return svgAdd}}return svgD},label: {position: 'left',verticalAlign: 'middle',align: 'right',color: '#293c55',margin: [2, 4],borderWidth: 1,borderColor: '#aaa',backgroundColor: 'white',borderRadius: 2,padding: [5, 4],rich: {keywords: {color: "red",fontSize: '12'},index: {fontSize: 12,color: '#2979ff',position: '10%'},},formatter: function(data, data1) {var newName = data.data.name//默认样式data.data.label = {fontSize: 12,padding: [5, 4],backgroundColor: 'rgb(238, 243, 246)',borderColor: 'rgb(115, 161, 191)',color: '#000000',}//如果是最后一级,设置样式不带框if (!data.data.children) {// debuggerdata.data.label.borderWidth = 0data.data.label.fontSize = 12data.data.label.padding = [5, 4]data.data.label.backgroundColor = 'transparent'data.data.symbolSize = 12data.data.label.color = '#2979ff'} elsenewName = data.data.children.length >= 0 ? newName + '(' + data.data.children.length + '类)' : newName;var arr = []//关键字标红if (keywords.length) {var splitName = newName$.each(keywords, function(index, item) {splitName = splitName.replace(item, '`' + item + '`')})$.each(splitName.split('`'), function(i, item) {if (is_exit_value(keywords, item))arr.push('{keywords|' + item + '}');elsearr.push(item);})} else {arr.push(newName);}return arr.join('');},},leaves: {label: {position: 'right',verticalAlign: 'middle',align: 'left',}},expandAndCollapse: true,animationDuration: 550,animationDurationUpdate: 750}]}, true);$chart.hideLoading();resize()}/*** 初始化echarts数据* */searchCanves()
</script>

以上代码中引用了三个js 提供链接,点击之后可以打开对应代码,可下载可复制

<script src="./js/jquery.js"></script>

<script src="./echarts/echarts.js"></script>

<script src="./data/data.js"></script>


总结

echart tree中一些实现方式,官方并没有提供,可以通过一些奇妙的方式解决哈哈,希望能帮到大家。

实现 echarts tree  label样式修改、symbol图标自定义、formatter添加样式、​​​​​​

echarts tree (树图) 实现自定义节点图标 自定义样式 点击节点后线条变色 自适应高度 搜索后节点关键字标红 写的很详细,建议收藏!相关推荐

  1. echarts 图例(legend icon)图标自定义的几种方式

    echarts 图例(legend icon)图标自定义的几种方式 前言 一.默认 图例项的 icon 二.使用图片链接或者base64 图片 三.使用 矢量 路径 1-3.以上例子的DEMO 四.创 ...

  2. html自定义列表图标,自定义列表项符号list-style-image详解

    本篇文章给大家带来的内容是关于自定义列表项符号list-style-image详解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 一.list-style-image属性 不管是有序 ...

  3. Android自定义app图标,自定义app图标(Icon) - Cordova中文网

    自定义图标(Icon) 这节将介绍如何为不同的平台配置一个app的图标.对启动画面(splash screen)的支持已经被移动到Cordova自己的插件中了.配置选项可以在Splashscreen插 ...

  4. 自定义View和自定义ViewGroup一步到位

    1.自定义View 首先我们要明白,为什么要自定义View?主要是Android系统内置的View无法实现我们的需求,我们需要针对我们的业务需求定制我们想要的View.自定义View我们大部分时候只需 ...

  5. echarts 树图样式美化_echarts2 tree树图自定义显示缩放大小、位置

    <> 看到网上关于echarts tree的资料有点少,做项目恰巧遇到这个,把一些获得分享给大家. 从echarts.官方API中我们似乎只能定义根节点的位置,并不能指定树图整体的大小以及 ...

  6. echart树图设置层级距离_echarts2 tree树图自定义显示缩放大小、位置

    <> 看到网上关于echarts tree的资料有点少,做项目恰巧遇到这个,把一些获得分享给大家. 从echarts.官方API中我们似乎只能定义根节点的位置,并不能指定树图整体的大小以及 ...

  7. Echarts —自定义label标签的样式(formatter,rich,添加图标等操作)

    最近公司项目中在使用 Echarts 绘制图表时,由于默认的 label 标签不能满足设计稿需求,所以研究了对 label标签进行格式化的方案,了解到可以使用 formatter 内容格式器对标签内容 ...

  8. echarts tree默认展开_Echarts树图定制详解

    本文讲的是如何定制Echarts的tree图.主要包括下载.全局变量名修改.左键菜单添加.右键菜单添加.内容缩放.文本过滤高亮等. 一 说明 Echarts中提供了tree图,但实际项目中,该tree ...

  9. vue23自定义svg图标组件

    可参考: 未来必热:SVG Sprites技术介绍 懒人神器:svg-sprite-loader实现自己的Icon组件 在Vue3项目中使用svg-sprite-loader 前置知识 在页面中,虽然 ...

最新文章

  1. 王劲对外发声:确已离开景驰,不是因为百度诉讼
  2. 中国固废处理行业十四五建议规划与前景深度研究报告2022-2028年
  3. 通过IDEA查看jar包中的依赖关系
  4. 梁迪:我为MVP骄傲,《微软最有价值专家奖励计划介绍》附专题视频
  5. static in c language
  6. 代码生成插件Easy Code 使用
  7. MacBook不断重启的 5 个原因以及如何解决此问题
  8. 赫斌C语言全案文,自用笔记,给后来者一点思路
  9. Altium Designer快捷键布线无法实现网络线自动编号
  10. 端到端深度学习在自动驾驶汽车上的应用
  11. 实践:nginx代理,通过使用GeoIp模块获取访问者IP及访问地区信息
  12. springcloud五大神兽之Gateway
  13. 移动端浏览器沉浸式导航
  14. 沈阳大学生招聘2020计算机,2020—毕业生必备的各大就业信息网站汇总
  15. Hello Jexus
  16. 【队列】C002_逛画展(单调队列)
  17. 深圳计算机中级职称如何申请,深圳中级职称评定有何流程
  18. 无线WLAN隧道转发模式下数据的封装以及转发过程
  19. 【报错解决方案】rm 删除不了文件:rm: cannot remove XXX: Operation not permitted
  20. 用js判断字符串的字节长度(区分汉字和英文)@莫成尘

热门文章

  1. ACM日历题新版(界面修改+国际节日)
  2. 【云计算】云计算的优势以及未来的发展趋势
  3. IMEI和IMSI有什么区别啊。分别是什么意思?有什么实际用途。
  4. 基于OpenCV的混凝土裂纹检测
  5. 学习笔记:Java虚拟机——JVM内存结构、垃圾回收、类加载与字节码技术
  6. [hdu6595]Everything Is Generated In Equal Probability
  7. jquery遍历得到的 Map 数据,
  8. DBM、GDBM与C语言跨平台代码研究
  9. 三峡西陵庙会:“文”味重 年味浓
  10. Mac干货 如何快速的在Mac上安装Windows双系统?虚拟机Parallels Desktop +Bootcamp安装