echarts图例点击事件

这段代码展示了如何处理Echarts图例的点击事件。它包括了legend切换事件的定义,判断是否只选择一个图例的函数,以及一个开关来控制第一次点击时的图例翻转行为。当图例被选择或取消时,'legendselectchanged'事件被监听并执行相应的逻辑。

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

//图例切换事件
var legend;
    var triggerAction = function(action, selected) {
        legend = [];
        for (name in selected) {
            if (selected.hasOwnProperty(name)) {
                legend.push({
                    name: name
                });
            }
        }
        myCharts.dispatchAction({
            type: action,
            batch: legend
        });
    };
    //是否只选择一个图例
    var isFirstUnSelect = function(selected) {
        var unSelectedCount = 0;
        for (name in selected) {
            if (!selected.hasOwnProperty(name)) {
                continue;
            }
            if (selected[name] == false) {
                unSelectedCount++;
            }
        }
        return unSelectedCount == 1;
    };
    //定义一个开关,第一次点击的时候才翻转。当所有都被选择的时候,再次点击不会只显示一个。
    var onOff = true;
    myCharts.on('legendselectchanged', function(obj) {
        var selected = obj.selected;
        var legend = obj.name;
        // 使用 legendToggleSelect Action 会重新触发 legendselectchanged Event,导致本函数重复运行
        // 使得 无 selected 对象
        if (selected != undefined && isFirstUnSelect(selected) && onOff) {
            triggerAction('legendToggleSelect', selected);
            onOff = false;
        }
    });
},
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值