ホームページ >ウェブフロントエンド >フロントエンドQ&A >es6 における構造化代入の役割は何ですか

es6 における構造化代入の役割は何ですか

青灯夜游
青灯夜游オリジナル
2022-05-19 13:56:142190ブラウズ

関数: 1. 2 つの変数の値を交換します (構文 "[x,y] = [y,x];")。 2. 文字列を分解し、文字を変数に渡します。構文 "[変数リスト] = string"; 3. 関数から複数の値を返す構文 "[変数リスト]=関数"; 4. json データを抽出する構文 "{変数リスト}=json 変数"すぐ。

es6 における構造化代入の役割は何ですか

このチュートリアルの動作環境: Windows 7 システム、ECMAScript バージョン 6、Dell G3 コンピューター。

es6 代入の構造化

es6 を使用すると、特定のパターンに従って配列またはオブジェクトから値を抽出し、値を変数に割り当てることができます。これは割り当ての構造化と呼ばれます。

構造化代入は、明確なセマンティクスを備えたコード記述でシンプルかつ理解しやすいため、複雑なオブジェクトのデータ フィールドを取得するのに便利です。

分割モデル

分割では、分割のソースは分割代入式の右側にあり、分割のターゲットは分割代入式の左側にあります。破壊的な表現。

分割代入の役割

1. x, y変数の値を交換する

分割代入を使用すると、3 番目の変数を使用せずに 2 つの変数の値を交換できます

    let x = 1;
    let y = 2;
    console.log('x:'+x, 'y:'+y);   //x:1 y:2
    //结构赋值  
    [x,y] = [y,x];
    console.log('x:'+x, 'y:'+y);   //x:2 y:1

2. 文字列を分解し、文字を変数に渡します

var [a,b,c,d,e] = "hello";
console.log(a); // h
console.log(b); // e
console.log(c); // l
console.log(d); // l
console.log(e); // o

3 , 関数から複数の値を返す

//関数は 1 つの値のみを返すことができます。複数の値を返したい場合は、それらを配列に入れるか、異議を唱えて返してください。

  function example(){
        //返回一个数组
        return [1,2,3]
    }
    let [a,b,c]= example();
    console.log('a:'+a,'b:'+b,'c:'+c);  //a:1 b:2 c:3
    
    
    function example2(){
        //返回一个对象
        return {
            name:'kang+',
            age:20
        }
    }
    let {name,age} = example2();
    console.log('name:'+name,'age:'+age);  //name:kang+ age:20

4. 関数パラメータの定義

 //参数是一组有次序的值
         function f([x,y,z]){
             console.log('x:'+x);
             console.log('y:'+y);
             console.log('z:'+z);
         }

         f([1,2,3]);


        //参数是一组没有次序的值
         function f({x,y,z}){
             console.log('x:'+x);
             console.log('y:'+y);
             console.log('z:'+z);
         }
         f({z:3, x:2, y:1});

5. json データの抽出 (プロジェクト開発で使用する必要があります)

    let jsonData = {
        number:01,
        status:'200',
         data:[{person:'kang+',age:20}]

     }
    // 获取json数据

     let {number,status,data,data:[{person,age}]} = jsonData;
     console.log('number:'+number);   //number:1
     console.log('status:'+status);   //status:200 
     console.log(data)                // [{…}]
     console.log('person:'+person);   //person:kang+
     console.log('age:'+age);         //age:20

6. 関数パラメータのデフォルト値 (個人的にはこれはほとんど役に立たないと思います)

   function Person(name,age,school = 'xiyou'){
         this.name = name;
         this.age = age;
        this.school = school;
     }
     var son = new Person('kang+',20);
     console.log(son)   // {name: "kang+", age: 20, school: "xiyou"}

7.マップ構造

 Map 结构原生支持 Iterator接口,配合变量的解构赋值获取键名和键值就非常方便。    var map = new Map();
    map.set('name','kang+');
    map.set('age','20');

    for(let [key, value] of map){
        console.log(key + ' is ' + value);
    }
    name is kang+
    age is 20

    获取键名    var map = new Map();
    map.set('name','kang+');
    map.set('age','20');
    for(let [key] of map){
        console.log(key);    //name   age
    }

    // 获取键值
    var map = new Map();
    map.set('name','kang+');
    map.set('age','20');
    for(let [,value] of map){
        console.log(value);   // kang+    20
    }

[関連する推奨事項: JavaScript ビデオ チュートリアル Web フロントエンド ]

以上がes6 における構造化代入の役割は何ですかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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