ECharts 实现人民的名义关系图谱 代码开源

本文介绍了如何使用ECharts创建关系图谱,包括设置series的type为graph,选择force布局,配置tooltip和data,以及定义关系。提供完整代码示例,并分享了Github仓库和在线演示链接,适合需要在web上展示关系图的开发者参考。
摘要由CSDN通过智能技术生成
1、什么是ECharts

ECharts是百度开源的纯 Javascript 图表库,目前开源可以与highcharts相匹敌的一个图表库,相信有很多国内用户使用。

官网 http://echarts.baidu.com/

 

2、开始简单配置关系图

1、首先配置series的type为graph。

2、layout为force,layout可以选择none、circular和force

  'none' 不采用任何布局,使用节点中提供的 x, y 作为节点的位置。

  'circular' 采用环形布局。

  'force' 采用力引导布局。

  来自官方文档

2、设置鼠标移动到人物处显示人物简介tooltip

tooltip: {
    formatter: function (x) {
        return x.data.des;
    }
}

 

3、设置data 

{
    name: '侯亮平',
    des: '最高检反贪局侦查处处长,汉东省人民检察院副检察长兼反贪局局长。<br/>经过与腐败违法分子的斗争,最终将一批腐败分子送上了审判台,<br/>正义战胜邪恶,自己也迎来了成长。',
    symbolSize: 100,
    itemStyle: {
        normal: {
            color: 'red'
        }
    }
}

 

4、设置关系

{
    source: '高育良',
    target: '侯亮平',
    name: '师生',
    des: '侯亮平是高育良的得意门生'
}

 

3、完整代码

<!DOCTYPE html>
<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>ECharts 实现人民的名义关系图谱</title>
    <script src="jquery-1.10.2.min.js"></script>
    <script src="echarts.min.js"></script>
    <style type="text/css">
        html, body, #main { height: 100%; width: 100%; margin: 0; padding: 0 }
    </style>
</head>
<body>
    <div id="main" style=""></div>
    <script type="text/javascript">
        var myChart = echarts.init(document.getElementById('main'));
        option = {
            title: { text: '人民的名义关系图谱' },
            tooltip: {
                formatter: function (x) {
                    return x.data.des;
                }
            },
            series: [
                {
                    type: 'graph',
                    layout: 'force',
                    symbolSize: 80,
                    roam: true,
                    edgeSymbol: ['circle', 'arrow'],
                    edgeSymbolSize: [4, 10],
                    edgeLabel: {
                        normal: {
                            textStyle: {
                                fontSize: 20
                            }
                        }
                    },
                    force: {
                        repulsion: 2500,
                        edgeLength: [10, 50]
                    },
                    draggable: true,
                    itemStyle: {
                        normal: {
                            color: '#4b565b'
                        }
                    },
                    lineStyle: {
                        normal: {
                            width: 2,
                            color: '#4b565b'

                        }
                    },
                    edgeLabel: {
                        normal: {
                            show: true,
                            formatter: function (x) {
                                return x.data.name;
                            }
                        }
                    },
                    label: {
                        normal: {
                            show: true,
                            textStyle: {
                            }
                        }
                    },
                    data: [
                        {
                            name: '侯亮平',
                            des: '最高检反贪局侦查处处长,汉东省人民检察院副检察长兼反贪局局长。<br/>经过与腐败违法分子的斗争,最终将一批腐败分子送上了审判台,<br/>正义战胜邪恶,自己也迎来了成长。',
                            symbolSize: 100,
                            itemStyle: {
                                normal: {
                                    color: 'red
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>组织结构图</title> <style> .dvItem { position:absolute; width:24px; border:1px solid #999999; font-size:12px; padding:5px; height:80px; z-index:9; background-color:#FFFFFF; line-height:16px; } a { text-decoration:none; color:#333333; } .dvhline { position:absolute; z-index:17; padding:0px; margin:0px; border-top:1px solid #999999; } .dvvline { color:blue; position:absolute; background-color:#999999; width:1px; z-index:17; } </style> <script> var dItem = new Array(); var w = 600; var h = 40; var iw = 60; var ih = 80; var boxh = 80; var startleft = 400; var starttop = 40; var hr = "<hr size=\"1\" noshade>" var labledv = "<div class=\"dvItem\" style=\"" var hdv = "<div class=\"dvhline\" style=\"width:"; var vdv = "<div class=\"dvvline\" style=\"height:" + h + "px;\""; var endsdv = "\">"; var enddv = "</div>"; var htm = ""; var len; var maxn=0;//深度 function Load_Data() { dItem[0] = "1|总经理|0|"; dItem[1] = "2|营运主管|1|"; dItem[2] = "3|技术主管|1|"; dItem[3] = "4|客服主管|2|"; dItem[4] = "5|商务主管|2|"; dItem[5] = "6|商务代表|5|"; dItem[6] = "7|营运策划|2|"; dItem[7] = "8|程序员|3|"; dItem[8] = "9|美工|3|"; len = dItem.length; Set_Item(0,0); Set_Max(); Write_Item(0,0,0,1); var htm1 = ""; for(var i=0;i<len;i++) { htm1 = htm1 +dItem[i]+"<br>"; } //document.getElementById("Load_DV").innerHTML = htm1 ; document.getElementById("List_DV").innerHTML = htm; } //设置层次 function Set_Item(pid,ni) { var n = ni + 1; var iAry = new Array(); for(var i=0;i<len;i++) { iAry = dItem[i].split("|"); if(iAry[2] == pid) { dItem[i] = dItem[i] + ni; if(maxn < ni) { maxn = ni; } Set_Item(iAry[0],n); } } } //设置节点子节点中最大数 function Set_Max() { var iAry = new Array(); var childnum; for(var i=0;i<len;i++) { iAry = dItem[i].split("|"); childnum = Get_Child_Num(iAry[0]); if(childnum <= 1) { dItem[i] = dItem[i] + "|0"; } else { dItem[i] = dItem[i] + "|" + Get_Max(iAry[0],iAry[3]); } } } function Get_Max(pid,start) { var iAry = new Array(); var m = 0; var n = 0; for(var j=start;j<=maxn;j++) { for(var i=0;i<len;i++) { iAry = dItem[i].split("|"); if(iAry[3] == j) { if(Get_RootID(pid,iAry[0])) { m = m + 1; } } if(n < m) { n = m; } } m = 0; } return n; } function Get_RootID(pid,id) { var iAry = new Array(); for(var i=0;i<len;i++) { iAry = dItem[i].split("|"); if(iAry[0] == id) { if(iAry[2] == pid) { return true; break; } else { return Get_RootID(pid,iAry[2]); } } } return false; }
以下是一个示例代码,用于展示企业组织结构关系图谱: ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>ECharts企业组织结构关系图谱示例</title> <!-- 引入 ECharts 文件 --> <script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script> </head> <body> <!-- 绘制图表的容器 --> <div id="chart" style="width: 1000px;height: 600px;"></div> <!-- 图表的 JavaScript 代码 --> <script> // 基于准备好的dom,初始化echarts实例 var myChart = echarts.init(document.getElementById('chart')); // 数据 var data = { "name": "公司总部", "children": [ { "name": "财务部", "children": [ { "name": "会计" }, { "name": "出纳" }, { "name": "审计师" } ] }, { "name": "人力资源部", "children": [ { "name": "人事专员" }, { "name": "薪酬专员" }, { "name": "培训专员" } ] }, { "name": "研发部", "children": [ { "name": "前端开发工程师" }, { "name": "后端开发工程师" }, { "name": "测试工程师" } ] } ] }; // 配置项 var option = { tooltip: { trigger: 'item', triggerOn: 'mousemove' }, series: [ { type: 'tree', data: [data], top: '1%', left: '7%', bottom: '1%', right: '20%', symbolSize: 7, label: { position: 'left', verticalAlign: 'middle', align: 'right', fontSize: 14 }, leaves: { label: { position: 'right', verticalAlign: 'middle', align: 'left' } }, expandAndCollapse: true, animationDuration: 550, animationDurationUpdate: 750 } ] }; // 使用刚指定的配置项和数据显示图表。 myChart.setOption(option); </script> </body> </html> ``` 以上代码中,我们使用 ECharts 的 `tree` 类型来绘制企业组织结构关系图谱。具体来说,我们通过一个 JSON 数据来定义组织结构的层级关系,然后在配置项中设置相关参数,例如节点大小、标签位置、动画效果等,最后调用 `setOption` 方法来绘制图表。 需要注意的是,这只是一个简单的示例代码,实际情况下,我们可能需要根据具体的业务需求来调整相关参数和样式,以达到更好的可视化效果。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值