Echarts自动轮播插件echarts-auto-tooltip的使用(附停止轮播的方法)

本文介绍如何使用Echarts的自动轮播插件echarts-auto-tooltip实现图表tooltip的自动循环展示,并提供了一种清除先前轮播设置的方法来避免图表闪烁问题。文中还包含了一个完整的测试示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Echarts自动轮播插件echarts-auto-tooltip的使用(附停止轮播的方法)

echarts-auto-tooltip使用方法:

	//引入echarts-auto-tooltip.js后
	var JSQKloop;
	//设置轮播
	JSQKloop = tools.loopShowTooltip(myChart, option, {
		interval:2000,  // 轮播时间间隔,单位毫秒,默认为2000
		loopSeries: true,     //boolean类型,默认为false。
							 //true表示循环所有series的tooltip,false则显示指定seriesIndex的tooltip
        seriesIndex:0  //默认为0,指定某个系列(option中的series索引)循环显示tooltip,当loopSeries为true时,从seriesIndex系列开始执行.
	});

经测试,多次为同一个echarts图表设置轮播效果后会出现图表闪烁的问题,即:echarts-auto-tooltip不会覆盖之前的设置;
因此要在设置新轮播效果前,删除当前轮播,方法:

	//删除以往设置的轮播
	var JSQKloop;
	if(JSQKloop){
		JSQKloop.clearLoop()
	}

完整测试代码:

<!doctype html>
	<meta charset="utf-8">
	<title>轮播测试</title>
	
	<script src="js/jquery-3.2.0.min.js" charset="utf-8" type="text/javascript"></script>
	<script src="js/echarts.min.js" charset="utf-8" type="text/javascript"></script>
	<!-- 轮播 -->
	<script src="js/echarts-auto-tooltip.js" charset="utf-8" type="text/javascript"></script>

</head>
<body>
	<div id="testDiv" style="width: 500px;height:500px;">
		
	</div>
</body>
<script type="text/javascript">
	var chartDom = document.getElementById('testDiv');
	var myChart = echarts.init(chartDom);
	var option;
	
	var JSQKloop;
	
	option = {
	  title: {
	    text: 'Referer of a Website',
	    subtext: 'Fake Data',
	    left: 'center'
	  },
	  tooltip: {
	    trigger: 'item'
	  },
	  legend: {
	    orient: 'vertical',
	    left: 'left'
	  },
	  series: [
	    {
	      name: 'Access From',
	      type: 'pie',
	      radius: '50%',
	      data: [
	        { value: 1048, name: 'Search Engine' },
	        { value: 735, name: 'Direct' },
	        { value: 580, name: 'Email' },
	        { value: 484, name: 'Union Ads' },
	        { value: 300, name: 'Video Ads' }
	      ],
	      emphasis: {
	        itemStyle: {
	          shadowBlur: 10,
	          shadowOffsetX: 0,
	          shadowColor: 'rgba(0, 0, 0, 0.5)'
	        }
	      }
	    }
	  ]
	};
	
	myChart.setOption(option);
	
	if(JSQKloop){
		JSQKloop.clearLoop()
	}
	
	JSQKloop = tools.loopShowTooltip(myChart, option, {
		loopSeries: true
	});

</script>
</html>

### Vue ECharts 实现 Tooltip 自动轮播效果 为了实现在 Vue 中使用 ECharts自动轮播 Tooltip 功能,可以借助 `echarts-auto-tooltip` 插件来简化开发过程。此插件允许设置定时器来自动生成并显示 Tooltips。 #### 安装依赖项 首先安装必要的 npm 包: ```bash npm install echarts echarts-auto-tooltip vue-echarts ``` #### 创建组件结构 创建一个新的 Vue 组件用于集成 ECharts 图表及其自动轮播功能: ```vue <template> <div ref="chartContainer" style="width: 600px; height: 400px;"></div> </template> <script setup> import * as echarts from 'echarts'; import autoTooltipPlugin from 'echarts-auto-tooltip'; // 初始化图表实例 const chartContainer = $ref(null); let myChart; onMounted(() => { // 基于准备好的 DOM,初始化 echarts 实例 myChart = echarts.init(chartContainer); // 注册自定义工具提示插件 echarts.registerAction('autoShowTip', function (payload, ecInstance) {}); const option = { title: { text: 'ECharts Auto Tooltip Example' }, xAxis: { type: 'category', data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri'] }, yAxis: { type: 'value' }, series: [{ name: 'Sales', type: 'bar', data: [120, 200, 150, 80, 70], itemStyle: { color: '#3aa1ff' } }] }; // 设置配置项 myChart.setOption(option); // 启用自动滚动提示框 setTimeout(function () { let dataIndex = 0; setInterval(function () { myChart.dispatchAction({ type: 'showTip', seriesIndex: 0, dataIndex: (dataIndex++) % 5 }); }, 2000); // 每隔两秒切换一次 }, 1000); }); </script> <style scoped> /* 添加样式 */ .echarts-tooltip { z-index: 999 !important; } </style> ``` 这段代码展示了如何通过 JavaScript API 来控制 ECharts 的行为,在页面加载完成后启动一个计时器每隔一段时间触发一次 `showTip` 行为从而达到自动播放的效果[^1]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值