我有一个像这样的数组:arr = {lst1: 300, lst2: 381, lst3: 4, lst4: 4, lst5: 49, …}
我正在尝试使用Javascript获得最低的键值。
我尝试过的事情:
alert(Math.min.apply(Math, arr));
返回Infinity
我不知道为什么
我在Google上找到了它,只是为了尝试:
var keys = Object.keys(arr).map(Number).filter(function(a){
return arr[a];
}); alert(Math.min.apply(Math, keys));
也返回Infinity
我想要更完整的东西,例如以下输出:“最低值是lst9中的2”。
在问这里之前,我真的尝试过自己修复它,但是没有成功! 您能帮我解决此“ Infinity”问题吗?谢谢。
答案 0 :(得分:15)
您可以使用Object.entries
获取键和值:
var arr = {
lst1: 300,
lst2: 381,
lst3: 4,
lst4: 4,
lst5: 49
};
function lowestValueAndKey(obj) {
var [lowestItems] = Object.entries(obj).sort(([ ,v1], [ ,v2]) => v1 - v2);
return `Lowest value is ${lowestItems[1]}, with a key of ${lowestItems[0]}`;
}
var lowest = lowestValueAndKey(arr);
console.log(lowest);
答案 1 :(得分:9)
有几种方法可以达到您想要的。请查看以下方法:
const obj = { lst1: 300, lst2: 381, lst3: 4, lst4: 4, lst5: 49 }
const values = Object.values(obj)
const lowest = Math.min.apply(null, values)
// Using Object.keys(), Object.values() and findIndex()
const keys = Object.keys(obj)
const indexOfLowest = values.findIndex(function (x) { return x === lowest })
console.log(`The lowest value is ${lowest} from ${keys[indexOfLowest]}`)
// OR Using Object.keys() and filter()
const key = Object.keys(obj).filter(function (x) { return obj[x] === lowest })[0]
console.log(`The lowest value is ${lowest} from ${key}`)
// OR Using Object.entries() and sort()
const [[lowestKey, lowestVal]] = Object.entries(obj).sort(function ([,valA], [,valB]) { return valA - valB });
console.log(`The lowest value is ${lowestVal} from ${lowestKey}`)
答案 2 :(得分:9)
有很多方法可以解决您的问题,但这是一种简单的替代方法。基本上,这是一种蛮力做事的方式,您可以遍历每个属性以检查其值。
const obj = {lst1: 300, lst2: 381, lst3: 4, lst4: 4, lst5: 49};
const getSmallest = function (object) {
let smallestValue = Number.MAX_VALUE;
let selectedKey = '';
for (let key in object) {
if (object[key] < smallestValue) {
smallestValue = object[key];
selectedKey = key;
}
};
console.log(selectedKey, smallestValue)
return `The lowest value is ${smallestValue} from ${selectedKey}`;
};
getSmallest(obj);
答案 3 :(得分:5)
要仅获取最小数量,可以使用Math.min(...Object.entries(arr).map(o => o[1]))
:
const arr = {lst1: 300, lst2: 381, lst3: 4, lst4: 4, lst5: 49};
const lowestValue = Math.min(...Object.entries(arr).map(o => o[1]));
console.log(lowestValue);
要获得最小值,可以使用Object.entries(arr).reduce((a, [k, v]) => a[Object.keys(a)[0]] < v ? a : {[k]: v}, {})
:
const arr = {lst1: 300, lst2: 381, lst3: 4, lst4: 4, lst5: 49};
const lowestObj = Object.entries(arr).reduce((a, [k, v]) => a[Object.keys(a)[0]] < v ? a : {[k]: v}, {});
console.log(lowestObj);
答案 4 :(得分:4)
在这里,我们首先假设min,key和value分别是第一个属性和值。然后,我们遍历所有元素并与minValue进行比较,以找到小于该对象中任何值的任何值。如果是,那么我们将同时更新minValue和minKey。无论如何,arr类型是一个对象。它不是javascript中的数组。
var arr = {lst1: 300, lst2: 381, lst3: 4, lst4: 4, lst5: 49};
var minkey = Object.keys(arr)[0];
var minValue = arr[Object.keys(arr)[0]];
for (var key in arr) {
if (arr.hasOwnProperty(key)) {
if(arr[key] < minValue){
minValue = arr[key];
minKey = key;
}
}
}
答案 5 :(得分:3)
您可以尝试以下方法:
Windows
答案 6 :(得分:2)
您可以尝试以下方法:
obj = {lst1: 300, lst2: 381, lst3: 4, lst4: 4, lst5: 49, lst9: 2}; // This is an object, That;s ehy you getting infinite
var arr = Object.keys( obj ).map(function ( key ) { return obj[key]; });
alert(Math.min.apply( null, arr ));
答案 7 :(得分:2)
虽然不是最佳方法,但它很容易,因为它遍历数组两次:找到最小值,然后找到属于它的键。
arr = {lst1: 300, lst2: 381, lst3: 4, lst4: 4, lst5: 49, lst9: 2}
min = Math.min(...Object.values(arr));
minkey = Object.keys(arr).find(key => arr[key] = min);
console.log(`Lowest is ${min} at ${minkey}`);
答案 8 :(得分:2)
您可以使用Object.entries
并使用Array.reduce
将生成的[键-值]对减少为具有最低条目的对象:
const data = {lst1: 300, lst2: -381, lst3: 4, lst4: 4, lst5: 49, lst6: -49, lst7: 0, lst7: 78, lst7: -90};
const obj = Object.entries(data).reduce((acc, [key, value]) =>{
acc["lowest"] = acc["lowest"] ? Object.values(acc["lowest"])[0] < value ? acc["lowest"] : {[key] : value} : {[key] : value };
return acc;
}, {});
console.log(`Lowest value is found in ${JSON.stringify(obj.lowest)}`);
答案 9 :(得分:0)
您可以使用Object.entries
和Array.reduce
跟踪最小配对:
const findKeyForMin = obj => Object.entries(obj).reduce(([accKey, accVal], [curKey, curVal]) =>
/* Change `<` to `<=` to find the last minimum instead of the first minimum. */
curVal < accVal ? [curKey, curVal] : [accKey, accVal]
)[0];