Javascript 系列:[{ allowPointSelect:true, 名称:'测试事物', colorByPoint:对, 数据:[{ 名称:“动物”, y:2, 深入调查:正确 }, { 名称:'水果', y:7, 深入调查:正确 }, { 名称:“汽车”, y:4, 深入调查:正确 }] }], 向下展开:{ 系列:[] } }) });
Jsfiddle: 编辑:我想在我的图表中实现以下JSFIDLE,但我无法实现这个目标 总结: 我希望执行多重选择(类似于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和便携式设备中正常工作。我也试过你说
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: []
}
})
});