当前位置: 首页 > article >正文

React echarts柱状图点击某个柱子跳转页面

绘制echarts柱状图

在 ECharts 中,如果你想要在点击柱状图的某个柱子时进行页面跳转,你可以通过设置 series 中的 data 属性中的 itemStyle 或者使用 series 的 label 属性中的 emphasis 属性来实现。但是,直接在柱状图中实现点击跳转通常涉及到使用 JavaScript 的事件监听功能,而不是通过 ECharts 的配置直接实现。

步骤 1: 创建 ECharts 实例

首先,确保你已经创建了一个 ECharts 实例并且已经设置了柱状图的配置。

<div id="my-chart" style={{height:400}} />
var myChart = echarts.init(document.getElementById('my-chart'));
var option = {
	tooltip: {
		trigger: "axis",
	},
	legend: {
		right: 30,
		data: ["数量"],
	},
    xAxis: {
        type: 'category',
        data: ['A', 'B', 'C', 'D', 'E']
    },
    yAxis: {
        type: 'value'
    },
    series: [{
        data: [120, 200, 150, 80, 70],
        type: 'bar',
        barWidth: "40%",
    }]
};

myChart.setOption(option);

步骤 2: 添加点击事件监听器

然后,你需要为 ECharts 实例添加一个点击事件监听器。当用户点击柱状图时,这个监听器会被触发。

项目的 react router是 v5 版本的,如果是新的 v6 版本可以使用 navigate

myChart.on('click', function (params) {
    if (params.componentType === 'series') {
        // 打印出 params 看一下,里面会有x轴和y轴的数据
        console.log(params);
        // 取x轴中的数据作为url的参数传递
        const {name} = params;
        // 获取对应的 URL 并进行跳转
        history.push({
          pathname: "/newPage",
          state: { code: name },
        });
    }
});

步骤 3: 取参数

传递过来的参数可以在 props.location.state 里看到。

跳转页面

React Router v5和v6 方式不太一样。

React Router v5

在React Router v5中,history.push通常是通过withRouter高阶组件或useHistory钩子(在函数组件中)来访问的。你可以使用history.push方法来携带参数,通常是通过URL的查询字符串(query string)或者通过状态(state)来实现。

通过查询字符串传递参数:

import { useHistory } from 'react-router-dom';
 
function MyComponent() {
  let history = useHistory();
 
  function handleClick() {
    history.push({
      pathname: '/some-path',
      search: '?param1=value1&param2=value2',
    });
  }
 
  return <button onClick={handleClick}>Go to Some Path</button>;
}

通过状态传递参数:

import { useHistory } from 'react-router-dom';
 
function MyComponent() {
  let history = useHistory();
 
  function handleClick() {
    history.push({
      pathname: '/some-path',
      state: { fromDashboard: true }
    });
  }
 
  return <button onClick={handleClick}>Go to Some Path</button>;
}

React Router v6

在React Router v6中,history对象被移除,取而代之的是使用useNavigate钩子来进行导航。传递参数的方式略有不同,但依然可以通过查询字符串或状态来实现。

通过查询字符串传递参数:

import { useNavigate } from 'react-router-dom';
 
function MyComponent() {
  let navigate = useNavigate();
 
  function handleClick() {
    navigate('/some-path?param1=value1&param2=value2');
  }
 
  return <button onClick={handleClick}>Go to Some Path</button>;
}

通过状态传递参数:

import { useNavigate } from 'react-router-dom';
 
function MyComponent() {
  let navigate = useNavigate();
 
  function handleClick() {
    navigate('/some-path', { state: { fromDashboard: true } });
  }
 
  return <button onClick={handleClick}>Go to Some Path</button>;
}

总结

React Router v5 使用 history.push 或 useHistory 钩子。可以通过 search 属性传递查询字符串,或者通过 state 属性传递状态。

React Router v6 使用 useNavigate 钩子。同样可以通过在 navigate 函数中直接附加查询字符串,或者通过第二个参数传递状态对象。

选择哪种方式取决于你使用的React Router版本以及你的具体需求。


http://www.kler.cn/a/548101.html

相关文章:

  • ABC393E/F简要题解
  • 基于web的留守儿童网站的设计与实现
  • 《当DeepSeek遇上豆包:AI大模型的华山论剑》
  • CAS单点登录(第7版)8.委托和代理
  • 筷子科技和抖去推哪个支持短视频矩阵系统源码搭建,OEM贴牌
  • python-leetcode-阶乘后的零
  • 【ISO 14229-1:2023 UDS诊断(会话控制0x10服务)测试用例CAPL代码全解析⑥】
  • CAS单点登录(第7版)3.安装
  • 蓝桥杯之图
  • DeepSeek 背后的技术:GRPO,基于群组采样的高效大语言模型强化学习训练方法详解
  • 基于斜坡单元的机器学习模型预测滑坡易发性,考虑条件因素的异质性
  • 【设计模式】02-理解常见设计模式-结构型模式
  • 基于opencv的 24色卡IQA评测算法源码-可完全替代Imatest
  • YOLOv5-Seg 完全指南:从训练到后处理
  • RAII(Resource Acquisition Is Initialization)机制
  • Ubuntu 24.04 上安装 Nginx
  • C++经典习题
  • 【Python爬虫(1)】专栏开篇:夯实Python基础
  • 服务器被暴力破解的一次小记录
  • 【Docker】Docker中卷的类型、区别及应用