小码哥的IT人生

JavaScript 数字方法

JavaScript基础 2022-04-25 01:31:58小码哥的IT人生shichen

JavaScript 数字方法

Number 方法帮助您处理数值。

Number 方法和属性

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

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

toString() 方法

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

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

示例代码:

var x = 123;
x.toString();            // 从变量 x 返回 123
(123).toString();        // 从文本 123 返回 123
(100 + 23).toString();   // 从表达式 100 + 23 返回 123

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数字</h1>
<p>toString() 方法以基数 2 到 36 输出字符串:</p>
<p id="demo"></p>
<script>
var myNumber = 32;
document.getElementById("demo").innerHTML =
"32 = " + "<br>" + 
" Decimal " + myNumber.toString(10) + "<br>" +
" Hexadecimal " + myNumber.toString(16) + "<br>" +
" Octal " + myNumber.toString(8) + "<br>" +
" Binary " + myNumber.toString(2);
</script>
</body>
</html>

运行结果:

Javascript 数字

toString() 方法以基数 2 到 36 输出字符串:

32 =
Decimal 32
Hexadecimal 20
Octal 40
Binary 100000

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

toExponential() 方法

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

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

示例代码:

var x = 9.656;
x.toExponential(2);     // 返回 9.66e+0
x.toExponential(4);     // 返回 9.6560e+0
x.toExponential(6);     // 返回 9.656000e+0

完整实例:

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

运行结果:

Javascript 数字方法

toExponential() 方法返回一个字符串,包含进行舍入的数字并使用指数表示法。

可选参数定义小数点后面的位数。

9.656e+0
9.66e+0
9.6560e+0
9.656000e+0

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

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

toFixed() 方法

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

示例代码:

var x = 9.656;
x.toFixed(0);           // 返回 10
x.toFixed(2);           // 返回 9.66
x.toFixed(4);           // 返回 9.6560
x.toFixed(6);           // 返回 9.656000

完整实例:

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

运行结果:

Javascript 数字方法

toFixed() 方法将数字四舍五入为给定的位数。

对于处理金钱,toFixed(2) 是完美的。

10
9.66
9.6560
9.656000

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

toFixed(2) 非常适合处理金钱。

toPrecision() 方法

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

示例代码:

var x = 9.656;
x.toPrecision();        // 返回 9.656
x.toPrecision(2);       // 返回 9.7
x.toPrecision(4);       // 返回 9.656
x.toPrecision(6);       // 返回 9.65600

完整实例:

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

运行结果:

Javascript 数字方法

toPrecision() 方法返回一个字符串,其中包含一个用指定长度写的数字:

9.656
9.7
9.656
9.65600

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

valueOf() 方法

valueOf() 以数值返回数值:

示例代码:

var x = 123;
x.valueOf();            // 从变量 x 返回 123
(123).valueOf();        // 从文本 123 返回 123
(100 + 23).valueOf();   // 从表达式 100 + 23 返回 123

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数字方法</h1>
<p>valueOf() 把数字返回为数字:</p>
<p id="demo"></p>
<script>
var x = 123;
document.getElementById("demo").innerHTML = 
  x.valueOf() + "<br>" +
  (123).valueOf() + "<br>" +
  (100 + 23).valueOf();
</script>
</body>
</html>

运行结果:

Javascript 数字方法

valueOf() 把数字返回为数字:

123
123
123

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

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

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

没有理由在代码中使用它。

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

把变量转换为数值

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

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

这些方法并非数字方法,而是全局 JavaScript 方法。

全局方法

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

这些是在处理数字时最相关的方法:

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

Number() 方法

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

示例代码:

x = true;
Number(x);        // 返回 1
x = false;     
Number(x);        // 返回 0
x = new Date();
Number(x);        // 返回 1404568027739
x = "10"
Number(x);        // 返回 10
x = "10 20"
Number(x);        // 返回 NaN

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 全局方法</h1>
<p>Number() 方法把变量转换为数字:</p>
<p id="demo"></p>
<script>
document.getElementById("demo").innerHTML = 
  Number(true) + "<br>" +
  Number(false) + "<br>" +
  Number("10") + "<br>" + 
  Number("  10") + "<br>" +
  Number("10  ") + "<br>" +
  Number(" 10  ") + "<br>" +
  Number("10.33") + "<br>" + 
  Number("10,33") + "<br>" +
  Number("10 33") + "<br>" +
  Number("Bill");
</script>
</body>
</html>

运行结果:

Javascript 全局方法

Number() 方法把变量转换为数字:

1
0
10
10
10
10
10.33
NaN
NaN
NaN

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

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

用于日期的 Number() 方法

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

示例代码:

Number(new Date("2019-04-15"));    // 返回 1506729600000

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 全局方法</h1>
<p>Number() 方法可以把日期转换为数字:</p>
<p id="demo"></p>
<script>
var x = new Date("2017-09-30");
document.getElementById("demo").innerHTML = Number(x); 
</script>
</body>
</html>

运行结果:

Javascript 全局方法

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

1506729600000

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

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

parseInt() 方法

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

示例代码:

parseInt("10");         // 返回 10
parseInt("10.33");      // 返回 10
parseInt("10 20 30");   // 返回 10
parseInt("10 years");   // 返回 10
parseInt("years 10");   // 返回 NaN

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 全局函数</h1>
<p>全局 JavaScript 函数  parseInt() 把字符串转换为数字:</p>
<p id="demo"></p>
<script>
document.getElementById("demo").innerHTML = 
  parseInt("10") + "<br>" +
  parseInt("10.33") + "<br>" +
  parseInt("10 6") + "<br>" +  
  parseInt("10 years") + "<br>" +  
  parseInt("years 10");  
</script>
</body>
</html>

运行结果:

Javascript 全局函数

全局 Javascript 函数 parseInt() 把字符串转换为数字:

10
10
10
10
NaN

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

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

parseFloat() 方法

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

示例代码:

parseFloat("10");        // 返回 10
parseFloat("10.33");     // 返回 10.33
parseFloat("10 20 30");  // 返回 10
parseFloat("10 years");  // 返回 10
parseFloat("years 10");  // 返回 NaN

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 全局方法</h1>
<p>parseFloat() 方法把字符串转换为数字:</p>
<p id="demo"></p>
<script>
document.getElementById("demo").innerHTML = 
  parseFloat("10") + "<br>" +
  parseFloat("10.33") + "<br>" +
  parseFloat("10 6") + "<br>" +  
  parseFloat("10 years") + "<br>" +
  parseFloat("years 10");    
</script>
</body>
</html>

运行结果:

Javascript 全局方法

parseFloat() 方法把字符串转换为数字:

10
10.33
10
10
NaN

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.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 中可能的最大数字。

示例代码:

var x = Number.MAX_VALUE;

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript Number 对象属性</h1>
<p>MAX_VALUE 返回 JavaScript 中可能的最大值。</p>
<p id="demo"></p>
<script>
var x = Number.MAX_VALUE;
document.getElementById("demo").innerHTML = x;
</script>
</body>
</html>

运行结果:

Javascript Number 对象属性

MAX_VALUE 返回 Javascript 中可能的最大值。

1.7976931348623157e+308

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

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

示例代码:

var x = Number.MIN_VALUE;

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript Number 对象属性</h1>
<p>MIN_VALUE 返回 JavaScript 中可能的最小数字。</p>
<p id="demo"></p>
<script>
var x = Number.MIN_VALUE;
document.getElementById("demo").innerHTML = x;
</script>
</body>
</html>

运行结果:

Javascript Number 对象属性

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

5e-324

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

JavaScript POSITIVE_INFINITY

示例代码:

var x = Number.POSITIVE_INFINITY;

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript Number 对象属性</h1>
<p>POSITIVE_INFINITY</p>
<p id="demo"></p>
<script>
var x = Number.POSITIVE_INFINITY;
document.getElementById("demo").innerHTML = x;
</script>
</body>
</html>

运行结果:

Javascript Number 对象属性

POSITIVE_INFINITY

Infinity

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

溢出时返回 POSITIVE_INFINITY

示例代码:

var x = 1 / 0;

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript Number 对象属性</h1>
<p>溢出时返回 POSITIVE_INFINITY:</p>
<p id="demo"></p>
<script>
var x = 1 / 0;
document.getElementById("demo").innerHTML = x;
</script>
</body>
</html>

运行结果:

Javascript Number 对象属性

溢出时返回 POSITIVE_INFINITY:

Infinity

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

JavaScript NEGATIVE_INFINITY

示例代码:

var x = Number.NEGATIVE_INFINITY;

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript Number 对象属性</h1>
<p>NEGATIVE_INFINITY</p>
<p id="demo"></p>
<script>
var x = Number.NEGATIVE_INFINITY;
document.getElementById("demo").innerHTML = x;
</script>
</body>
</html>

运行结果:

Javascript Number 对象属性

NEGATIVE_INFINITY

-Infinity

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

溢出时返回 NEGATIVE_INFINITY

示例代码:

var x = -1 / 0;

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript Number 对象属性</h1>
<p>NEGATIVE_INFINITY</p>
<p id="demo"></p>
<script>
var x = -1 / 0;
document.getElementById("demo").innerHTML = x;
</script>
</body>
</html>

运行结果:

Javascript Number 对象属性

NEGATIVE_INFINITY

-Infinity

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

JavaScript NaN - 非数字

示例代码:

var x = Number.NaN;

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript Number 对象属性</h1>
<p id="demo"></p>
<script>
document.getElementById("demo").innerHTML = Number.NaN;
</script>
</body>
</html>

运行结果:

Javascript Number 对象属性

NaN

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

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

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

示例代码:

var x = 100 / "Apple";  // x 将是 NaN (Not a Number)

完整实例:

<!DOCTYPE html>
<html>
<body>
<h1>JavaScript 数字</h1>
<p>数字除以非数字字符串会成为 NaN (Not a Number):</p>
<p id="demo"></p>
<script>
document.getElementById("demo").innerHTML = 100 / "Apple";
</script>
</body>
</html>

运行结果:

Javascript 数字

数字除以非数字字符串会成为 NaN (Not a Number):

NaN

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

数字属性不可用于变量

数字属性属于名为 number 的 JavaScript 数字对象包装器。

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

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

示例代码:

var x = 6;
var y = x.MAX_VALUE;    // y 成为 undefined

完整实例:

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

运行结果:

Javascript Number 对象属性

对变量、表达式或值使用数字属性,将返回 undefined:

undefined

可以使用本站在线JavaScript测试工具测试上述代码运行效果:http://www.phpcodeweb.com/runjs.html

完整的 JavaScript Number 参考手册

如需完整的参考手册,请访问我们完整的 JavaScript Number 参考手册

参考手册包含所有 Number 对象属性和方法的描述和实例。

版权所有 © 小码哥的IT人生
Copyright © phpcodeweb All Rights Reserved
ICP备案号:苏ICP备17019232号-2  

苏公网安备 32030202000762号

© 2021-2024