赞
踩
网上找了好久资料,没有一个完整实例,所以研究出来立马发布,共享下,希望能帮助到大家。
点击此处,可查看演示地址 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 = false
- if ($.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] = item
- if (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 = k
- flag = 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._nodes
- var options = {
- lengthH: 0,
- lengthZh: 0,
- data: []
- }
- var lengthH = elesArr.length
- var 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.lengthH
- var 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.dataIndex
- if (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://'
- //减号svg
- var svgD = 'image://'
- //最后一级展示圆圈图标
- if (!params1.data.children) {
- return 'emptyCircle'
- } else
- if ($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) {
- // debugger
- data.data.label.borderWidth = 0
- data.data.label.fontSize = 12
- data.data.label.padding = [5, 4]
- data.data.label.backgroundColor = 'transparent'
- data.data.symbolSize = 12
- data.data.label.color = '#2979ff'
- } else
- newName = 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 + '}');
- else
- arr.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>
echart tree中一些实现方式,官方并没有提供,可以通过一些奇妙的方式解决哈哈,希望能帮到大家。
实现 echarts tree label样式修改、symbol图标自定义、formatter添加样式、
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。