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);