JavaScript の値は常に特定の型です。例えば、文字列や数値です。
JavaScript には8つの基本的なデータ型があります。ここでは基本を学び、次のチャプターでそれらの詳細について話しましょう。
なお、変数はどんなデータでも入れることができます。変数はある時点では文字列で、その後数値を設定することができます:
// エラーなし
let message = "hello";
message = 123456;
このようなことができるプログラミング言語は “動的型付け” と呼ばれ、データ型はありますが、変数はそのどれにもバインドされないことを意味します。
数値
let n = 123;
n = 12.345;
数値 型は整数と浮動小数点両方に使われます。
数値に関する多くの操作があります、 e.g. 乗算 *
, 除算 /
, 加算 +
, 減算 -
など。
通常の数値に加えて、これらのタイプに属する “特別な数値型” もあります。: Infinity
、 -Infinity
、 NaN
.
-
Infinity
は数学的な無限大 ∞ を表します。どの値よりも大きい特別な値です。ゼロによる除算でそれを得ることができます。:
alert( 1 / 0 ); // 無限大
もしくは、単にコードに直接書くこともできます:
alert( Infinity ); // 無限大
-
NaN
は計算上のエラーを表します。正しくないもしくは未定義の数学的な操作の結果です。例:alert( "not a number" / 2 ); // NaN, このような除算は誤りです
NaN
は粘着性です。NaN
以降はどのような操作をしてもNaN
になります:alert( "not a number" / 2 + 5 ); // NaN
そのため、数学的な表現の中のどこかに
NaN
がある場合、結果全体に伝搬します。
JavaScriptでは数学をするのは安全です。ゼロによる除算、数値ではない文字列を数値として扱う、など何でもできます。
スクリプトは致命的なエラー(“死”)で止まることはありません。 最悪の場合でも NaN という結果になります。
特別な数値は正式には “数値” 型に所属します。もちろん、常識では数値ではありませんが。
チャプター 数値 でより数値の動作について見ていきます。
BigInt
JavaScript では、“数値” 型は (253-1)
(つまり 9007199254740991
) より大きい、あるいは負値であれば -(253-1)
より小さい整数を表現することができません。これらは内部表現に起因する技術的な制限です。
ほとんどの目的ではこれで十分ですが、場合によっては非常に大きな数が必要になります。例えば暗号化やマイクロ秒の精度のタイムスタンプです。
BigInt
型は任意の長さの整数を表現するために、最近言語に追加された型です。
BigInt
の値は整数値の末尾に n
を追加することで作成されます:
// 末尾の "n" は BigInt を意味します
const bigInt = 1234567890123456789012345678901234567890n;
BigInt
の数値はめったに必要とされないのでここでは説明しませんが、別のチャプター BigInt で記載しています。このような大きな数値が必要なときは参照してください。
現時点では、BigInt
は Firefox/Chrome/Edge/Safari でサポートされていますが、IE ではサポートされていません。
MDN BigInt compatibility table で、どのバージョンのブラウザがサポートしているか確認できます。
文字列
JavaScriptの文字列は引用符で囲む必要があります。
let str = "Hello";
let str2 = 'Single quotes are ok too';
let phrase = `can embed ${str}`;
JavScriptでは3種類の引用符があります。
- ダブルクォート:
"Hello"
. - シングルクォート:
'Hello'
. - バッククォート:
`Hello`
.
ダブル/シングルクォートは “シンプルな” 引用符です。JavaScriptの中ではそれらに違いはありません。
バッククォートは “拡張機能” の引用符です。変数を ${…}
の中にラップすることで、変数を埋め込み文字列の中で表現することができます。たとえば:
let name = "John";
// 変数が埋め込まれた場合
alert( `Hello, ${name}!` ); // Hello, John!
// 式が埋め込まれた場合
alert( `the result is ${1 + 2}` ); // 結果は 3
${…}
の中の表現は評価され、結果は文字列の一部になります。そこには何でも置くことができます: name
のような変数、1 + 2
のような算術表現、またはより複雑なものを書くこともできます。
これはバッククォートでのみ可能なことに留意してください。他のクォートはこのような埋め込みは許容しません!
alert( "the result is ${1 + 2}" ); // 結果は ${1 + 2} です(ダブルクォートは何もしません)
チャプター文字列 で、より深く文字列の説明をします。
言語によっては、1文字のための特別な “文字” 型があります。たとえば、C言語やJavaでは、それは char
です。
JavaScriptではこのような型はありません。string
型の1つなだけです。文字列は単一の文字または複数の文字から構成されます。
boolean (論理型)
boolean 型は2つの値だけを持ちます: true
と false
この型は通常 yes/no の値を格納するために使われます: true
は “yes” を意味し、 false
は “no, 正しくない” を意味します。
例:
let nameFieldChecked = true; // yes, 名前フィールドはチェックされている
let ageFieldChecked = false; // no, 年齢フィールドは未チェック
Boolean 値は比較の結果としても使われます:
let isGreater = 4 > 1;
alert( isGreater ); // true (比較結果は "yes" です)
後ほどチャプター論理演算子でbooleanのより詳細を説明します。
“null” 値
特殊な null
値は上で述べたどの型にも属しません。
それは自身の別の型を形成し、null
値だけを含みます。
let age = null;
JavaScriptでは、 null
は他の言語のような “存在しないオブジェクトへの参照” または “null へのポインタ” ではありません。
それは、 “無し”、“空” または “不明な値” と言った意味を持つ特別な値です。
上のコードは、 age
は何らかの理由で不明な値もしくは空であることを述べています。
“undefined” 値
特殊な値 undefined
も別に扱われます。null
のように、それ自身の型を持ちます。
undefined
の意味は “値は代入されていません” です。
もしも変数は宣言されているが代入されていない場合、その値は正確には undefined
です:
let x;
alert(x); // "undefined" を表示
技術的にはどの変数にも undefined
を代入することができます。
let age = 100;
// 値を undefined に変更
age = undefined;
alert(age); // "undefined"
…しかし、そのようにするのは推奨されません。一般的には、 “空” や “不明な値” と言った用途では null
を使い、undefined
は変数が割り当てられているか、もしくは似たような確認のために使います。
オブジェクトとシンボル
object
型は特殊です。
他のすべての型は、値は1つのもの(文字列, 数値, または何でも)だけを含むので、“プリミティブ” と呼ばれます。対照的に、オブジェクトはデータのコレクションやより複雑なエンティティを格納するために使われます。
その重要性から、オブジェクトに関してはプリミティブについて詳しく学んだ後に、チャプターオブジェクトで扱います。
symbol
型はオブジェクトの一意な識別子を作るのに使われます。完全性のためにここで言及していますが、オブジェクトの後で勉強するのがよいでしょう。
typeof 演算子
typeof
操作は、引数の型を返します。異なる型の値を別々に処理したい、または素早くチェックしたいときに役立ちます。
これは2つの形式の構文をサポートします:
- 演算子として:
typeof x
. - 関数スタイル:
typeof(x)
.
言い換えると、それは括弧があってもなくても動作します。結果は同じです。
typeof x
の呼び出しは型名の文字列を返します。:
typeof undefined // "undefined"
typeof 0 // "number"
typeof 10n // "bigint"
typeof true // "boolean"
typeof "foo" // "string"
typeof Symbol("id") // "symbol"
typeof Math // "object" (1)
typeof null // "object" (2)
typeof alert // "function" (3)
最後の3行については追加の説明が必要かもしれません:
Math
は数学的な操作を提供する組み込みオブジェクトです。チャプター数値で学ぶでしょう。ここでは、単にオブジェクトとしての例です。typeof null
の結果は"object"
です。これは間違っています。これはtypeof
において、公式に認められているエラーで、互換性のために維持されています。もちろん、null
はオブジェクトではありません。それは自身の別の型をもつ特殊な値です。なので、繰り返しますがそれは言語のエラーです。alert
は言語の機能なので、typeof alert
の結果は"function"
です。我々は次のチャプターで function を勉強します。そして、言語の中には特別な “function” 型がないことがわかるでしょう。function はオブジェクト型に属します。しかしtypeof
はそれらを別々に扱います。正式にはそれは正しくありませんが、実際にはとても便利です。
サマリ
JavaScriptには7つの基本型があります。
number
あらゆる種類の数値: 整数または浮動小数点bigint
は任意の長さの整数値のための型string
文字列。文字列は1つかより多くの文字を持ち、別の1文字型はありません。boolean
true
/false
null
不明な値 – 単一の値null
を持つスタンドアロン型undefined
未割り当て値 – 単一の値undefined
を持つスタンドアロン型object
より複雑なデータ構造symbol
一意な識別子
typeof
操作は変数にどの型が格納されているかを知ることができます。
- 2つの形式:
typeof x
ortypeof(x)
. "string"
のように型の名前の文字列を返します。null
は"object"
を返します – それは言語のエラーで、実際はオブジェクトではありません。
次のチャプターではプリミティブ値について集中し、それらに精通した後オブジェクトに進みます。