Loading...
在数据可视化中,状态(State) 是实现交互反馈、高亮、选中等效果的核心机制。Ant Design Charts 提供了灵活且强大的状态系统,允许开发者为图表中的每个标记(mark)配置不同的状态样式,实现如鼠标悬停高亮、点击选中等多种交互场景,极大提升了图表的可用性和表现力。
状态样式的属性与 @antv/g 支持的样式属性一致,常见如 fill(填充色)、stroke(描边色)、strokeWidth(描边宽度)、opacity(透明度)等,详见样式(Style)。
Ant Design Charts 支持在 mark 层级通过 state 字段配置不同状态下的样式。常用状态包括:
| 状态名 | 说明 | 典型场景 |
|---|---|---|
| active | 高亮时的样式 | 鼠标悬停 |
| inactive | 非高亮时的样式 | 其他未被高亮的元素 |
| selected | 选中时的样式 | 鼠标点击 |
| unselected | 未选中时的样式 | 其他未被选中的元素 |
import { Column } from '@ant-design/plots';import React from 'react';import { createRoot } from 'react-dom/client';const Demo = () => {const state = {selected: { fill: 'red' },active: { fill: 'green', stroke: 'black', lineWidth: 1 },};const config ={data: [{ type: 'A', value: 30 },{ type: 'B', value: 50 },{ type: 'C', value: 20 },],xField: 'type',yField: 'value',state: {active: { fill: 'red', stroke: 'blue', strokeWidth: 2 },inactive: { fill: '#aaa' },selected: { fill: 'orange', stroke: 'black', strokeWidth: 2 },unselected: { fill: '#eee' },},interaction: { elementHighlight: true, elementSelect: true }};return <Column {...config} />;};createRoot(document.getElementById('container')).render(<Demo />);
状态样式属性支持函数,根据数据动态返回样式:
import { Column } from '@ant-design/plots';import React from 'react';import { createRoot } from 'react-dom/client';const Demo = () => {const config ={data: [{ type: 'A', value: 30 },{ type: 'B', value: 50 },{ type: 'C', value: 20 },],xField: 'type',yField: 'value',state: {active: {fill: (d) => (d.value > 40 ? 'red' : 'blue'),},},interaction: { elementHighlight: true }};return <Column {...config} />;};createRoot(document.getElementById('container')).render(<Demo />);
Ant Design Charts 支持多个状态同时生效,当同一属性被多个状态配置时,会按照优先级选择最终生效的样式。
优先级如下:
selected: 3unselected: 3active: 2inactive: 2default: 1
selected/unselected 优先级高,常用于点击选中active/inactive 次之,常用于悬停高亮default 为默认样式import { Column } from '@ant-design/plots';import React from 'react';import { createRoot } from 'react-dom/client';const Demo = () => {const config ={data: [{ letter: 'A', frequency: 0.08167 },{ letter: 'B', frequency: 0.01492 },{ letter: 'C', frequency: 0.02782 },],xField: 'letter',yField: 'frequency',state: {selected: { fill: 'red' },active: { fill: 'green', stroke: 'black', lineWidth: 1 },},interaction: { elementHighlight: true, elementSelect: true }};return <Column {...config} />;};createRoot(document.getElementById('container')).render(<Demo />);
active 状态生效,显示绿色和黑色描边selected 和 active 同时生效,但 selected 优先级更高,最终填充色为红色Ant Design Charts 提供了丰富的交互,配合状态样式可实现多种交互效果:
| 名称 | 说明 | 典型状态 |
|---|---|---|
| brushAxisHighlight | 轴刷选高亮 | active/inactive |
| brushHighlight | 区域刷选高亮 | active/inactive |
| brushXHighlight | X 轴刷选高亮 | active/inactive |
| brushYHighlight | Y 轴刷选高亮 | active/inactive |
| elementHighlight | 悬停高亮 | active/inactive |
| elementHighlightByColor | 按颜色高亮 | active/inactive |
| elementHighlightByX | 按 X 高亮 | active/inactive |
| legendHighlight | 图例高亮 | active/inactive |
| elementSelect | 点击选中 | selected/unselected |
| elementSelectByColor | 按颜色选中 | selected/unselected |
| elementSelectByX | 按 X 选中 | selected/unselected |
通过 elementHighlight 交互插件,配合 active 和 inactive 状态样式,实现鼠标悬停高亮效果:
import { Column } from '@ant-design/plots';import React from 'react';import { createRoot } from 'react-dom/client';const Demo = () => {const config ={data: [{ letter: 'A', frequency: 0.08167 },{ letter: 'B', frequency: 0.01492 },{ letter: 'C', frequency: 0.02782 },],xField: 'letter',yField: 'frequency',state: {active: { fill: 'red' },inactive: { fill: '#aaa' },},interaction: { elementHighlight: true }};return <Column {...config} />;};createRoot(document.getElementById('container')).render(<Demo />);
效果说明:
active 样式,其他柱子应用 inactive 样式。通过 elementSelect 交互插件,配合 selected 和 unselected 状态样式,实现点击选中效果:
import { Column } from '@ant-design/plots';import React from 'react';import { createRoot } from 'react-dom/client';const Demo = () => {const config ={data: [{ letter: 'A', frequency: 0.08167 },{ letter: 'B', frequency: 0.01492 },{ letter: 'C', frequency: 0.02782 },],xField: 'letter',yField: 'frequency',state: {selected: { fill: 'orange', stroke: 'black', strokeWidth: 2 },unselected: { fill: '#eee' },},interaction: { elementSelect: true }};return <Column {...config} />;};createRoot(document.getElementById('container')).render(<Demo />);
效果说明:
selected 样式,其他柱子应用 unselected 样式。支持同时高亮与选中,常用于仪表盘、BI 报表等场景:
import { Column } from '@ant-design/plots';import React from 'react';import { createRoot } from 'react-dom/client';const Demo = () => {const config ={data: [{ type: 'A', value: 30 },{ type: 'B', value: 50 },{ type: 'C', value: 20 },],xField: 'type',yField: 'value',state: {active: { fill: 'yellow' },inactive: { fill: '#eee' },selected: { fill: 'orange', stroke: 'black', strokeWidth: 2 },unselected: { fill: '#ccc' },},interaction: { elementHighlight: true, elementSelect: true }};return <Column {...config} />;};createRoot(document.getElementById('container')).render(<Demo />);
状态切换时可结合动画(如淡入淡出、缩放等),提升交互体验。详见动画系统。
{type: 'interval',// 其他配置...state: {active: {fill: 'red',opacity: (d) => (d.value > 40 ? 1 : 0.5),},}}
支持将样式属性设置为函数,根据数据动态返回样式:
{type: 'interval',// 其他配置...state: {active: {fill: (d) => (d.value > 40 ? 'red' : 'blue'),},}}
状态样式未生效?
检查是否正确配置了交互插件(如 elementHighlight、elementSelect),并确保 state 配置正确。
多个状态冲突?
合理利用优先级机制,避免同一属性在多个高优先级状态下重复配置。
状态样式与动画冲突?
注意状态切换时动画的配置,避免样式和动画叠加导致的视觉异常。