27

我只是想在我的“柱形图”上禁用 DRILL-DOWN 效果。任何人都可以帮忙吗?这是 Fiddle http://jsfiddle.net/D8Ez3/的示例代码

*如您所见,图表的图例是可点击的。我需要图例中的项目不可点击,因为当您单击所有项目时,图表返回空。我宁愿对图表没有任何深入研究。有任何想法吗?

chart = new Highcharts.Chart({
    chart: {
        renderTo: 'impact',
        type: 'column',
        margin: [0, 0, 0, 0],
        spacingTop: 0,
        spacingBottom: 0,
        spacingLeft: 0,
        spacingRight: 0,
        backgroundColor: null,
        events: {
            load: function (event) {
                console.log(this);
            }}},
    exporting: {
       buttons: { 
       exportButton: {
       enabled:false
    },
    printButton: {
        enabled:false
    }}},
credits: {
        enabled: false
    },
    title: {
        text: ''
    },
    subtitle: {
        text: ''
    },
    xAxis: {
        categories: ['Reporting Year']
    },
    yAxis: {
        min: 0,
        title: {
            text: 'Millions (mm)'
        }
    },
    legend: {
    enabled:false,
        layout: 'vertical',
        backgroundColor: '#FFFFFF',
        align: 'left',
        verticalAlign: 'top',
        x: 50,
        y: 30,
        floating: true,
        shadow: true
    },
    tooltip: {
        formatter: function () {
            return '' + this.x + ': ' + this.y + ' mm';
        }
    },
    plotOptions: {
        column: {
            pointPadding: 0.2,
            size: '95%',
            borderWidth: 0},
    point: {
                events: {
                    legendItemClick: function () {
                        return true; // <== returning false will cancel the
                        default action }}},
            allowPointSelect: false,
    },
    series: [{
        name: 'Yr 1',
        data: [23.7] }, 
    {
        name: 'Yr 2',
        data: [13.6] }, 
    {
        name: 'Yr 3',
        data: [49.9] }, 
    {
        name: 'Yr 4',
        data: [83.6] }]
      });
4

7 回答 7

48

你很亲密。代替:

plotOptions: {
    column: {
        pointPadding: 0.2,
        size: '95%',
        borderWidth: 0
    },
    point: {
            events: {
                legendItemClick: function () {
                    return false; // <== returning false will cancel the default action
                }
            }
    },
    allowPointSelect: false,
},

你要:

plotOptions: {
    column: {
        pointPadding: 0.2,
        size: '95%',
        borderWidth: 0,
        events: {
            legendItemClick: function () {
                return false; 
            }
        }
    },
    allowPointSelect: false,
},
于 2012-11-07T18:29:06.553 回答
15

如果你使用馅饼,你必须这样做:

    pie: {
       showInLegend: true,
       allowPointSelect: false,
       point:{
           events : {
            legendItemClick: function(e){
                e.preventDefault();
            }
           }
       }
   }
于 2014-07-17T11:09:03.327 回答
3

这是使 Highcharts 图的图例不可点击的方法,因为每当您单击特定图例时,相应的切片就会从图中消失,因此根据业务要求使图保持不变,我们可能会使图例不可点击。

  plotOptions: {
        column: {
            pointPadding: 0,
            borderWidth: 1,
        },
        series: {
            events: {
                legendItemClick: function (e) {
                    e.preventDefault();
                }
            }
        }
    }
于 2016-12-09T12:43:40.397 回答
1

如果使用ES6,您可以使用箭头函数使其更短,因为它指向DOM 元素,您可以简单地返回false ...

{
  name: 'Name of this chart',
  type: 'line',
  lineWidth: 1,
  color: '#333333',
  events: {
    legendItemClick: () => false  // disable legend click
  },
  data: [1, 5, 10, 8, 19, 28, 0 , 12]
};
于 2018-11-21T07:49:06.240 回答
0

来自Highcharts JS API 文档(v7.1.1)

“默认操作是切换点的可见性。这可以通过调用 event.preventDefault() 来防止。”

所以这对我来说适用于饼图 -

    plotOptions: {
        pie: {
            point: {
                events: {
                    legendItemClick: function (e) {
                        e.preventDefault();
                    }
                }
            }
        }
    }
于 2019-04-25T22:01:07.537 回答
0

这是一个JSFiddle演示如何实现这一点:

plotOptions: {
        series: {
            events: {
                legendItemClick: function () {
                    var visibility = this.visible ? 'visible' : 'hidden';
                    if (!confirm('The series is currently ' +
                   **strong text**              visibility + '. Do you want to change that?')) {
                        return false;
                    }
                }
            }
        }
    }
于 2015-11-03T12:34:38.660 回答
0

作为对任何其他答案的有用补充,您可能还希望禁用图例悬停样式:

legend: {
    itemStyle: {
        cursor: 'default',
    },
    itemHoverStyle: {
        color: '#333333',
    }
},

见:https ://jsfiddle.net/oyps4fj6/

于 2019-08-21T14:00:56.110 回答