ES6分解課題の原理と応用

ES6分解課題の原理と応用

配列分割代入

[a, b, c] = [1, 2, 3]とする

複数の変数を同時に定義します。a は 1 に一致し、b は 2 に一致し、c は 3 に一致します。

分割代入ではデフォルト値を指定できます。つまり、左側の変数にデフォルト値が指定されていて、右側に対応する値がない場合、デフォルト値が最初に出力されます。

[x, y = 'b'] = ['a'] とします // x = 'a'、y = 'b'

x は文字 a に一致し、y のデフォルト値は文字 b です。右側に対応する文字がない場合、デフォルトの出力は文字 b になります。

オブジェクトの分解代入

分解は配列だけでなく、オブジェクトにも使用できます。オブジェクトの分解と配列の分解には重要な違いがあります。配列の要素は順番に配置され、変数の値は位置によって決まりますが、オブジェクトのプロパティには順序がなく、正しい値を取得するには変数の名前がプロパティと同じである必要があります。

させて {
    名前、
    年、
    趣味: [1つ、2つ]
} = {
    名前: 「シラマシロ」
    年齢: 21,
    趣味: ['サイクリング', 'アニメーション']
}

たとえば、age の値を abc の値に変更すると、オブジェクト内のプロパティ名に対応していないため、対応する値を割り当てることができず、未定義になります。

分割割り当ての適用

変数の値の交換

変数の値を交換する通常の考え方

x = 1とすると、
    y = 2,
    温度 = 0

温度 = x // x = 1 = 温度
x = y // y = 2 = x
y = 温度 // 温度 = 1 = y

コンソールログ('x => ', x)
コンソールログ('y => ', y)

分割代入による変数の交換

x = 1 とします。
y = 2とします。
y = 0;

コンソールログ('x => ', x)
コンソールログ('y => ', y) 

変数 x と y の値を交換するこの方法は、簡潔であるだけでなく、読みやすく、非常に明確なセマンティクスを備えています。

関数から複数の値を返す

関数は 1 つの値しか返せません。複数の値を返したい場合は、配列またはオブジェクトでのみ返せます。分割代入を使用すると、さらに便利になります。

趣味配列の2番目の値を抽出する

関数 getArray() {
    戻る {
        名前: 'コンサム',
        年齢: 21,
        趣味: ['サイクリング'、'アニメ'、'バドミントン']
    }
}
console.log(getArray().name + 'like' + getArray().hobbies[1]) // アニメ

趣味配列の2番目の値を取得するには、分割代入を使用します。

{名前、年齢、趣味} = getArray() とします。
console.log(name + 'like' + 趣味[1]) // アニメ

マップ構造のトラバース

for...of ループのトラバーサルでは、トラバースされた値は配列であり、分解割り当ては配列に対して「パターン マッチング」できるため、キー値をすばやく抽出できます。

キー値を取得するために、構造化代入を伴う for...of ループトラバーサルを使用すると非常に便利です。

for (let [キー, 値] of map) {
    console.log("キー => ", キー)
    console.log("値 => ", 値)
}

関数パラメータの分割代入

// { x = 10, y = 5 } = {} とします

関数 f({ x = 10, y = 5 } = {}) {
    [x, y]を返す
}

console.log(f({ x: 100, y: 50 })) // [100, 50]
console.log(f({ x: 3 })) // [3, 5]
コンソール.log(f({})) // [10, 5]
コンソール.log(f()) // [10, 5]

関数のパラメータにオブジェクトを渡し、渡されたオブジェクトのデフォルト値を設定できます。それを関数に分解して使用するので、このように理解することができます。

関数 f(x = 10, y = 5) {
    [x, y]を返す
}

console.log(f(100, 50)) // [100, 50]
コンソール.log(f(3)) // [3, 5]
コンソール.log(f()) // [10, 5]

書き方が異なれば結果も異なります。

関数 f({ x, y } = { x: 10, y: 5 }) {
    [x, y]を返す
}

console.log(f({ x: 100, y: 50 })) // [100, 50]
console.log(f({ x: 3 })) // [3, 未定義]
console.log(f({})) // [未定義、未定義]
コンソール.log(f()) // [10, 5]

渡された x または y がオブジェクト プロパティの値に対応せず、一致が失敗するため、3 番目と 4 番目の出力は undefined になります。

上記は、ES6 分割代入の原理と応用の詳細な内容です。ES6 分割代入の詳細については、123WORDPRESS.COM の他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • JS ES6 変数分割代入の詳細な説明
  • ES6 の let と const の違いと変数分解代入演算法の例題解析
  • ES6 配列とオブジェクトの分割代入の詳細な説明
  • ES6 のエクスポート デフォルトおよびインポート ステートメントにおける分割代入の詳細な説明
  • ES6 分割代入の例の詳細な説明
  • ES6 知識ポイントのまとめ: オブジェクト分割代入の応用例
  • ES6入門チュートリアル: 変数分割代入の詳細な説明
  • ES6 分割代入の基本
  • ES6 オブジェクトの新しい関数と分割代入の紹介
  • ES6 分割代入の機能と使用例の分析
  • ES6 分割代入の例の詳細な説明

<<:  Python ベースの Linux システムにおける特定のプロセスのパフォーマンス監視の考え方の詳細な説明

>>:  MySQL の JSON 挿入の問題

推薦する

MySql はコミットする必要がありますか?

MySQL が挿入などの操作を実行するときにコミットする必要があるかどうかは、ストレージ エンジン...

Linux 編集の開始、停止、再起動の Springboot jar パッケージ スクリプトの例

序文springboot設定ファイルでは、設定ファイルの名前には独自の意味と用途があります。 dev...

シェルを使用して複数のサーバーでバッチ操作を実行する方法

目次SSHプロトコルパスワード接続プロセスsshツールssh公開鍵ログインバッチ操作複数サーバーファ...

Windows10にmysql5.7.18をインストールするチュートリアル

このチュートリアルでは、MySQL 5.7.18のインストールと設定方法を参考までに紹介します。具体...

Vueルータールーティングガードの詳細な説明

目次1. グローバル beforeEach 1. グローバル beforeEach 2. 実装2. ...

mysql8.0.11をインストールしてrootパスワードを変更し、navicat for mysqlに接続するアイデアの詳細な説明

1.1. ダウンロード:公式ウェブサイトから zip パッケージをダウンロードします。私は 64 ビ...

入力ボックスのプレースホルダーアニメーションと入力検証を実現する純粋なCSS

さらに興味深いコンテンツについては、https://github.com/abc-club/free...

MYSQL8.0.13 無料インストール版 設定チュートリアル例 詳細説明

1. ダウンロード、例として8.0を取り上げますダウンロードアドレス: https://dev.my...

MySql5.7.21 インストールポイント記録メモ

ダウンロードしたバージョンは、Zip 解凍版、Windows システムです。長い間 Windows ...

Linux コマンド クエリ アプレットでの WePY クラウド開発の実践

みなさんこんにちは。今日は Linux コマンド クエリ アプレットでの WePY クラウド開発の実...

MySQL 起動エラー InnoDB: ロックできません/ibdata1 エラー

OS X 環境で MySQL を起動すると、エラー メッセージが表示されます。 016-03-03T...

MySQL をインストールするときに初期パスワードを忘れた場合のシンプルで効果的な解決策

MySQL をインストールすると初期パスワードが与えられますが、この初期パスワードは大文字と小文字の...

HTMLでvueとel​​ement-uiを直接参照する方法

コードは次のようになります。 <!DOCTYPE html> <html> ...

FirefoxでCookieとお気に入りをインポートおよびエクスポートする方法

Firefox は、多くの拡張機能とプラグインを備えた、よく使用されるブラウザです。IE に比べて多...

SQLインジェクションの詳しい解説 - セキュリティ編(第2部)

この記事に誤りがあったり、ご提案がありましたら、お気軽にご連絡ください。よろしくお願いいたします。は...