微信小程序制犯案例_基于ES6作用域宽和构赋值详

日期:2021-01-12 类型:行业动态 

关键词:建站平台有哪些,如何建设网站,免费自助建站,如何建立一个网站,网站建站的

基于ES6作用域和解构赋值详解       下面小编就为大家带来一篇基于ES6作用域和解构赋值详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

var 声明局部变量,for/if花括号中定义的变量在花括号外也可访问

let 声明的变量为块作用域,变量不可重复定义

const 声明常量,块作用域,声明时必须赋值,不可修改

// const声明的k指向一个对象,k本身不可变,但对象可变
function test() {
 const k={
 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}]} = metaData;
 console.log(esTitle, cnTitle);
//Output: abc test

以上这篇基于ES6作用域和解构赋值详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持凡科。