JavaScript 数值方法

JavaScript 数值方法是专门用于处理数值类型的数据,比如字符串转数字,数字四舍五入等。


Number 方法和属性

原始值(比如 3.14 或 2016),无法拥有属性和方法(因为它们不是对象)。

但是通过 JavaScript,方法和属性也可用于原始值,因为 JavaScript 在执行方法和属性时将原始值视作对象。


toString() 方法

toString() 以字符串返回数值。

所有数字方法可用于任意类型的数字(字面量、变量或表达式):

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript 数字</h1>
  5. <p>toString() 方法以基数 2 到 36 输出字符串:</p>
  6. <p id="demo">
  7. <script>
  8. var myNumber = 32;
  9. document.getElementById("demo").innerHTML =
  10. "32 = " + "<br>" +
  11. " Decimal " + myNumber.toString(10) + "<br>" +
  12. " Hexadecimal " + myNumber.toString(16) + "<br>" +
  13. " Octal " + myNumber.toString(8) + "<br>" +
  14. " Binary " + myNumber.toString(2);
  15. </script>
  16. </body>
  17. </html>

toExponential() 方法

toExponential() 返回字符串值,它包含已被四舍五入并使用指数计数法的数字。

参数定义小数点后的字符数:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript 数字方法</h1>
  5. <p>toExponential() 方法返回一个字符串,包含进行舍入的数字并使用指数表示法。</p>
  6. <p>可选参数定义小数点后面的位数。</p>
  7. <p id="demo">
  8. <script>
  9. var x = 9.656;
  10. document.getElementById("demo").innerHTML =
  11. x.toExponential() + "<br>" +
  12. x.toExponential(2) + "<br>" +
  13. x.toExponential(4) + "<br>" +
  14. x.toExponential(6);
  15. </script>
  16. </body>
  17. </html>

该参数是可选的。如果您没有设置它,JavaScript 不会对数字进行4舍5入。


toFixed() 方法

toFixed() 返回字符串值,它包含了指定位数小数的数字:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript 数字方法</h1>
  5. <p>toFixed() 方法将数字四舍五入为给定的位数。</p>
  6. <p>对于处理金钱,toFixed(2) 是完美的。</p>
  7. <p id="demo">
  8. <script>
  9. var x = 9.656;
  10. document.getElementById("demo").innerHTML =
  11. x.toFixed(0) + "<br>" +
  12. x.toFixed(2) + "<br>" +
  13. x.toFixed(4) + "<br>" +
  14. x.toFixed(6);
  15. </script>
  16. </body>
  17. </html>

toFixed(2) 非常适合处理货币类型数据。


toPrecision() 方法

toPrecision() 返回字符串值,它包含了指定长度的数字:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript 数字方法</h1>
  5. <p>toPrecision() 方法返回一个字符串,其中包含一个用指定长度写的数字:</p>
  6. <p id="demo">
  7. <script>
  8. var x = 9.656;
  9. document.getElementById("demo").innerHTML =
  10. x.toPrecision() + "<br>" +
  11. x.toPrecision(2) + "<br>" +
  12. x.toPrecision(4) + "<br>" +
  13. x.toPrecision(6);
  14. </script>
  15. </body>
  16. </html>

valueOf() 方法

valueOf() 以数值返回数值:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript 数字方法</h1>
  5. <p>valueOf() 把数字返回为数字:</p>
  6. <p id="demo">
  7. <script>
  8. var x = 123;
  9. document.getElementById("demo").innerHTML =
  10. x.valueOf() + "<br>" +
  11. (123).valueOf() + "<br>" +
  12. (100 + 23).valueOf();
  13. </script>
  14. </body>
  15. </html>

在 JavaScript 中,数字可以是原始值(typeof = number)或对象(typeof = object)。

在 JavaScript 内部使用 valueOf() 方法可将 Number 对象转换为原始值。

所有 JavaScript 数据类型都有 valueOf() 和 toString() 方法。


把变量转换为数值

这三种常用 JavaScript 全局方法可用于将变量转换为数字:

  • Number() 方法
  • parseInt() 方法
  • parseFloat() 方法

全局方法

JavaScript 全局方法可用于所有 JavaScript 数据类型。

方法描述
Number()返回数字,由其参数转换而来。
parseFloat()解析其参数并返回浮点数。
parseInt()解析其参数并返回整数。

Number() 方法

Number() 可用于把 JavaScript 变量转换为数值:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript 全局方法</h1>
  5. <p>Number() 方法把变量转换为数字:</p>
  6. <p id="demo">
  7. <script>
  8. document.getElementById("demo").innerHTML =
  9. Number(true) + "<br>" +
  10. Number(false) + "<br>" +
  11. Number("10") + "<br>" +
  12. Number(" 10") + "<br>" +
  13. Number("10 ") + "<br>" +
  14. Number(" 10 ") + "<br>" +
  15. Number("10.33") + "<br>" +
  16. Number("10,33") + "<br>" +
  17. Number("10 33") + "<br>" +
  18. Number("John");
  19. </script>
  20. </body>
  21. </html>

如果无法转换数字,则返回 NaN。


用于日期的 Number() 方法

Number() 还可以把日期转换为数字:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript 全局方法</h1>
  5. <p>Number() 方法可以把日期转换为数字:</p>
  6. <p id="demo">
  7. <script>
  8. var x = new Date("2017-09-30");
  9. document.getElementById("demo").innerHTML = Number(x);
  10. </script>
  11. </body>
  12. </html>

上面的 Number() 方法返回 1970 年 1 月 1 日至今的毫秒数。


parseInt() 方法

parseInt() 解析一段字符串并返回数值。允许空格。只返回首个数字:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript 全局函数</h1>
  5. <p>全局 JavaScript 函数 parseInt() 把字符串转换为数字:</p>
  6. <p id="demo">
  7. <script>
  8. document.getElementById("demo").innerHTML =
  9. parseInt("10") + "<br>" +
  10. parseInt("10.33") + "<br>" +
  11. parseInt("10 6") + "<br>" +
  12. parseInt("10 years") + "<br>" +
  13. parseInt("years 10");
  14. </script>
  15. </body>
  16. </html>

如果无法转换为数值,则返回 NaN (Not a Number)。


parseFloat() 方法

parseFloat() 解析一段字符串并返回数值。允许空格。只返回首个数字:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript 全局方法</h1>
  5. <p>parseFloat() 方法把字符串转换为数字:</p>
  6. <p id="demo">
  7. <script>
  8. document.getElementById("demo").innerHTML =
  9. parseFloat("10") + "<br>" +
  10. parseFloat("10.33") + "<br>" +
  11. parseFloat("10 6") + "<br>" +
  12. parseFloat("10 years") + "<br>" +
  13. parseFloat("years 10");
  14. </script>
  15. </body>
  16. </html>

如果无法转换为数值,则返回 NaN (Not a Number)。


数值属性

属性描述
MAX_VALUE返回 JavaScript 中可能的最大数。
MIN_VALUE返回 JavaScript 中可能的最小数。
NEGATIVE_INFINITY表示负的无穷大(溢出返回)。
NaN表示非数字值("Not-a-Number")。
POSITIVE_INFINITY表示无穷大(溢出返回)。

JavaScript MIN_VALUE 和 MAX_VALUE

MAX_VALUE 返回 JavaScript 中可能的最大数字。

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript Number 对象属性</h1>
  5. <p>MAX_VALUE 返回 JavaScript 中可能的最大值。</p>
  6. <p id="demo">
  7. <script>
  8. var x = Number.MAX_VALUE;
  9. document.getElementById("demo").innerHTML = x;
  10. </script>
  11. </body>
  12. </html>

MIN_VALUE 返回 JavaScript 中可能的最小数字。

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript Number 对象属性</h1>
  5. <p>MIN_VALUE 返回 JavaScript 中可能的最小数字。</p>
  6. <p id="demo">
  7. <script>
  8. var x = Number.MIN_VALUE;
  9. document.getElementById("demo").innerHTML = x;
  10. </script>
  11. </body>
  12. </html>

JavaScript POSITIVE_INFINITY

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript Number 对象属性</h1>
  5. <p>POSITIVE_INFINITY</p>
  6. <p id="demo">
  7. <script>
  8. var x = Number.POSITIVE_INFINITY;
  9. document.getElementById("demo").innerHTML = x;
  10. </script>
  11. </body>
  12. </html>

溢出时返回 POSITIVE_INFINITY:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript Number 对象属性</h1>
  5. <p>溢出时返回 POSITIVE_INFINITY:</p>
  6. <p id="demo">
  7. <script>
  8. var x = 1 / 0;
  9. document.getElementById("demo").innerHTML = x;
  10. </script>
  11. </body>
  12. </html>

JavaScript NEGATIVE_INFINITY

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript Number 对象属性</h1>
  5. <p>NEGATIVE_INFINITY</p>
  6. <p id="demo">
  7. <script>
  8. var x = Number.NEGATIVE_INFINITY;
  9. document.getElementById("demo").innerHTML = x;
  10. </script>
  11. </body>
  12. </html>

溢出时返回 NEGATIVE_INFINITY:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript Number 对象属性</h1>
  5. <p>NEGATIVE_INFINITY</p>
  6. <p id="demo">
  7. <script>
  8. var x = -1 / 0;
  9. document.getElementById("demo").innerHTML = x;
  10. </script>
  11. </body>
  12. </html>

JavaScript NaN - 非数字

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript Number 对象属性</h1>
  5. <p id="demo">
  6. <script>
  7. document.getElementById("demo").innerHTML = Number.NaN;
  8. </script>
  9. </body>
  10. </html>

NaN 属于 JavaScript 保留字,指示数字并非合法的数字。

尝试使用非数字字符串进行算术运算将导致 NaN(非数字):

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript 数字</h1>
  5. <p>数字除以非数字字符串会成为 NaN (Not a Number):</p>
  6. <p id="demo">
  7. <script>
  8. document.getElementById("demo").innerHTML = 100 / "Apple";
  9. </script>
  10. </body>
  11. </html>

数字属性不可用于变量

数字属性属于名为 Number 的 JavaScript 数字对象。

这些属性只能作为 Number.MAX_VALUE 访问。

使用 myNumber.MAX_VALUE,其中 myNumber 是变量、表达式或值,将返回 undefined:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <h1>JavaScript Number 对象属性</h1>
  5. <p>对变量、表达式或值使用数字属性,将返回 undefined:</p>
  6. <p id="demo">
  7. <script>
  8. var x = 6;
  9. document.getElementById("demo").innerHTML = x.MAX_VALUE;
  10. </script>
  11. </body>
  12. </html>

完整的 JavaScript Number 参考手册

如需完整的参考手册,请访问本站的 JavaScript Number 参考手册。