React学习:ES6

参考视频

1. let,var, const 区别

js 复制代码
var x = 1;      // 函数作用域,可重复声明
let y = 2;      // 块级作用域,不可重复声明
const z = 3;    // 块级作用域,不可重新赋值

2. Objects

js 复制代码
const person ={
    name: 'Maximilian',
    age: 30,
    walk(){
        console.log("walk")
    }
}
// 访问对象属性的两种方式:
//1. 通过[]
console.log(person["name"])
//2. 通过 .
console.log(person.age)

3. this

如果使用对象的形式调用方法,this指向这个对象;但如果单独调用该函数,this并不指向该对象,具体而言:严格模式下:this 为undefined;非严格模式下:this 这时指向的是浏览器的全局对象,即window。

js 复制代码
const person ={
    name: 'Maximilian',
    age: 30,
    walk(){
        console.log(this)
    }
}


person.walk() //{name: 'Maximilian', age: 30, walk: ƒ}
const walk= person.walk
walk() // undefined because this is not bound to the object anymore

注意 :在js中,由于函数也是对象,因此单独调用该孤立函数时,可以通过.bind()方法绑定this指向的对象

js 复制代码
const walk= person.walk.bind(person)
walk() //{name: 'Maximilian', age: 30, walk: ƒ}

4 . Arrow Function

js 复制代码
const person ={
    name: 'Maximilian',
    age: 30,
    walk(){
        console.log(this)
    },
    talk(){
        //由于以孤立函数调用setTimeout,因此this默认是window对象
        setTimeout(function(){
            console.log(this)
        }, 1000)

        //使用箭头函数,不重新绑定this
        setTimeout(()=>{
            console.log(this)
        },1000)
    }
}

person.talk()

5. Array map && filter

js 复制代码
const colors=["red","blue","green"]

const items =colors.map(color=>`<li>${color}</li>`)
const list=colors.filter(color=> color === "red")

6. Object Destructing 解构

js 复制代码
const address={
    street:"1234",
    city:"New York",
    state:"NY",
    zip:"10001"
}

// const street=address.street
// const city=address.city
// const state=address.state
// const zip=address.zip

const{street,city,state,zip}=address

7. Spread Operator

把一个可迭代对象(数组、字符串等)或对象"展开"成独立的元素。

js 复制代码
const address={
    street:"1234",
    city:"New York",
    state:"NY",
    zip:"10001"
}

const person ={
    name:"John",
    age:30,
    address:address
}

// concat
const information={...address,... person}
// clone
const clone ={...address}

8. Named and Default

js 复制代码
// Default -> import ... from '';
// Named -> import {...} from ''
相关推荐
yangyanping201081 小时前
Go语言学习之对象关系映射GORM
jvm·学习·golang
网络工程小王1 小时前
【Transformer架构详解】(学习笔记)
笔记·学习
倒酒小生3 小时前
今日算法学习小结
学习
醇氧4 小时前
【学习】【说人话版】子网划分
学习
前端精髓4 小时前
移除 Effect 依赖
前端·javascript·react.js
不灭锦鲤4 小时前
网络安全学习(面试)
学习·安全·web安全
世人万千丶6 小时前
Flutter 框架跨平台鸿蒙开发 - 鸿蒙版本五子棋游戏应用
学习·flutter·游戏·华为·harmonyos·鸿蒙
Aktx20FNz6 小时前
一文学习 Spring AOP 源码全过程
java·学习·spring
Jay Kay6 小时前
生成式推荐模型学习记录part1
学习
菲利普马洛7 小时前
记一次主题闪烁问题
前端·css·react.js