温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

基于ES6作用域和解构赋值的示例分析

发布时间:2021-08-07 09:55:41 来源:亿速云 阅读:167 作者:小新 栏目:web开发

小编给大家分享一下基于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作用域和解构赋值的示例分析”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

es6
AI