Math.max不能直接处理数组,需用扩展运算符Math.max(...arr)或Math.max.apply(null, arr);含非数字项时须先清洗过滤再转换,空数组需兜底处理。
直接写 Math.max([199, 299, 249]) 得到的是 NaN,因为 Math.max() 接收的是**多个独立参数**,不是数组。浏览器控制台一试就暴露问题——这不是数据错了,是调用方式错了。
常见错误现象:Math.max(prices) 返回 NaN,但 console.log(prices) 明明打印出正确数组;或者在 React/Vue 渲染中价格显示为空白或 “NaN”。
...,即 Math.max(...prices)
Math.max.apply(null, prices),但需确保 prices 非空且全为数字"—"、null、undefined),Math.max(...prices) 会把它们转成 NaN,整结果变 NaN
真实竞品接口返回的数据常不干净:可能有 "N/A"、""、null,甚至单位字符串如 "¥299"。直接展开会崩,得先清洗。
推荐一步过滤 + 转换:
const cleanPrices = prices .filter(p => p != null && p !== '' && p !== 'N/A') .map(p => parseFloat(p.toString().replace(/[^0-9.-]/g, ''))) .filter(p => !isNaN(p) && isFinite(p));const highestPrice = cleanPrices.length > 0 ? Math.max(...cleanPrices) : null;
replace(/[^0-9.-]/g, '') 剥离货币符号、空格、中文单位,保留数字和小数点parseFloat 转数值,对非法字符串返回 NaN,后续 filter 剔除cleanPrices.length > 0,否则 Math.max(...[]) 在某些环境下返回 -Infinity
在 useMemo 或 useEffect 里写 Math.max(...prices) 却不触发更新,大概率是 prices 是引用相等的旧数组(比如浅拷贝没变)。
prices 是新数组引用:后端响应后用 [...res.data] 或 Array.from(res.data) 创建新数组useMemo 依赖项里写 prices 却没让它变化——比如每次从同一对象属性取值但对象未重建console.log('prices ref:', prices, prices === prevPrices) 看是否真变了单次计算几千个价格,Math.max(...arr) 本身很快(底层是 C++ 实现),但扩展运算符会临时创建大量参数,Chrome 下超过 ~15 万项可能报 “maximum call stack size exceeded”。
prices.reduce((max, p) => p > max ? p : max, -Infinity)
Ref 或模块级变量里,避免重复计算Math.max —— 比如表格每行都算一遍最高价,应提前算好传下去