type: 'graph',echarts 企业关系图谱圆形类似企查查的详细代码
时间: 2023-12-29 11:02:27 浏览: 195
以下是一个示例代码,用于展示类似企查查的企业关系图谱:
```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 = {
"nodes": [
{
"name": "公司总部",
"symbolSize": 60,
"itemStyle": {
"color": "#0078D7"
}
},
{
"name": "财务部",
"symbolSize": 40,
"itemStyle": {
"color": "#00BFFF"
}
},
{
"name": "人力资源部",
"symbolSize": 40,
"itemStyle": {
"color": "#00BFFF"
}
},
{
"name": "研发部",
"symbolSize": 40,
"itemStyle": {
"color": "#00BFFF"
}
},
{
"name": "会计",
"symbolSize": 30,
"itemStyle": {
"color": "#98FB98"
}
},
{
"name": "出纳",
"symbolSize": 30,
"itemStyle": {
"color": "#98FB98"
}
},
{
"name": "审计师",
"symbolSize": 30,
"itemStyle": {
"color": "#98FB98"
}
},
{
"name": "人事专员",
"symbolSize": 30,
"itemStyle": {
"color": "#98FB98"
}
},
{
"name": "薪酬专员",
"symbolSize": 30,
"itemStyle": {
"color": "#98FB98"
}
},
{
"name": "培训专员",
"symbolSize": 30,
"itemStyle": {
"color": "#98FB98"
}
},
{
"name": "前端开发工程师",
"symbolSize": 30,
"itemStyle": {
"color": "#98FB98"
}
},
{
"name": "后端开发工程师",
"symbolSize": 30,
"itemStyle": {
"color": "#98FB98"
}
},
{
"name": "测试工程师",
"symbolSize": 30,
"itemStyle": {
"color": "#98FB98"
}
}
],
"links": [
{
"source": "公司总部",
"target": "财务部"
},
{
"source": "公司总部",
"target": "人力资源部"
},
{
"source": "公司总部",
"target": "研发部"
},
{
"source": "财务部",
"target": "会计"
},
{
"source": "财务部",
"target": "出纳"
},
{
"source": "财务部",
"target": "审计师"
},
{
"source": "人力资源部",
"target": "人事专员"
},
{
"source": "人力资源部",
"target": "薪酬专员"
},
{
"source": "人力资源部",
"target": "培训专员"
},
{
"source": "研发部",
"target": "前端开发工程师"
},
{
"source": "研发部",
"target": "后端开发工程师"
},
{
"source": "研发部",
"target": "测试工程师"
}
]
};
// 配置项
var option = {
tooltip: {},
series: [{
type: 'graph',
layout: 'circular',
symbol: 'circle',
symbolSize: 60,
roam: true,
label: {
show: true,
fontSize: 14
},
edgeSymbol: ['none', 'arrow'],
edgeSymbolSize: 10,
edgeLabel: {
fontSize: 12
},
data: data.nodes,
links: data.links,
lineStyle: {
color: '#B0C4DE',
width: 2,
curveness: 0.3
}
}]
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
</script>
</body>
</html>
```
以上代码中,我们使用了 ECharts 的 `graph` 类型来绘制企业关系图谱。与之前的 `tree` 类型不同,这里我们需要手动构造节点和边的数据,然后将它们传递给 `series` 中的 `data` 和 `links` 参数。在节点的数据中,我们为每个节点设置了不同的颜色,并指定了节点的大小;在边的数据中,我们指定了边的起点和终点。最后,我们选择了 `circular` 布局,使得节点按照圆形排列,并设置了一些额外的样式参数来达到类似企查查的效果。
需要注意的是,在实际应用中,我们可能还需要根据具体情况对节点和边的样式进行进一步的调整,以满足不同的需求。
阅读全文