Math.sign() 返回数值符号:正数(含Infinity)为1,负数(含-Infinity)为-1,0和-0分别返回0和-0,非数字返回NaN;用于符号分支、方向归一化等场景。

Math.sign() 用于判断一个数值的正负号,返回 -1、0、1 或 NaN,不改变原值,只反映其符号状态。
返回值规则
根据输入数值的类型和大小,Math.sign() 按以下逻辑返回:
- 正数(包括
Infinity)→ 返回1 - 负数(包括
-Infinity)→ 返回-1 -
0→ 返回0 -
-0→ 返回-0(注意:严格相等===下-0 === 0为true,但Math.sign(-0)明确返回-0) - 非数字(如
NaN、undefined、字符串无法转为有效数字)→ 返回NaN
常见使用场景
适合快速做符号分支处理,比如统一归一化方向、判断增减趋势、避免重复写条件判断:
- 将任意数映射为单位方向值:
Math.sign(x) * Math.abs(y)可保留 y 的绝对值,但赋予 x 的符号 - 排序时按符号分组:
arr.sort((a, b) => Math.sign(a) - Math.sign(b)) - 检测是否为负数(比
x 更明确处理 <code>-0和NaN边界情况)
注意事项
该方法对类型敏感,不会自动强制转换:
立即学习“Java免费学习笔记(深入)”;
-
Math.sign("5")→1(字符串可解析为有效数字) -
Math.sign("abc")→NaN -
Math.sign(null)→0(null转为数字是0) -
Math.sign(undefined)→NaN(undefined转为数字是NaN) - 不支持 BigInt,
Math.sign(1n)会报错
兼容性提示
Math.sign() 是 ES6 新增方法,现代浏览器均支持;若需兼容 IE,可用简易 polyfill:
if (!Math.sign) {
Math.sign = function(x) {
x = +x;
if (x === 0 || isNaN(x)) return x;
return x > 0 ? 1 : -1;
};
}










