我有一个数组,我需要找到最高值,所以当我将它应用于Highchart时,如果它超过用户输入的动态数字,我可以为背景着色。
我的代码如下所示:
<div id="highest"></div>
var array = {
data: [123, 234, 456, 789],
data: [321, 654, 987],
data: [963, 852, 741]
};
for (var i=0; i < array.data.length; i++){
var m = Math.max.apply(Math, array.data);
$('#highest').append('<div>'+m+'</div>');
}
我得到的只是数字
<div>963</div>
<div>963</div>
<div>963</div>
答案 0 :(得分:4)
您的array
变量不是数组([]
),它是一个对象({}
)。使用键data
在对象中有多个项目,但每个键只允许一个值。
所以你基本上写了这个:
var array = {
data: [963, 852, 741]
};
也许你想要这样的东西?
var array = [
{data: [123, 234, 456, 789]},
{data: [321, 654, 987]},
{data: [963, 852, 741]}
];
var values = [];
for (var i=1; i < array.length; i++) {
values.push.apply(values, array[i].data);
}
$('#highest').append('<div>' + Math.max.apply(Math, values) + '</div>');
或完全摆脱data
,只需将其作为一个数组数组。
答案 1 :(得分:3)
首先制作一个合适的嵌套数组。然后,您可以使用.map()
执行此操作:
var array = [
[123, 234, 456, 789],
[321, 654, 987],
[963, 852, 741]
];
var maxVals = array.map(function(a) {
return Math.max.apply(Math, a);
});
或者像这样:
var maxVals = array.map(Function.apply.bind(Math.max, Math));
答案 2 :(得分:2)
嗯,这不是一个数组,它是一个带有重复键的对象,所以你只是循环覆盖所有其他键的最后一个。
试试这个http://jsbin.com/olahuq/2/edit
var obj = {
a: [123, 234, 456, 789],
b: [321, 654, 987],
c: [963, 852, 741]
};
var max = [];
for (var i in obj) {
max.push(Math.max.apply(0, obj[i]));
}
$('#highest').append('<div>'+ max.join('</div><div>') +'<div>');
尽管你可以使用一组对象。
答案 3 :(得分:1)
不确定你在这里要做什么。该“数组”变量被定义为一个对象。 JavaScript中的对象文字需要唯一的键。您在“数组”对象中使用“数据”键入的最后一个数组是解释器唯一选择的数组。
你可能想要这个吗?
var data = [
[123, 234, 456, 789],
[321, 654, 987],
[963, 852, 741]
];
for (var i=0; i < data.length; i++){
var m = Math.max.apply(Math, data[i]);
$('#highest').append('<div>'+m+'</div>');
}
答案 4 :(得分:0)
您正在使用具有相同名称的多个密钥,这些密钥不是有效的JavaScript(嗯,代码可能仍在运行,但您无法获得您期望的结果)。这很容易修复,但只需使用数组:
var arr = [
[123, 234, 456, 789],
[321, 654, 987],
[963, 852, 741]
];
for (var i=0; i < arr.length; i++){
var m = Math.max.apply(Math, arr[i]);
$('#highest').append('<div>'+m+'</div>');
}
你可以使用一个对象执行此操作,但我没有看到任何理由,除非您从服务或其他内容中读取此数据并且无法更改其格式。
答案 5 :(得分:0)
我只想添加另一种简化的方式。
var obj = {
a: [123, 234, 456, 789],
b: [321, 654, 987],
c: [963, 852, 741]
};
var max = Math.max.apply(0, [].concat.apply([], Object.values(obj)));
但是,这可能会混淆在生产代码中使用,我宁愿使用reduce
来提高可读性。
var max = Object.values(obj)
.reduce((a, d) => a.concat(d), [])
.reduce((p, c) => Math.max(p, c));
最后,您也可以使用sort方法替换后者的reduce:
var max = Object.values(obj)
.reduce((a, d) => a.concat(d), [])
.sort((l, r) => l - r)
.pop();