ES5与ES6常用语法教程之 ②解构语法糖、声明变量异同
js常用语法系列教程如下
- es5与es6常用语法教程(1)
- es5与es6常用语法教程(2)
- es5与es6常用语法教程(3)
- es5与es6常用语法教程(4)
- es5与es6常用语法教程(5)
- es5与es6常用语法教程(6)
- es5与es6常用语法教程(7)
这部分教程我们主要讲解以下几个常用语法
- 如何创建对象,如何给对象添加属性和方法
- var 与 let 申明变量时的异同点
- 解构对象
- 解构数组
- 解构函数参数
如何创建对象,如何给对象添加属性和方法
1 componentDidMount() { 2 3 // 创建一个小明对象 4 let xiaoming = {} 5 6 // 给小明这个对象添加属于他的属性 7 xiaoming.name = 'XiaoMing' 8 xiaoming.age = 20 9 xiaoming.height = 180 10 11 // 给小明这个对象添加属于他的方法 12 xiaoming.eat = () => {console.log('eat')} 13 xiaoming.learn = () => {console.log('learn RN')} 14 15 // 获取小明的名字 16 console.log(xiaoming.name) 17 18 // 调用小明自己的方法 19 xiaoming.eat() 20 xiaoming.learn() 21 22 // 打印小明对象看看效果吧 23 console.log(xiaoming) 24 }
日志
var 与 let 申明变量时的区别
- 只申明变量不赋值,表现相同
1 (function() { 2 var varVariable 3 let letVariable 4 console.log(varVariable) // 输出 undefined 5 console.log(letVariable) // 输出 undefined 6 }())
- 使用未声明的变量时,表现相同
1 (function() { 2 console.log(varTest) // 输出 undefined 3 console.log(letTest) // 输出 undefined 4 5 var varTest = 'varTest' 6 let letTest = 'varTest' 7 }())
- 重复声明同一个变量时,表现不同
1 (function() { 2 3 var varTest = 'test var OK.' 4 let letTest = 'test let OK.' 5 6 var varTest = 'varTest changed.' 7 let letTest = 'letTest changed.' // 直接报错:SyntaxError:Identifier 'letTest' has already been declared 8 9 console.log(varTest) // 输出 varTest changed,覆盖掉了之前的值:test 10 // var OK. 11 console.log(letTest) 12 }())
- 变量作用域,表现不同
1 var xx 2 3 const test = () => { 4 var aa // 声明一 5 let bb //声明二 6 this.cc //声明三 7 8 // 声明一局部代码块 9 { 10 let dd //声明四 11 } 12 }
区别
- let 声明的变量作用域为某个代码块。而代码块的长度可大可小。也就是说,当按声明二的方式声明一个变量时,该变量的作用范围于为整个function语句。当按声明四方式声明一个变量时,该变量的作用范围为局部的代码块。
- var 声明的变量作用域为整个函数体(当按声明一的方式声明变量时);当var变量声明在函数外,该var变量的作用域为整个js文件周期(全局作用域)。
那么,用this声明的变量呢?
- 简单地说,用this声明的变量作用域也是全局的。如果实例化test函数 var p=new test() 那么用p能访问test函数内的哪些变量呢?答案是只有cc 。实际上this声明的变量是作用于上下文的。
任何函数中的this代表调用该函数的对象,如果没有任何对象调用该函数(直接让函数执行),那么就相当于是window对象调用该函数执行(其中的this就代表window对象)
var 与 let 总结
- 使用 var 申明的变量,可以重复申明,只是后申明的会覆盖前面申明的
- 使用 let 申明的变量,不能够重复申明,重复申明直接报错
- 使用 let 声明变量,该变量的作用范围限于声明它的代码块中
- 如果未在 var \ let 语句中初始化变量,则将自动为其分配 JavaScript 值 undefined
解构对象
1 const breakfast = () => { 2 return {dessert: '🎂', drink: '🍵', fruit: '🍎'} 3 } 4 5 let {dessert: dessert, drink: drink, fruit: fruit} = breakfast() 6 7 console.log(dessert) // 输入 🎂 8 console.log(drink) // 输入 🍵 9 console.log(fruit) // 输入 🍎
我们可以将上面的解构对象简化
1 const breakfast = () => { 2 return {dessert: '🎂', drink: '🍵', fruit: '🍎'} 3 } 4 5 let {dessert, drink, fruit} = breakfast() 6 7 console.log(dessert) // 输入 🎂 8 console.log(drink) // 输入 🍵 9 console.log(fruit) // 输入 🍎
解构数组
- 常规数组取值方法
1 const breakfast = () => { 2 return [🎂, 🍵, 🍎] 3 } 4 5 var tmpArr = breakfast() 6 dessert = tmpArr [0] 7 drink = tmpArr [1] 8 fruit = tmpArr [2] 9 10 console.log(dessert) // 输出 🎂 11 console.log(drink) // 输出 🍵 12 console.log(fruit) // 输出 🍎
- 使用解构语法
1 const breakfast = () => { 2 return [🎂, 🍵, 🍎] 3 } 4 let [dessert, drink, fruit] = breakfast() 5 6 console.log(dessert) // 输出 🎂 7 console.log(drink) // 输出 🍵 8 console.log(fruit) // 输出 🍎
解构函数参数
1 const breakfast = (dessert, drink, {locaiotn, restaurant} = {}) => { 2 console.log(dessert, drink, locaiotn, restaurant) // 输出:🍰 🍺 济南 星巴克 3 } 4 5 breakfast ('🍰', '🍺', {locaiotn: '济南', restaurant: '星巴克'})
解构参数必须传参
解构参数与一般的参数不同点在于,它是一个必须要传值的参数,如果不传,则会引发程序报错:
function setCookie(name, value, {secure, path, domain, expires}) { console.log(expires); //其他代码 } setCookie('type', 'js'); // Uncaught TypeError: Cannot destructure property `secure` of 'undefined' or 'null'.
原因是为什么呢?是因为解构参数存在的函数,当我们在调用setCookie()的时候,函数内部其实是这样的:
function setCookie(name, value, options) { let {secure, path, domain, expires} = options; //这是引擎背后做的 console.log(expires); //其他代码 }
用于结果的对象如果是null或者undefined,则程序会报错,所以当我们不给解构参数传值的时候,会引发了程序报错。
为了解决以上问题,我们需要在定义函数的时候,给解构参数提供默认值:
function setCookie(name, value, {secure, path, domain, expires} = {}) {}
setCookie('id', 'mike'); //有了默认值,便不会报错 {} 为解构参数的默认值
给解构参数属性设置默认值
let defaultOptions = { secure: true, path: '/example', domain: 'test', expires: 60 }; function setCookie(name, value, { secure = defaultOptions.secure, path = defaultOptions.path, domain = defaultOptions.domain, expires = defaultOptions.expires } = defaultOptions) { console.log(secure); //true console.log(path); //example console.log(domain);//test console.log(expires);//30 } setCookie('id', 'mike', {path: '/example', domain: 'test', expires: 30});
给解构参数的属性设置默认值和一般对象的解构设置默认值是一样的,也是在用等号=给属性赋值。
这里特别要注意的是,如果只是单纯地给解构参数的属性设置默认值,而不给整个解构参数设置默认值,依然不能解决类似于setCookie('id', 'mike')
这样不传参所引发的代码报错问题,所以不要忘了给整个解构参数设置默认值(也就是这个例子里面的= defaultOptions
)。