Echart重写图例点击事件

本文介绍了如何重写Echarts的图例点击事件,实现第一次点击时仅显示所选图例,且在所有图例都被取消选中后自动全选的效果。通过示例代码详细展示了这一过程。
echarts version: 3

修改图例点击事件样例代码:
当第一次点击图例时,只显示点击的图例。
当还剩一个图例被取消选中后,自动全选中所有图例。

var lastselect="";//记录最近一次单击值
var oldvalue="";//记录上一次单击值
var cs=1;//记录选中单个值,还是所有,默认1
var triggerAction = function(action, selected) {
        legend = [];
        for ( name in selected) {
            if ((((selected[name] == true&&name==oldvalue) ||oldvalue=="")&&action=="legendToggleSelect")
            ||(action=="legendSelect")){
                legend.push({name: name});
            }
        }
         oldvalue=lastselect;

        myChart.dispatchAction({
            type: action,
            batch: legend
        });
    };
//当有其它选中图例时
    var isFirstUnSelect = function(selected) {
        var count=0;
        var unSelectedCount = 0;
        for ( name in selected) {
            count++;
            if (selected[name] == true && cs==2) {
                if(name!=oldvalue && oldvalue!=""){
                     lastselect=name;
                }else if(name==oldvalue){
                     ++unSelectedCount;
                }
                continue;
            }

            if (selected[name] == false) {
                if(cs==1){
                lastselect=name;
                cs=2;   
                }
                ++unSelectedCount;
            }
        }
        return unSelectedCount==1 || unSelectedCount==count-1;
    };
//当再次选中同一个图例,且只有这一个图例时,查看所有图例
    var isAllUnSelected = function(selected) {
        var selectedCount = 0;
        for ( name in selected) {
            if (!selected.hasOwnProperty(name)) {
                continue;
            }

            // 所有 selected Object 里面 true 代表 selected, false 代表 unselected
            if (selected[name] == true) {
                ++selectedCount;
            }
        }
        return selectedCount==0;
    };

    myChart.on('legendselectchanged', function(obj) {
        var selected = obj.selected;
        var legend = obj.name;

        // 使用 legendToggleSelect Action 会重新触发 legendselectchanged Event,导致本函数重复运行
        // 使得 无 selected 对象
        if (selected != undefined) {

            if (isFirstUnSelect(selected)) {
                triggerAction('legendToggleSelect', selected);
                // alert(1+";"+oldvalue)
            } else if (isAllUnSelected(selected)) {
                cs=1;
                triggerAction('legendSelect', selected);
               // alert(2+";"+oldvalue)
                oldvalue="";
                
            }
        }

    });
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值