序文これは JavaScript の非常に基本的な知識ポイントであるはずですが、多くの友人は面接中に簡単に触れただけで、それについて何も知らないようです。ここでは、以前のメモと合わせて、プリミティブ値と参照値の関連知識を簡単に紹介します。それでは始めましょう。 ECMAScript では、変数にはプリミティブ値または参照値の 2 つのデータ型を含めることができると規定されています。プリミティブ値は最も単純なデータ構造ですが、参照値は複数の値で構成されるオブジェクトです。 プリミティブ値は、Undefined、Null、Boolean、Number、String、Symbol の計 6 種類あります。プリミティブ値を操作するということは、格納変数内の実際の値を操作することを意味します。 参照値は、メモリに格納されているオブジェクトです。JavaScript はメモリ位置に直接アクセスできないため、オブジェクトが配置されているメモリ空間を直接操作することはできません。オブジェクトを操作する場合、実際にはオブジェクト自体ではなく、オブジェクトの参照を操作しています。 動的プロパティとは何ですか?動的プロパティとは、参照値が作成された後、そのプロパティとメソッドを動的に追加、変更、削除できることを意味します。例: obj = new Object(); obj.name = "サム"; console.log(obj.name); // "サム" 説明: まず、参照値オブジェクトが作成され、変数 obj に格納されます。次に、名前属性が値 "Sam" で obj に割り当てられます。このプロパティが変更/削除されない限り、このプロパティを直接印刷したりアクセスしたりできます。 プリミティブ値には属性を持たせることはできませんが、属性操作を実行してもエラーは報告されません。例: let me = "Sam"; me.sex = "男性"; console.log(me.sex); // 未定義 ここではリテラル初期化が使用されているため、性別属性が私に割り当てられても無意味であり、属性にアクセスすることはできません。 let me = new String("Sam"); me.sex = "男性"; console.log(me.sex); // "男性" 値のコピープリミティブ値と参照値は、変数を介してコピーされる場合にも異なります。プリミティブ値は新しい変数にコピーされますが、参照値は実際には値へのポインタをコピーします。例: 名前を "Sam" にします。 myName = 名前とします。 console.log(myName); // "サム" myName が name に初期化されると、「Sam」も myName にコピーされますが、これは name とは独立しており、互いに干渉しません。myName は name のコピーであると理解できます。 参照値のコピーは、実際にはヒープ メモリ内のオブジェクトを指すポインターをコピーします。コピーされた変数に対する属性操作は、実際にはコピーされたオブジェクトに対する操作です。2 つの変数は実際には同じオブジェクトを参照します。例: let me = new Object(); あなた=私になります。 me.name = "サム"; console.log(you.name); // "サム" 値の種類を決定する変数の型を決定するために typeof をよく使用します。これはプリミティブ値の型を決定するのに便利ですが、参照値と null の場合、typeof はオブジェクトを返すため、参照値を決定するのにはあまり役立ちません。 通常、これがどのようなタイプのオブジェクトであるかを正確に知る必要があるため、instanceof 演算子を使用します。構文は次のとおりです。 結果 = 変数インスタンスコンストラクタ instanceof はブール値を返します。例: console.log(person オブジェクトのインスタンス); // 変数 person はオブジェクトですか? console.log(色のインスタンス配列); // 変数 colors は配列ですか? console.log(パターンインスタンスRegExp); // 変数パターンは正規表現ですか? プリミティブ値に対して instanceof を使用すると、プリミティブ値はオブジェクトではないため、常に false が返されます。 要約するECMAScript におけるオリジナル値と参照値についての記事はこれで終了です。ECMAScript におけるオリジナル値と参照値についてさらに詳しく知りたい方は、123WORDPRESS.COM の過去記事を検索するか、引き続き以下の関連記事を閲覧してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 |
>>: MySQLデータベースのbinlogクリーンアップコマンドの詳細な説明
導入から始めず、いきなり本題に入りましょう。通常の背景ぼかし効果は次のとおりです。 プロパティを使用...
<meta name="viewport" content="...
目次1. vuexとは何か2. インストールと導入3. vuexの使用4. プロセスの紹介5. 突然...
MySQLをインストールしてメモしておきます。うまくインストールできるか分かりませんが、試してみます...
一般的なブラウザでテスト ページを開き、Fiddler で http リクエストを表示してください。...
目次仕様a. ページファイルはVueの単一ファイルコンポーネント仕様に準拠しています。 b. コンポ...
1. InnoDBのロック機構InnoDB ストレージ エンジンは、行レベルのロックとトランザクショ...
目次導入ルート内のオブジェクト属性パス: 文字列コンポーネント: コンポーネント | () =>...
この記事では、適応解像度を実現するためのVue2.0の具体的なコードを参考までに紹介します。具体的な...
特定のデータの一括更新処理において、特定のステータスが固定値に更新されるなど、更新するフィールドの値...
1. 背景実際のプロジェクトでは、分散スケジュールされたタスク実行の状況に遭遇することがあります。ス...
効果画像: 実装コード: <テンプレート> <div id="map&q...
基本的な HTML Web ページ タグのネスト ルールを紹介する場合、最初に説明する必要があるのは...
環境説明サーバーシステム: Ubuntu 18.04 64ビットnginx: 1.14この記事では主...
この記事の例では、Vueプロジェクトでのトークン検証ログインの具体的なコードを参考までに共有していま...