Javascript 系列:[{ allowPointSelect:true, 名称:'测试事物', colorByPoint:对, 数据:[{ 名称:“动物”, y:2, 深入调查:正确 }, { 名称:'水果', y:7, 深入调查:正确 }, { 名称:“汽车”, y:4, 深入调查:正确 }] }], 向下展开:{ 系列:[] } }) });

Javascript 系列:[{ allowPointSelect:true, 名称:'测试事物', colorByPoint:对, 数据:[{ 名称:“动物”, y:2, 深入调查:正确 }, { 名称:'水果', y:7, 深入调查:正确 }, { 名称:“汽车”, y:4, 深入调查:正确 }] }], 向下展开:{ 系列:[] } }) });,javascript,json,highcharts,tablet,drilldown,Javascript,Json,Highcharts,Tablet,Drilldown,Jsfiddle: 编辑:我想在我的图表中实现以下JSFIDLE,但我无法实现这个目标 总结: 我希望执行多重选择(类似于allowPointSelect:true),而无需在第一个图表以及代码中实现的深入分析中使用Shift+click/Ctrl+click 谢谢大家 嗯。。但这究竟应该如何运作呢?也许您想为移动设备实现某种复选框,可以选中该复选框来选择多个点?然后,不要使用选择而使用单击事件,在那里您可以调用点。选择(true,true)?它应该可以在PC和便携式设备中正常工作。我也试过你说

Jsfiddle:

编辑:我想在我的图表中实现以下JSFIDLE,但我无法实现这个目标

总结: 我希望执行多重选择(类似于
allowPointSelect:true
),而无需在第一个图表以及代码中实现的深入分析中使用Shift+click/Ctrl+click


谢谢大家

嗯。。但这究竟应该如何运作呢?也许您想为移动设备实现某种复选框,可以选中该复选框来选择多个点?然后,不要使用
选择
而使用
单击
事件,在那里您可以调用
点。选择(true,true)
?它应该可以在PC和便携式设备中正常工作。我也试过你说的,它在正常的图表中工作,但在我的情况下,我有一个向下钻取。因此,第一次单击应该执行选择,第二次单击应该执行向下展开。我已经完美地完成了这一点,但我必须选择的唯一方法是使用Cntrol+click/Shift+click,我希望避免这种情况,以使我的图表可用于便携式设备。我正在寻找另一种选择方法(类似于您所解释的),但让我使用向下钻取。希望我能更好地解释我的问题。谢谢你answering@FerranBuireu也许您可以使用一个按钮来执行向下搜索?这种方式是点击选择/取消选择按钮和向下搜索按钮。这是另一种交互观点。我有点害怕,因为我还不够好,所以我想我会努力的。。但这究竟应该如何运作呢?也许您想为移动设备实现某种复选框,可以选中该复选框来选择多个点?然后,不要使用
选择
而使用
单击
事件,在那里您可以调用
点。选择(true,true)
?它应该可以在PC和便携式设备中正常工作。我也试过你说的,它在正常的图表中工作,但在我的情况下,我有一个向下钻取。因此,第一次单击应该执行选择,第二次单击应该执行向下展开。我已经完美地完成了这一点,但我必须选择的唯一方法是使用Cntrol+click/Shift+click,我希望避免这种情况,以使我的图表可用于便携式设备。我正在寻找另一种选择方法(类似于您所解释的),但让我使用向下钻取。希望我能更好地解释我的问题。谢谢你answering@FerranBuireu也许您可以使用一个按钮来执行向下搜索?这种方式是点击选择/取消选择按钮和向下搜索按钮。这是另一种交互观点。我有点害怕,因为我不够好,我想我会努力的
<html>
    <head>
        <title>Highcharts</title>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script>
        <script src="https://code.highcharts.com/highcharts.js"></script>
        <script src="https://code.highcharts.com/modules/data.js"></script>
        <script src="http://github.highcharts.com/modules/exporting.js"></script>
        <script src="https://code.highcharts.com/modules/drilldown.js"></script>
        <script src="highcharts.js" type="text/javascript"></script>
        <!--Black theme
        <script src="black-theme.js" type="text/javascript"></script>
        -->
    </head>
    <body>
        <div id="container" style="min-width: 310px; height: 400px; margin: 0 auto"></div>       
    </body>
</html>
$(function () {
    // Create the chart
    $('#container').highcharts({
        chart: {
            type: 'column',
            events: {
                drilldown: function (e) {
                    if (!e.seriesOptions && e.point.selected) {
                        var chart = this,
                                points = chart.getSelectedPoints(),
                                drilldowns = {
                                    'Animals': {
                                        name: 'Animals',
                                        data: [
                                            ['Cows', 2],
                                            ['Sheep', 3]
                                        ]
                                    },
                                    'Fruits': {
                                        name: 'Fruits',
                                        data: [
                                            ['Apples', 5],
                                            ['Oranges', 7],
                                            ['Bananas', 2]
                                        ]
                                    },
                                    'Cars': {
                                        name: 'Cars',
                                        data: [
                                            ['Toyota', 1],
                                            ['Volkswagen', 2],
                                            ['Opel', 5]
                                        ]
                                    }
                                };

                        Highcharts.each(points, function (p) {
                            chart.addSingleSeriesAsDrilldown(p, drilldowns[p.name]);
                        });
                        chart.applyDrilldown();
                    }

                },
                drillup: function (e) {
                    var chart = this,
                            points = [];
                    setTimeout(function () {
                        points = chart.getSelectedPoints();

                        Highcharts.each(points, function (p) {
                            // unselect points from previous drilldown
                            p.selected = false;
                            p.setState('', true);
                        });
                    }, 0);
                }
            }
        },
        title: {
            text: 'Async drilldown'
        },
        xAxis: {
            type: 'category',
            categories: []
        },
        yAxis: {
            title: {
                text: 'Values'
            }

        },
        tooltip: {
            headerFormat: '<span style="font-size:10px">{point.key}</span><table>',
            pointFormat: '<tr><td style="color:{series.color};padding:0">{series.name}: </td>' +
                    '<td style="padding:0"><b>{point.y:.1f}</b></td></tr>',
            footerFormat: '</table>',
            shared: false,
            useHTML: true
        },
        legend: {
            enabled: false
        },
        plotOptions: {
            column: {
                allowPointSelect: true
            },
            series: {
                borderWidth: 0,
                dataLabels: {
                    enabled: true
                },
                point: {
                    events: {
                        select: function (event) {
                            var text = 'All selected points: <br/>',
                                    chart = this.series.chart,
                                    otherSelected = chart.getSelectedPoints();
                            if (event.accumulate) {
                                Highcharts.each(otherSelected, function (point) {
                                    text += point.name + ', value: ' + point.y + '<br/>';
                                });
                            }
                            var pretext = this.name + ', value: ' + this.y + ' (last selected)';
                            text += pretext.bold();
                            if (!chart.lbl) {
                                chart.lbl = chart.renderer.label(text, 100, 70)
                                        .attr({
                                            padding: 10,
                                            r: 5,
                                            fill: Highcharts.getOptions().colors[1],
                                            zIndex: 5
                                        })
                                        .css({
                                            color: '#FFFFFF'
                                        })
                                        .add();
                            } else {
                                chart.lbl.attr({
                                    text: text
                                });
                            }
                        }
                    }
                }
            }
        },
        series: [{
                allowPointSelect: true,
                name: 'Test things',
                colorByPoint: true,
                data: [{
                        name: 'Animals',
                        y: 2,
                        drilldown: true
                    }, {
                        name: 'Fruits',
                        y: 7,
                        drilldown: true
                    }, {
                        name: 'Cars',
                        y: 4,
                        drilldown: true
                    }]
            }],
        drilldown: {
            series: []
        }
    })
});