ホームページ >ウェブフロントエンド >jsチュートリアル >JSネイティブオブジェクトと組み込みオブジェクトの違いを詳しく解説

JSネイティブオブジェクトと組み込みオブジェクトの違いを詳しく解説

小云云
小云云オリジナル
2018-03-06 14:29:564856ブラウズ

1. JS のオブジェクトと型

JS 内のすべてのものは、文字列、値、配列、関数などを含むがこれらに限定されないオブジェクトであり、カスタム オブジェクトも含まれます。 Red Book では、JS は 5 つの基本タイプ (null、unknown、number、string、boolean) と 1 つの複合タイプ (object) に分割されています。ただし、「The Essence of JavaScript Language and Programming Practice」では、unknown、number、string、boolean、object、function の 6 種類があると考えられています。これは、typeof の結果が 6 種類しかないという事実に基づいています (ES 自体のみ)。 、ホストオブジェクトを除く)、その中で null の型もオブジェクトです。

var a = 1, b = '2', c = true, d, e = null, f = function(){} 
typeof a === 'number'; // true
typeof b === 'string';    // true
typeof c === 'boolean'; // true
typeof d === 'undefined'; // true
typeof e === 'object'; // true
typeof f === 'function'; // true

以下は Symbol の基本的な使い方です。 ES6 では、一意の値を表す不変型である新しい Symbol 型が追加されました。通常、オブジェクトのプロパティの識別子として使用されます。 ES6 より前のプロパティ名はすべて文字列型であったため、プロパティ名が上書きされていました。 ES6 で Symbol 型が提案されてから、JS の基本型の数は 7 に増加しました。

var s1 = Symbol();
typeof s1; // "symbol"
 
var s2 = Symbol('andy');
s2; // Symbol(andy)

2. JS のネイティブ オブジェクトと組み込みオブジェクト


1. セマンティクスがホスト環境ではなくこの仕様によって完全に定義される ECMAScript 実装内のネイティブ オブジェクト

ネイティブ オブジェクト:独立した ホスト環境の ECMAScript 実装によって提供されるオブジェクト。

注: この仕様では、標準のネイティブ オブジェクトが定義されています。一部のネイティブ オブジェクトは、ECMAScript プログラムの実行中に構築される場合があります。オブジェクトは ECMAScript プログラムの実行中に生成されます。

ネイティブ オブジェクトには次のものが含まれます:

Object、Function、Array、String、Boolean、Number、Date、RegExp、Error、EvalError、RangeError、ReferenceError、SyntaxError、TypeError、URIError、ActiveXObject(服务器方面)、Enumerator(集合遍历类)、RegExp(正则表达式)

2. 組み込みオブジェクト

ホスト環境に依存せず、ECMAScript 実装によって提供されるオブジェクト。ECMAScript プログラムの実行開始時に存在します。

組み込みオブジェクト: ホスト環境に関係なく、スクリプト実行の開始時に提供される ECMAScript オブジェクトによって実装されます。

注: 標準の組み込みオブジェクトはこの仕様で定義されており、ECMAScript 実装では他の組み込みオブジェクトを指定および定義することができます。組み込みコンストラクターは、コンストラクターでもある組み込みオブジェクトです。 .

注: すべての組み込みオブジェクトはネイティブ オブジェクトです。組み込みコンストラクターは組み込みオブジェクトであり、コンストラクターでもあります。

出典: http://es5.github.io/#x4.3.7

ECMA-262 では、Global と Math という 2 つの新しい組み込みオブジェクトのみが定義されています (定義上、これらはネイティブ オブジェクトでもあり、それぞれの組み込みオブジェクトです)オブジェクトはすべてネイティブ オブジェクトです)。

組み込みオブジェクトには以下が含まれます:

global、Object、Function、Array、String、Boolean、Number、Math、Date、RegExp、JSON、Error对象(Error,   EvalError, RangeError, ReferenceError,   SyntaxError, TypeError 和URIError)


Math オブジェクトは Date や String のようなオブジェクトのクラスではないため、コンストラクター Math() はありません Math.sin() のような関数は単なる関数であり、特定のオブジェクト メソッド。これを作成する必要はありません。Math をオブジェクトとして使用して、そのすべてのプロパティとメソッドを呼び出すことができます。

グローバル オブジェクトは、JavaScript のグローバル関数およびグローバル プロパティのプレースホルダーとして機能する事前定義されたオブジェクトです。グローバル オブジェクトを使用すると、他のすべての定義済みオブジェクト、関数、プロパティにアクセスできます。グローバル オブジェクトはどのオブジェクトのプロパティでもないため、名前はありません。

トップレベルの JavaScript コードでは、キーワード this を使用してグローバル オブジェクトを参照できます。ただし、グローバル オブジェクトはスコープ チェーンの先頭にあるため、通常はこの方法でグローバル オブジェクトを参照する必要はありません。つまり、修飾されていない変数名と関数名はすべてオブジェクトのプロパティとしてクエリされることになります。たとえば、JavaScript コードが parseInt() 関数を参照する場合、グローバル オブジェクトの parseInt プロパティを参照します。グローバル オブジェクトはスコープ チェーンの先頭です。これは、トップレベルの JavaScript コードで宣言されたすべての変数がグローバル オブジェクトのプロパティになることも意味します。

関連する推奨事項:

JSネイティブオブジェクトインスタンスの説明

JSの基本的な組み込みオブジェクトの詳細な説明

JavaScriptの組み込みオブジェクト引数の詳細な説明

以上がJSネイティブオブジェクトと組み込みオブジェクトの違いを詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。