目次
2。構文と構造
3。データへのアクセス
4。注文とインデックス
5。組み込みメソッド
6。タイプチェック
ホームページ ウェブフロントエンド jsチュートリアル JavaScriptのオブジェクトと配列の違いは何ですか

JavaScriptのオブジェクトと配列の違いは何ですか

Aug 13, 2025 am 03:06 AM

Objectsは、一意のプロパティ名でキー付きコレクションを保存し、アレイは数値インデックスでアクセスされるリストを保存します。 2。オブジェクトは、キーと値のペアでcurlyブレース{}を使用しますが、配列はカンマ分離値を持つ正方形のブラケット[]を使用します。 3.オブジェクト値は、キーを使用してDOTまたはブラケット表記を介してアクセスされますが、配列要素はインデックス番号のブラケット表記を介してアクセスされます。 4。オブジェクトはプロパティの順序を保証するものではありませんが、アレイは数値インデックスを介して挿入順序を維持します。 5。オブジェクトは、Object.keys()やObject.Values()などの方法を使用し、配列はpush()、pop()、map()、filter()などのリスト固有のメソッドを提供します。 6.配列は特別なタイプのオブジェクトであるため、typeofは両方の「オブジェクト」を返しますが、配列.isarray()は配列とプレーンオブジェクトを区別します。インデックスベースのアクセスとリスト操作を備えた順序付けられたデータには、指定されたプロパティと配列にオブジェクトを使用します。

JavaScriptのオブジェクトと配列の違いは何ですか

JavaScriptでは、オブジェクトと配列の両方がデータを保存するために使用されますが、さまざまな目的を果たし、明確な特性を持っています。主な違いの内訳は次のとおりです。

JavaScriptのオブジェクトと配列の違いは何ですか

1。目的とユースケース

  • オブジェクト:各値が一意のキー(プロパティとも呼ばれます)に関連付けられているキー付きデータのコレクションを保存するために使用されます。オブジェクトは、複数の属性を持つ実際のエンティティを表すのに最適です。

    例:

    JavaScriptのオブジェクトと配列の違いは何ですか
     const person = {
      名前:「アリス」、
      年齢:30、
      市:「ニューヨーク」
    };
  • 配列:注文された値のコレクションを保存するために使用されます。配列は、注文が重要なリストを維持し、その位置(インデックス)でアイテムにアクセスする必要がある場合に最適です。

    例:

    JavaScriptのオブジェクトと配列の違いは何ですか
     const colors = ["red"、 "green"、 "blue"];

2。構文と構造

  • オブジェクト:Curly Braces {}を使用して定義されています。プロパティはkey: valueペア。

  • 配列:四角い括弧を使用して定義されています[] 。値は順番にリストされ、コンマで区切られています。

3。データへのアクセス

  • オブジェクト:プロパティ名でドット表記またはブラケット表記を使用したアクセス値。

     person.name; //「アリス」
    人物"]; // 30
  • 配列:数値インデックスを使用したブラケット表記を使用したアクセス値(0から始まる)。

    色[0]; // "赤"
    色[1]; // "緑"

4。注文とインデックス

  • オブジェクト:プロパティは特定の順序であることが保証されていません(実際には、最新のJavaScriptエンジンは、文字列キーの挿入順序を保持します)。キーは文字列またはシンボルです。

  • 配列:常に注文します。各アイテムには、その位置に基づいて数値インデックスがあります。

5。組み込みメソッド

  • オブジェクトObject.keys()Object.values()Object.entries()などのメソッドがあり、プロパティで動作します。

  • 配列push()pop()map()filter()forEach()など、操作リストを操作するための多くの組み込みメソッドが付属しています。

    例:

     colors.push( "yellow"); //最後に追加します
    colors.map(c => C.touppercase());

6。タイプチェック

配列は別のタイプのように見えますが、実際にはJavaScriptの特別な種類のオブジェクトです。

このようなタイプを確認できます。

 typeof {}; // "物体"
typeof []; //「オブジェクト」 - まだオブジェクトです!

array.isarray([]); // 真実
array.isarray({}); // 間違い

したがって、 typeof両方の「オブジェクト」を返しますが、 Array.isArray()を使用して、何かが配列であるかどうかを確実に確認できます。


要するに
名前のキー(フィールドやプロパティなど)が必要な場合は、オブジェクトを使用します。
数値インデックスとリスト固有の操作を備えた順序付けられたリストが必要な場合は、配列を使用します。

それらは両方とも不可欠であり、それぞれを使用するタイミングを理解することにより、コードがより明確になり、より効果的になります。

以上がJavaScriptのオブジェクトと配列の違いは何ですかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットAIツール

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

ホットトピック

TypeScriptの高度な条件付きタイプ TypeScriptの高度な条件付きタイプ Aug 04, 2025 am 06:32 AM

TypeScriptの高度な条件タイプは、TextEndsu?X:Y Syntaxを介してタイプ間の論理的判断を実装します。そのコア機能は、分散条件タイプ、推測タイプの推論、および複雑なタイプのツールの構築に反映されます。 1.条件付きタイプは、裸の型パラメーターに分散され、string [] | number []を取得するためにtoArrayなどのジョイントタイプを自動的に分割できます。 2.分布を使用してフィルタリングおよび抽出ツールを構築します。除外textendsuを除く除外:t、抽出抽出抽出extract textendsu?t:never、およびnullable filters null/undefined。 3

マイクロフロントエンドアーキテクチャ:実用的な実装ガイド マイクロフロントエンドアーキテクチャ:実用的な実装ガイド Aug 02, 2025 am 08:01 AM

MicrofRontendsSolvessCallingChallengesimSimSimSimsByEnablingEndependDevelymentAndDeployment.1)chooseanintegrations trategy:usemodulefederationinwebpack5forruntimeloadingindingindrueindopendence、build-time-integrationforsimplestups、oriframes/webcomponents

javascriptのvar、let、constの違いは何ですか? javascriptのvar、let、constの違いは何ですか? Aug 02, 2025 pm 01:30 PM

varisfunction-scoped、canbereasSigned、hoisted witHedededined、andattachedtotheglobalwindow object;

JSのオプションチェーン(?。)とは何ですか? JSのオプションチェーン(?。)とは何ですか? Aug 01, 2025 am 06:18 AM

optionalchaining(?。)indavascriptsafelyAccessededpropertiesbyReturningifinedifineparturypart ofthechainisnullorundeded、dietlowssafeacesteplynestededededededededobjectproperties、suchasuser.profile?

解決されたダブルチョコレートパズルを生成:データ構造とアルゴリズムのガイド 解決されたダブルチョコレートパズルを生成:データ構造とアルゴリズムのガイド Aug 05, 2025 am 08:30 AM

この記事では、ダブルチョコパズルゲーム用の溶媒があるパズルを自動的に生成する方法を詳細に説明します。効率的なデータ構造 - 境界情報、色、状態を含む2Dグリッドに基づくセルオブジェクトを紹介します。これに基づいて、再帰的なブロック認識アルゴリズム(深さfirst検索と同様)と、それを反復パズル生成プロセスに統合する方法について詳しく説明し、生成されたパズルがゲームのルールを満たし、溶媒があることを確認します。この記事では、サンプルコードを提供し、生成プロセスにおける重要な考慮事項と最適化戦略について説明します。

JavaScriptを使用してDOM要素からCSSクラスを削除するにはどうすればよいですか? JavaScriptを使用してDOM要素からCSSクラスを削除するにはどうすればよいですか? Aug 05, 2025 pm 12:51 PM

JavaScriptを使用してDOM要素からCSSクラスを削除するための最も一般的で推奨される方法は、クラスリストプロパティのremove()メソッドを使用しています。 1。要素を使用して、単一または複数のクラスを安全に削除するには、クラスが存在しなくてもエラーは報告されません。 2.代替方法は、クラス名プロパティを直接操作し、文字列交換でクラスを削除することですが、定期的なマッチングまたは不適切な空間処理のために問題を引き起こすのは簡単であるため、推奨されません。 3.最初にクラスが存在するかどうかを判断してから、element.classlist.contains()を介して削除できますが、通常は必要ありません。 4.クラスリスト

JavaScriptのクラス構文とは何ですか?プロトタイプとどのように関係していますか? JavaScriptのクラス構文とは何ですか?プロトタイプとどのように関係していますか? Aug 03, 2025 pm 04:11 PM

JavaScriptのクラス構文は、プロトタイプで継承された構文糖です。 1。クラスで定義されるクラスは基本的に関数であり、メソッドはプロトタイプに追加されます。 2。インスタンスは、プロトタイプチェーンを介してメソッドを検索します。 3.静的メソッドはクラス自体に属します。 4。プロトタイプチェーンを介して継承されているが、基礎となる層は依然としてプロトタイプメカニズムを使用している。クラスは、JavaScriptプロトタイプ継承の本質を変えていません。

VercelSPAルーティングとリソースの読み込み:ディープURLアクセスの問題を解決する VercelSPAルーティングとリソースの読み込み:ディープURLアクセスの問題を解決する Aug 13, 2025 am 10:18 AM

この記事の目的は、Vercelにシングルページアプリケーション(SPA)を展開する際に、ディープURLの更新または直接アクセスの原因となる問題を解決することを目的としています。コアは、Vercelのルーティング書き換えメカニズムと相対パスを解析するブラウザの違いを理解することです。 Vercel.jsonを設定してすべてのパスをindex.htmlにリダイレクトし、HTMLの静的リソースの参照方法を修正し、相対パスを絶対パスに変更し、アプリケーションがすべてのリソースを任意のURLに正しくロードできるようにします。

See all articles