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 ''
相关推荐
xuhaoyu_cpp_java3 小时前
项目学习(三)分页查询
java·经验分享·笔记·学习
小宋加油啊4 小时前
机械臂抓取物体 PVN3D算法调研学习
学习·算法·3d
Xzh04235 小时前
AI Agent 学习路线(Java 后端方向)
java·人工智能·学习
做cv的小昊6 小时前
计算机图形学:【Games101】学习笔记08——光线追踪(辐射度量学、渲染方程与全局光照、蒙特卡洛积分与路径追踪)
图像处理·笔记·学习·计算机视觉·游戏引擎·图形渲染·概率论
星恒随风6 小时前
C++ 类和对象入门(五):初始化列表、explicit 和 static 成员详解
开发语言·c++·笔记·学习·状态模式
鹤鸣的日常7 小时前
前端运行时动态环境变量方案
前端·react.js·docker·前端框架·vue·gitlab
sensen_kiss8 小时前
CPT304 SoftwareEngineeringII 软件工程 2 Pt.8 软件测试 (Software Testing)(上)
学习·软件工程
力学与人工智能8 小时前
PPT分享 | 洛桑联邦理工学院魏震:深度几何学习在工业设计优化中的应用
学习·优化·工业设计·深度几何学习·洛桑联邦理工学院
sensen_kiss9 小时前
CPT304 SoftwareEngineeringII 软件工程 2 Pt.9 软件测试 (Software Testing)(下)
学习·软件工程
wu_ye_m9 小时前
学习c语言第35天 函数声明和定义
c语言·开发语言·学习