G2Plot图表库——桑基图开发

最近在产品上有一个需求需要用到桑基图进行实现,在ECharts上稍微找了一下感觉都不太美观,于是找到了G2Plot这个库进行实现

1、G2Plot

这个库是antv(ant-design的可视化库)的一个产品,也有React和Vue3的版本,由于项目上用的是vue2,所以这边选择的是一个vue2的版本。 官网:g2plot.antv.antgroup.com/

2、桑基图

图表的效果基本如上,我这边实现的主要是一个企业迁入/迁出的数据展示,所以这个图表基本也能满足需求实现

3、代码实现

js 复制代码
      <div id="sankey" style="width: 1082px; height: 469px; margin-top: 23px"></div>

正常建一个容器用于图表的渲染,这一块跟Echart基本比较相似,使用canvas进行渲染

js 复制代码
 init() {
      this.sankey = new Sankey("sankey", {
        data: this.data, //数据
        sourceField: "source",
        targetField: "target",
        weightField: "value",
        color: this.randomColors, //一个颜色数组,可删除
        nodeWidthRatio: 0.008,
        nodePaddingRatio: 0.03,
        interactions: [{ type: "element-active" }],
        labels: (node) => {
          return node.name;
        },

        // 支持节点排序,降序
        nodeSort: (a, b) => b.value - a.value,
        // 支持边排序,降序
        // linkSort: (a, b) => b.value - a.value,
      });

      this.sankey.render();
      this.sankey.on("element:click", (...args) => {
        // 区分点击线还是点看data.isNode
        console.log(args);
        this.handleDrawer(args[0].data);
      });

    },

初始化方法如上,data处是你要渲染的数据,color这里根据UI需求我这边定义了一个颜色数组,只用我们产品主题的一些颜色,这样风格会更统一一些,排序方法则是对节点进行从大到小排序,然后还构造了一些点击方法进行图表交互的实现。 具体的参数内容可以参考官方API文档:g2plot.antv.antgroup.com/api/plot-ap...

相关推荐
Rhi63715 分钟前
从零搭建项目:React 19 + Vite 8 + Tailwind CSS v4 实战配置
前端
竹林81822 分钟前
用Viem替代ethers.js:从一次签名失败到完整迁移的实战记录
前端·javascript
之歆27 分钟前
DAY08_CSS浮动与行内块布局实战指南(上)
前端·css
light blue bird1 小时前
主子端台二分法任务汇总组件
前端·数据库·.net·桌面端winform
jeffwang2 小时前
我做了个让 AI 看屏幕跑测试的工具,因为 Playwright 测不了我的 Flutter Web
前端
HSunR2 小时前
dify 搭建ai作业批改流
开发语言·前端·javascript
代码不加糖2 小时前
2026 跨境电商独立站实战:从 0 到 1 搭建高转化 SaaS 商城(附源码)
开发语言·前端·javascript
亲亲小宝宝鸭3 小时前
拖一拖控件,拖出个问卷(低代码平台)
前端·低代码
江南十四行3 小时前
ReAct Agent 基本理论与项目实战(一)
前端·react.js·前端框架
We་ct3 小时前
LeetCode 72. 编辑距离:动态规划经典题解
前端·算法·leetcode·typescript·动态规划