ホームページ > ウェブフロントエンド > jsチュートリアル > ES6スコープに基づく代入と構造化の詳細説明

ES6スコープに基づく代入と構造化の詳細説明

小云云
リリース: 2017-12-28 10:29:26
オリジナル
1082 人が閲覧しました

この記事では、ES6 に基づいたスコープと構造化割り当てについて詳しく説明します。編集者はこれがとても良いものだと思ったので、皆さんの参考として今から共有します。編集者をフォローして見てみましょう。皆さんのお役に立てれば幸いです。

ES6 は厳密モードを強制的にオンにします

スコープ

•var は中括弧の外側でもアクセスできる for/if で定義された変数を宣言します

•let はブロック スコープで変数を宣言します。繰り返しの定義

•const は定数を宣言、ブロックスコープ、宣言時に割り当てる必要があり、変更できません

// const声明的k指向一个对象,k本身不可变,但对象可变

function test() {
 const k={
  a:1
 }
 k.b=3;
 
 console.log(k);
}
ログイン後にコピー

test() 代入の構造化

{
 let a, b, 3, rest;
 [a, b, c=3]=[1, 2];

 console.log(a, b);
}
//output: 1 2 3

{
 let a, b, 3, rest;
 [a, b, c]=[1, 2];

 console.log(a, b);
}
//output: 1 2 undefined

{
 let a, b, rest;
 [a, b, ...rest] = [1, 2, 3, 4, 5, 6];
 console.log(a, b, rest);
}
//output:1 2 [3, 4, 5, 6]

{
 let a, b;
 ({a, b} = {a:1, b:2})

 console.log(a ,b);
}
//output: 1 2
ログイン後にコピー

使用シナリオ

変数交換

{
 let a = 1;
 let b = 2;
 [a, b] = [b, a];
 console.log(a, b);
}
ログイン後にコピー

複数の関数値を取得

{
 function f(){
  return [1, 2]
 }
 let a, b;
 [a, b] = f();
 console.log(a, b);
}
ログイン後にコピー

複数の関数の戻り値の取得

{
 function f(){
  return [1, 2, 3, 4, 5]
 }
 let a, b, c;
 [a,,,b] = f();
 console.log(a, b);
}
//output: 1 4

{
 function f(){
  return [1, 2, 3, 4, 5]
 }
 let a, b, c;
 [a, ...b] = f();
 console.log(a, b);
}
//output: 1 [2, 3, 4, 5]
ログイン後にコピー

オブジェクトの構造化と代入

{
 let o={p:42, q:true};
 let {p, q, c=5} = o;

 console.log(p ,q);
}
//output: 42 true 5
ログイン後にコピー

json 値の取得

{
 let metaData={
  title: 'abc',
  test: [{
   title: 'test',
   desc: 'description'
  }]
 }
 let {title:esTitle, test:[{title:cnTitle}]} = metaData;
 console.log(esTitle, cnTitle);
}
//Output: abc test
ログイン後にコピー

関連する推奨事項:

ES6 の新しい配列メソッドの詳細な例

React での es6 の適用の詳細な例

ES6のJavaScriptの関数バインディングとクラスイベントバインディング関数について詳しく解説

以上がES6スコープに基づく代入と構造化の詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート