首頁 > 軟體

JavaScript資料結構Number

2022-02-18 13:03:27

前言:

NumberJavaScript的基本資料結構,是對應數值的應用型別。要建立一個 Number 物件,就使用 Number 建構函式並傳入一個數值。在 JavaScript 中沒有其他語言這麼多的數位型別。根據 ECMAScript 標準,數位只有一種型別,它是“雙精度 64 位二進位制格式 IEEE 754 值”。這種型別用於儲存整數和分數,相當於 Java 和 C 中的 double 資料型別。這個獨特性也就導致了 0.1+0.2 為什麼不等於 0.3。本文介紹JavaScript使用 Number 的常見問題。

先來看下下面的程式碼:

console.log(0.1 + 0.2); // 0.30000000000000004

從上面執行結果可以看出 0.1+0.2 不等於 0.3。只有分母為 2 的冪的分數才能有限地表示為二進位制形式. 由於 0.1 (1 / 10) 和 0.2 (1 / 5) 的分母不是 2 的冪,因此這些數位不能以二進位制格式有限地表示。為了將它們儲存為 IEEE-754 浮點數,它們必須四捨五入到尾數的可用位數——半精度為 10 位,單精度為 23 位,雙精度為 52 位。根據可用的精度位數,0.1 和 0.2 的浮點近似值可能比相應的十進位制表示略小或略大,但永遠不會相等。因為這個事實,永遠不會有 0.1+0.2 == 0.3。

一、NaN和Infinity

NaN 代表Not a Number 並且它不同於 Infinity,儘管兩者通常在實數的浮點表示以及浮點運算中都作為特殊情況處理。NaN 是一個特殊的值,它是唯一一個不等於自身的值,來看看下面的程式碼理解一個這個值:

const num = 9 + NaN;
console.log(num); // NaN
console.log(NaN == NaN); // false
console.log(NaN === NaN); // false
console.log(Object.is(NaN, NaN)); // true
console.log(isNaN(NaN)); // true
console.log(isNaN("devpoint")); // true
console.log(Number.isNaN(NaN)); // true
console.log(Number.isNaN("devpoint")); // false
console.log(Number.isNaN(+"devpoint")); // true

Infinity 是 JavaScript 中的一個特殊值,表示數學無窮大和溢位值,數位太大以至於“溢位”緩衝區並導致 Infinity。它是計算建立超出 JavaScript 中特殊最大值的數位的結果,該值約為1.79e+308 或 2¹⁰²⁴,即 JavaScript 中可以儲存為數位原始型別的最大值。

注意 :Infinity,-Infinity 和 NaN 是 JavaScript 中唯一的“無限”(非有限)數位。

二、常用方法

在程式中處理數位是一個常見的需求,例如序號、費用、溫度等等。下面通過程式碼展示一些常用的與 Number 有關的方法。

1.安全數位

安全數位是一個數位,其值保證可以正常顯示。例如,如果有一個變數值為 900719925474099194 ,那麼它是否安全?

下面來看 JavaScript 中安全數位的範圍是多少?如何驗證?

  • Number.MIN_SAFE_INTEGER:-9007199254740991
  • Number.MAX_SAFE_INTEGER:9007199254740991
  • Number.MAX_VALUE:1.7976931348623157e+308
  • Number.MIN_VALUE:`5e-324
const test = 900719925474099194;
console.log(Number.isSafeInteger(test)); // false
console.log(Number.isSafeInteger(9007199254740991)); // true

2.整數判斷

JavaScript 中對於數位不區分整數、小數等型別,統稱為 Number 型別。從下面的程式碼結果可以想到判斷整數的方法:

console.log(Number.isInteger(9)); // true
console.log(Number.isInteger(9 / 2)); // false
console.log(Number.isInteger(9.6)); // false
console.log(9 % 1 === 0); // true
console.log(9.1 % 1 === 0); // false
const checkInteger = (num) => (num | 0) === num;
console.log(checkInteger(9)); // true
console.log(checkInteger(9.1)); // false
console.log(checkInteger("9.0")); // false
console.log(checkInteger("")); // false

3.數位格式判斷

下面的程式碼片段將展示如何檢查一個值或變數是否包含一個數位(整數、浮點數等)。

function isNumber(n) {
    return !isNaN(parseFloat(n)) && isFinite(n);
}
console.log(isNumber(100)); // true
console.log(isNumber(3.14)); // true
console.log(isNumber("3.14")); // true
console.log(isNumber("a3.14")); // false
console.log(isNumber("JavaScript")); // false

4.四捨五入

JavaScript 中,對數值進行四捨五入操作有很多的方式,下面來一一總結一下。

向上取整:

向上取整使用 Math.ceil(),返回大於或等於 x ,並且與之最接近的整數。

console.log(Math.ceil(9.005)); // 10
console.log(Math.ceil(9.999)); // 10

四捨五入:

Math.round() 是對一個浮點數進行四捨五入,並保留整數位。語法如下:

Math.round(x)

x :需要處理的數值

返回值,返回給定數位的四捨五入後的值。

console.log(Math.round(9.005)); // 9
console.log(Math.round(9.51)); // 10
console.log(Math.round(9.49)); // 9
console.log(Math.round(9.999)); // 10

固定精度:

.toFixed()Number 原型上實現的一個方法,其作用是對一個浮點數進行四捨五入並保留固定小數位。語法如下:

numObj.toFixed(digits)

digits:小數點後數位的個數;介於 0 到 20 (包括)之間,實現環境可能支援更大範圍。如果忽略該引數,則預設為 0。
返回值,返回使用定點表示法表示給定數位的字串。

const pi = 3.14159265359;
console.log(pi.toFixed(2)); // 3.14
console.log(pi.toFixed(3)); // 3.142

固定長度:

.toPrecison() 也是 Number 原型上實現的一個處理浮點數的方法,和 toFixed 不同的是,它是對一個浮點數進行四捨五入並保留固定長度的有效數位,包括整數部分。語法如下:

numObj.toPrecision(precision)

precision:可選,一個用來指定有效數個數的整數。
返回值,以定點表示法或指數表示法表示的一個數值物件的字串表示,四捨五入到 precision 引數指定的顯示數位位數。

const pi = 3.14159265359;
console.log(pi.toPrecision(3)); // 3.14
console.log(pi.toPrecision(4)); // 3.142

向下取整:

Math.floor() 返回小於或等於一個給定數位的最大整數。

Math.floor(x)

x:一個數位。

返回值,一個表示小於或等於指定數位的最大整數的數位。

console.log(Math.floor(9.005)); // 9
console.log(Math.floor(9.51)); // 9
console.log(Math.floor(9.49)); // 9
console.log(Math.floor(9.999)); // 9

5.生成亂數

通過Math.random() 返回 0-1 之間的亂數的原理,結果乘以最大數並四捨五入即可獲得一個介於 0 和 max 之間的數位。

const randomNumber = (max) => Math.round(Math.random() * max);
console.log(randomNumber(100));

進一步完善上面的方法以可以獲取指定最小和最大範圍的亂數。

const randomNumber = (min, max) =>
    Math.round(Math.random() * (max - min) + min);
    console.log(randomNumber(51, 100));

數學函數 Math 是一個內建物件,它擁有一些數學常數屬性和數學函數方法,Math 不是一個函數物件,Math 用於 Number 型別,但它不支援 BigInt。

三、總結

JavaScriptNumber 物件是經過封裝的能讓你處理數位值的物件。介紹了JavaScript 中唯一的“無限”(非有限)數子:Infinity,-Infinity 和 NaN ,並提供了一些常用的數位處理方法。

到此這篇關於JavaScript資料結構Number的文章就介紹到這了,更多相關JavaScript-Number內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com