React 学习笔记总结(三)

1. React( v16.8 版本) 生命周期


组件的 挂载(mount) 和 卸载(unmount) 。

生命周期钩子函数:

  • componentDidMount()函数调用周期:组件挂载完毕之后。
  • componentWillUnmount()函数调用周期:组件将要卸载之前调用。
  • render函数调用周期:初始化渲染、state状态更新之后。

组件卸载后,经常遇到的一个错误:
在这里插入图片描述


react生命周期架构图:
在这里插入图片描述
在这里插入图片描述

2. React( v16.8 版本) 生命周期 更新流程

2.1 三个更新流程


更新流程,大体上三个流程如下:
在这里插入图片描述

2.2 setState()的生命周期流程(对应上图2号线)


setState()的生命周期流程:

// shouldComponentUpdate钩子函数:相当于一个控制组件更新的 阀门 (校验)
// 应该修改就返回true,不应该修改就返回false。
// 该函数不实现就会有一个默认值永远返回true。
shouldComponentUpdate(){
    console.log('shouldComponentUpdate')
    return true
}

// 组件将要更新的钩子
componentWillUpdate(){
    console.log('componentWillUpdate')
}

// 组件更新完毕之后的钩子
componentDidUpdate(){
    console.log('componentDidUpdate')
}

2.3 forceUpdate()的生命周期流程(对应上图3号线)


forceUpdate是强制更新,而setState是正常更新。

强制更新的不同在于,不修改state状态的情况下,也能更新页面。

在这里插入图片描述

2.4 父组件render()渲染的生命周期流程(对应上图1号线)


就是存在了父子组件会调用的钩子:

class A extends React.Component {
     state = {carName: '奔驰'}
     changeCar = ()=>{
         this.setState({carName:'奥托'})
     }
     render() {
         return (
             <div>
                 <div>我是A组件</div>
                 <button onClick={this.changeCar}>换车</button>
                 <B carName={this.state.carName}/>
             </div>
         );
     }
 }

 class B extends React.Component {
     render() {
         return (
             <div>
                 我是B组件,接受到的车是: {this.props.carName}
             </div>
         );
     }

     componentWillReceiveProps(){
         console.log('componentWillReceiveProps')
     }

     shouldComponentUpdate(){
         console.log('shouldComponentUpdate')
         return true
     }

     componentWillUpdate(){
         console.log('componentWillUpdate')
     }

     componentDidUpdate(){
         console.log('componentDidUpdate')
     }

 }

 // 渲染组件
 ReactDOM.render(<A/>,document.getElementById('test'))

2.5 React( v16.8 版本)生命周期 总结


在这里插入图片描述

3. React 新版本的生命周期


react.development.js 和 react-dom.development.js的版本一般都是对应的,如上面版本都是( v16.8 版本)。

接下来用17新版本的React学习:
在这里插入图片描述
在这里插入图片描述
官方的解释:
在这里插入图片描述

注意:这里的UNSAFE并不是指的安全性问题,而是为了未来版本迭代中有可能出现bug(异步渲染)。
在这里插入图片描述

几个版本的对于三个钩子的显示:
在这里插入图片描述


16版本React 与 17版本React生命周期比对:
在这里插入图片描述

4. React(17 新版本钩子函数) getDerivedStateFromProps函数


derived英文直译:衍生的。

该钩子函数一般用于下图的情况:即state的值在任何时候都取决于props的值。

在这里插入图片描述

class B extends React.Component {
    state = {
        count:0
    }
    render() {
        return (
            <div>
                我是B组件,接受到的车是: {this.props.carName}
            </div>
        );
    }
    static getDerivedStateFromProps(props,state){
        console.log('getDerivedStateFromProps',props,state)
        // 返回null,就是放行。因此,一般state状态要规定与props相同的时候才会用到。
        return null
    }
}

使用的时候注意以下几点:

  • 必须声明为static静态的。
  • 能接受到两个参数props和state两个参数。
    在这里插入图片描述

该函数生命周期钩子如下:
在这里插入图片描述

5. React(17 新版本钩子函数) getSnapshotBeforeUpdate函数


在这里插入图片描述


17版本的React的componentDidUpdate钩子函数可以接受三个参数:
在这里插入图片描述

getSnapshotBeforeUpdate(){
    console.log('getSnapshotBeforeUpdate')
    return '接受'
}
// 接受三个参数,更新前的props,更新前的state,快照值snapshotValue
componentDidUpdate(preProps,preState,snapshotValue){
    console.log('preProps',preProps)
    console.log('preState',preState)
    console.log('snapshotValue',snapshotValue)
}

getSnapshotBeforeUpdate函数使用场景:

  • 锁定滚动条场景案例:

在这里插入图片描述

6. React 17版本的生命周期总结


在这里插入图片描述

目前建议的做法:
在这里插入图片描述

7. React 之 DOM的Diffing算法


每一个真实DOM会对应一个虚拟DOM。当生成一个新的虚拟DOM,旧的虚拟DOM与新的虚拟DOM会进行比对。
在这里插入图片描述
就像上面是的,通过新虚拟DOM与旧虚拟DOM进行比对,仅仅是将不一样的数据(肖战)放上去了。

并且这个页面更新的最小粒度是标签。就像下图:
在这里插入图片描述


面试题:

  • react/vue中的key有什么作用!
  • 为什么遍历列表的时候,key最好不要用index?
    在这里插入图片描述

在这里插入图片描述


在这里插入图片描述

8. React 之 react脚手架初始化


facebook提供了一个react脚手架,项目的整体技术架构为:react、webpack、es6、eslint。

脚手架开发的项目特点:模块化、组件化、工程化。

React提供了一个用于创建React项目的脚手架库:create-react-app


创建脚手架项目过程:

  • 第一步:全局安装:npm install -g create-react-app。
  • 第二步:切换到创项目的目录,使用命令:create-react-app hello-react。
  • 第三步:进入项目文件夹:cd hello-react。
  • 第四步:启动项目npm start。

9. React 之 脚手架文件结构

9.1 文件结构


node_modules文件:存放依赖的文件。

public文件:存放静态资源的。
在这里插入图片描述

Vue 和 React都是SPA(single page application)应用,单页面应用。

9.2 应用加壳技术


应用加壳技术:

  • 可以理解为用户操作移动端的时候其实是打开了一个壳,通过这个壳操作壳里面的html页面。看着像是操作移动端的东西,其实是通过壳来操作html页面而已。
    在这里插入图片描述

可以通过开启移动端访问taobao.com网址来达到这种效果:(也就是应用加壳)
在这里插入图片描述

9.3 public中的index.html 结构解析


<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <!-- %PUBLIC_URL%代表public文件夹的路径。 -->
    <link rel="icon" href="%PUBLIC_URL%/favicon.ico" />
    <!-- 开启理想视口,用于做移动端网页的适配。 -->
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <!-- 用于配置浏览器页签的颜色 + 地址栏的颜色。(仅支持安卓手机,移动端的!) -->
    <meta name="theme-color" content="#000000" />
    <meta
      name="description"
      content="Web site created using create-react-app"
    />
    <!-- 用于指定网页添加到手机主屏幕后的图标 -->
    <link rel="apple-touch-icon" href="%PUBLIC_URL%/logo192.png" />
    <!-- 加壳应用要用到的一个配置文件! -->
    <link rel="manifest" href="%PUBLIC_URL%/manifest.json" />
    <title>React App</title>
  </head>
  <body>
    <!-- 若浏览器不支持js,则展示标签中的内容 -->
    <noscript>You need to enable JavaScript to run this app.</noscript>
    <div id="root"></div>
  </body>
</html>

9.4 public 中的robots.txt


当别人的爬虫,爬取网页信息时,通过此文件可以定义什么可以爬取,什么不可以爬取。

9.5 src下的文件


app.css:app组件的样式。

app.js:app的js文件。

app.test.js:测试文件。

index.css:入口文件index.js的样式。

logo.svg:是svg的logo图。


index.js:入口文件。

//  React.StrictMode作用:检查App组件的瑕疵什么的!
<React.StrictMode>
 <App />
</React.StrictMode>
// reportWebVitals方法是用来做性能检测的。
reportWebVitals();

在这里插入图片描述

在这里插入图片描述


setupTests.js文件:用来做组件测试的。也是引入了别的组件库。
在这里插入图片描述

总结:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xupengboo

你的鼓励将是我创作最大的动力。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值