【JSリファレンス】new Number()
更新日:2024/06/14
Numberコンストラクターは、数値を内部値に持つNumberオブジェクトを生成します。
Numberオブジェクトが持つ内部値を後から変更することはできません。
そのため数値演算等を行うことを目的としてNumberオブジェクトを使用する、ということはありません。
Numberオブジェクトは、数値(Number型)に関連するメソッドを提供するラッパーオブジェクトとして機能することを主な目的としています。
■構文
new Number ( value )
- value: Numberオブジェクトの内部値として設定する値
非数値は数値に変換される
parseInt()( Global.parseInt )は先頭から非数値文字の直前までを数値に変換しましたが、new Number()は非数値が含まれている場合 NaN に変換されます。
■使用例
// number値 ⇒ Numberオブジェクト
console.log( new Number( 100 ) ); // Number{100}
// BigInt値 ⇒ Numberオブジェクト
console.log( new Number( 100n ) ); // Number{100}
// 数値文字列 ⇒ Numberオブジェクト
console.log( new Number( "100" ) ); // Number{100}
// bool値 ⇒ Numberオブジェクト
console.log( new Number( true ) ); // Number{1}
▶NaN値へ変換
// NaN ⇒ Numberオブジェクト
console.log( new Number( NaN ) ); // Number{NaN}
// 非数値文字列 ⇒ Numberオブジェクト
console.log( new Number( "100A" ) ); // Number{NaN}
// オブジェクト ⇒ Numberオブジェクト
console.log( new Number( {} ) ); // Number{NaN}
▶TypeError
// Symbol ⇒ Numberオブジェクト
console.log( new Number( Symbol() ) ); // TypeError
▶数値として評価されるオブジェクト
const obj = {
valueOf:()=>100
}
// オブジェクト ⇒ Numberオブジェクト
console.log( new Number( obj ) ); // Number{100}
更新日:2024/06/14
スポンサーリンク
記事の内容について

こんにちはけーちゃんです。
説明するのって難しいですね。
「なんか言ってることおかしくない?」
たぶん、こんなご意見あると思います。
裏付けを取りながら記事を作成していますが、僕の勘違いだったり、そもそも情報源の内容が間違えていたりで、正確でないことが多いと思います。
そんなときは、ご意見もらえたら嬉しいです。
掲載コードについては事前に動作確認をしていますが、貼り付け後に体裁を整えるなどをした結果動作しないものになっていることがあります。
生暖かい視線でスルーするか、ご指摘ください。
ご意見、ご指摘はこちら。
https://jsref.affi-sapo-sv.com/info.php
このサイトは、リンクフリーです。大歓迎です。