Digamos que tengo una matriz de objetos:
const arr = [ {num:3,numTwo:1}, {num:5,numTwo:3}, {num:7,numTwo:9}, {num:7,numTwo:3}, {num:8,numTwo:4} ] const goal = 7
Tengo este código que encuentra correctamente el número más cercano cuando SOLO contabiliza num
:
const closest = arr.reduce(function (prev, curr) { return Math.abs(curr.num - goal) < Math.abs(prev.num - goal) ? curr : prev; });
Devuelve {num:7,numTwo:9}
(porque es la primera instancia), pero quiero que numTwo entre en juego donde devuelve el objeto con el numTwo
más bajo si en el caso el goal
coincide con múltiples num
coincidentes, por lo que en este en caso de que devuelva {num:7,numTwo:3}
Haz que tu expresión sea una resta y usa ||
para involucrar la comparación de numTwo
cuando esa resta es 0:
const arr = [{num:3,numTwo:1},{num:5,numTwo:3},{num:7,numTwo:9},{num:7,numTwo:3},{num:8,numTwo:4}]; const goal = 7; const closest = arr.reduce(function (prev, curr) { return (Math.abs(curr.num - goal) - Math.abs(prev.num - goal) || curr.numTwo - prev.numTwo) < 0 ? curr : prev; }); console.log(closest);