我有一个文本值列表及其对应的分数值(值X和值y)。我能够在值x和值y的交点处绘制一个点。将鼠标悬停在点上会在x,y坐标上显示点的位置值,但对于相应的文本值,它显示为未识别。
<script>
var array = @Html.Raw(Json.Encode(ViewBag.Items3DList));
var practicalityscore = [];
for(var i in array){
var serie = new Array(array[i].YAxis, array[i].AvgIPA, array[i].Title);
practicalityscore.push(serie);
}
$(function () {
var chart = new Highcharts.Chart({
chart: {
renderTo: 'practicalityscore',
zoomType: 'xy',
defaultSeriesType:'scatter',
borderWidth:1,
borderColor:'#fff',
marginLeft:50,
marginRight:50,
backgroundColor:'#fff',
plotBackgroundColor:'#fff',
},
credits:{enabled:false},
title:{
text:'Most Practical Ideas',
align: 'left',
},
legend:{
enabled:false
},
tooltip:{
crosshairs: [{
enabled:true,
width:1,
color:'rgba(238,46,47,.25)'
},{
enabled:true,
width:1,
color:'rgba(238,46,47,.25)'
}],
formatter: function(){
return '<span><b>Practicality</b>: '+ Highcharts.numberFormat(this.x,0) + '<br/><span><b>Avg IPA</b>: '+ Highcharts.numberFormat(this.y,0) + '<br/><span><b>Idea</b>: '+ this.point.name;
}
},
plotOptions: {
series: {
color:'#0093dd',
marker: {
fillOpacity:1,
radius:7,
lineWidth:.5,
lineColor:'#fff',
},
}
},
xAxis:{
title:{
text:'Practicality Score'
},
min:0,
max:10,
tickInterval:1,
tickLength:0,
minorTickLength:0,
gridLineWidth:0,
showLastLabel:true,
showFirstLabel:false,
lineColor:'#fff',
lineWidth:0
},
yAxis:{
title:{
text:'AvgIPA',
rotation:-90,
margin:10,
},
min:0,
max:10,
tickInterval:1,
tickLength:0,
minorTickLength:0,
lineColor:'#fff',
lineWidth:0
},
series: [{
color:'rgba(238,46,47,.5)',
data: practicalityscore,
}]
}, function(chart) { // on complete
var width = chart.plotBox.width / 2.0;
var height = chart.plotBox.height / 2.0 + 1;
chart.renderer.rect(chart.plotBox.x,
chart.plotBox.y, width, height, 1)
.attr({
fill: '#fff',
'stroke-width': 4,
stroke: '#fff',
zIndex: 1
})
.add();
chart.renderer.rect(chart.plotBox.x + width,
chart.plotBox.y, width, height, 1)
.attr({
fill: '#fff',
'stroke-width': 4,
stroke: '#fff',
zIndex: 1
})
.add();
chart.renderer.rect(chart.plotBox.x,
chart.plotBox.y + height, width, height, 1)
.attr({
fill: '#fff',
'stroke-width': 4,
stroke: '#fff',
zIndex: 1
})
.add();
chart.renderer.rect(chart.plotBox.x + width,
chart.plotBox.y + height, width, height, 1)
.attr({
fill: '#fff',
'stroke-width': 4,
stroke: '#fff',
zIndex: 1
})
.add();
});
});
</script>
这是我从服务器端代码收到的数组对象的json表示。
array[1]
object{
AvgIPA:7, IdeaId:17989, Likes:3, Status:2, StatusString:"Published", Title:"Spread the word", UserFullName:"Anurag Acharya", XAxis:9, YAxis:5, ZAxis:7}
现在我只通过practicalityscore数组向我的系列发送相关数据。以下是该数据的表示。
practicalityscore [1]
[5, 7, "Spread the word"]
以下是浏览器如何在图表上显示数据的屏幕截图
而不是未定义,&#34;传播单词&#34;应该显示出来。
答案 0 :(得分:0)
您可以尝试修改格式化程序,将this.point.name更改为this.point.series.name
function(){
return '<span><b>Practicality</b>: '+
Highcharts.numberFormat(this.x,0) +
'<br/><span><b>Avg IPA</b>: '+
Highcharts.numberFormat(this.y,0) +
'<br/><span><b>Idea</b>: '+ this.point.series.name;
}
不确定我是否理解你的目标,希望得到这个帮助
我尝试根据我的理解
创建一个类似的jsfiddle示例答案 1 :(得分:0)
您需要将数组替换为带有对象的点。它应该是{x:5,y:7,name:“Spread the word”}。然后在格式化程序中引用this.point.options.name