====== JavaScript オブジェクトの基本 ======
--- //[[http://www.y2sunlight.com/water|y2sunlight]] 2020-10-28//
===== プロトタイプベースのオブジェクト指向 =====
JavaScriptでは関数オブジェクトがクラスの役割を果たします。以下の例の様に、関数リテラルを使ってクラスを記述することができます。
var Student = function(name) { // コンストラクタ
this.name = name; // プロパティ
this.greeting = function() { // メソッド
console.log(`I am ${this.name}`);
};
};
var suzuki = new Student('suzuki');
- 関数オブジェクト(コンストラクタ)によってクラスを作る。
- ''this.プロパティ名'' でプロパティを定義する。
- 関数を値に持つプロパティがメソッドの役割を果たす。
- new演算子でクラスからインスタンスを作る。
この例と同様に、次の様に名前付きの関数定義によってクラスを記述することができます。
function Student(name) { // コンストラクタ
this.name = name; // プロパティ
this.greeting = function() { // メソッド
console.log(`I am ${this.name}`);
};
};
var suzuki = new Student('suzuki');
\\
=== new演算子 ===
var 変数名 = new オブジェクト名([引数, ・・・])
=== プロパティの定義 ===
this.プロパティ名
=== プロパティとメソッドのアクセス ===
var name = suzuki.name(); // プロパティの読み込み
suzuki.name = 'suzuki taro'; // プロパティの書き込み
suzuki.greeting(); // メソッドの呼び出し
=== メンバーの有無の判定(in演算子) ===
in演算子を使って、メンバーの存在の有無を判定することができます。
console.log('name' in suzuki); // true
console.log('greeting' in suzuki); // true
\\
===== 静的プロパティと静的メソッド =====
静的プロパティ(またはメソッド)は、インスタンスを生成しなくてもオブジェクトから直接呼び出すことができるプロパティ(またはメソッド)です。これは以下の様に定義することができます。
オブジェクト名.プロパティ名 = 値;
オブジェクト名.メソッド名 = function() {/* メソッドの定義 */};
var Student = function(name) {
this.name = name; // インスタンスプロパティ
this.greeting = function() { // インスタンスメソッド
console.log(`I am ${this.name}.`);
};
}
Student.age = 15; // 静的プロパティ
Student.getSchoolName = function() { // 静的メソッド
return 'AbcSchool';
}
console.log(Student.age); // OK (15)
console.log(Student.getSchoolName()); // OK (AbcSchool)
静的プロパティ(またはメソッド)は、インスタンスからアクセスすることはできません。
var taro = new Student('taro');
taro.name = 'suzuki taro' // OK
taro.greeting(); // OK (I am suzuki taro.)
console.log(taro.age); // NG (undefined)
console.log(taro.getSchoolName()); // NG (taro.getSchoolName is not a function)
=== メンバーの有無の判定(in演算子) ===
in演算子を使って、メンバーの存在の有無を判定することができます。
console.log('name' in taro); // true
console.log('greeting' in taro); // true
console.log('age' in taro); // false
console.log('getSchoolName' in taro); // false
console.log('age' in Student); // true
console.log('getSchoolName' in Student); // true
\\
===== 組み込みオブジェクト =====
* 組み込みオブジェクト ・・・ 全てのJavaScriptに標準で組み込まれている
* ブラウザーオブジェクト ・・・ 特定の環境(ブラウザー上)で動作する
^オブジェクト^^説明^
|Global||JavaScriptの基本機能|
|参照型|Object|ラッパーオブジェクト \\ JavaScriptの標準なデータ型(基本型、参照型)をラップしたもの|
|:::|Array|:::|
|:::|Function|:::|
|基本型|String|:::|
|:::|Boolean|:::|
|:::|Number|:::|
|:::|Symbol|:::|
|Math||数値演算|
|Date||日付|
|RegExp||正規表現|
|Error/XxxxError||エラー|
|Map/WeakMap[[js:top#ECMAScript|*2015]]||ディクショナリー|
|Set/WeakSet[[js:top#ECMAScript|*2015]]||集合(セット)|
|Proxy[[js:top#ECMAScript|*2015]]||オブジェクトの基本動作のカスタマイズ|
|Promise[[js:top#ECMAScript|*2015]]||非同期処理|
var str = 'こんにちは';
// 基本型のプロパティにアクセスすると一時的にオブジェクトが作られる
// str.length => (new String(str)).length
console.log(str.length);
// 基本型
var flag = false;
if(flag){
// ここには来ない
}
// 参照型
var flag = new Boolean(false);
if(flag){
// ここには来る
}
if(flag.valueOf()){ // 正解の書き方
// ここには来ない
}
\\