D3.js 是数据驱动的 SVG 可视化库,需手动绑定数据与 DOM 元素,适合深度定制;通过 select、data、enter、attr 等方法构建图表,配合 scale、axis、transition 实现映射、坐标轴和动画。
用 JavaScript 实现数据可视化,D3.js 是最强大也最灵活的选择之一,但它不是“开箱即用”的图表库——它提供的是底层操作 DOM 和 SVG 的能力,需要你亲手构建图表逻辑。想快速出图,可以搭配 Chart.js 或 Plotly.js;想深度定制、做交互式信息图或动态数据流,D3.js 更合适。
D3 的本质是把数据和页面元素(如 、、)建立绑定关系,并根据数据变化自动更新对应元素的属性(位置、颜色、大小等)。它不预设图表类型,而是让你用 SVG + 数据 + 过渡动画组合出任意可视化形式。
d3.select() 和 d3.selectAll() 获取/创建元素.data() 绑定数组,用 .enter().append() 创建新元素.attr()、.style()、.text() 设置视觉属性d3.scaleLinear()、d3.scaleBand() 等做数值到像素的映射假设你有一组销售数据:[{month: "Jan", value: 24}, {month: "Feb", value: 32}, ...],目标是渲染成横向排列的矩形柱子。
const svg = d3.select("#chart").append("svg")...
const xScale = d3.scaleLinear().domain([0, d3.max(data, d => d.value)]).range([0, width])
svg.selectAll("rect").data(data).enter().append("rect")...
x、y、width、height 属性(注意 y 坐标需考虑 SVG 坐标系原点在左上角)d3.axisBottom(xScale) 并插入到 SVG 中D3 的过渡(.transition())天然支持平滑动画,比如数据更新时柱子高度渐变、鼠标悬停高亮、点击筛选等。
.on("mouseover", (
event, d) => d3.select(event.target).style("fill", "orange"))
svg.selectAll("rect").data(newData).join("rect")...,配合 .transition().duration(500)
d3.zoom() 监听事件,动态调整比例尺和 SVG 内容位移纯 D3 编写完整仪表盘成本高。推荐组合使用:
d3-selection、d3-scale、d3-axis)按需引入,减少体积