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 }
日志es6
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声明的变量做用域也是全局的。若是实例化test函数 var p=new test() 那么用p能访问test函数内的哪些变量呢?答案是只有cc 。实际上this声明的变量是做用于上下文的。
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) // 输入 🍎
咱们能够将上面的解构对象简化dom
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,则程序会报错,因此当咱们不给解构参数传值的时候,会引起了程序报错。
为了解决以上问题,咱们须要在定义函数的时候,给解构参数提供默认值:ui
function setCookie(name, value, {secure, path, domain, expires} = {}) {} setCookie('id', 'mike'); //有了默认值,便不会报错 {} 为解构参数的默认值
给解构参数属性设置默认值this
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
)。lua