react笔记

一、项目打包部署:

命令:npm run build

要部署服务器需要通过java或者node搭建一个服务器,前端实现较困难,但是也可以借助一个第三方库express来体验服务器部署。

打包完成后进入build文件夹:

serve 文件名 指定启动的文件名。如果默认启动当前文件夹下根目录:serve

前端通常公司中是给后端一个build的包,让后端部署到服务器

二、react扩展

创建一个新项目:creare-react-app react-extension

初始化项目目录文件:

  • index.js
javascript 复制代码
import React from "react";
import ReactDOM from "react-dom";
import App from './App'

ReactDOM.render(<App/>,document.getElementById('root'))
  • app.js
javascript 复制代码
import React, { Component } from 'react'

export default class App extends Component {
  render() {
    return (
      <div>
        <h2>我是app</h2>
      </div>
    )
  }
}
  • index.html
html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root"></div>
</body>
</html>
扩展1:setState的使用

(1)、setState是异步更新,setState方法是同步执行的,但是更新state状态的动作是异步的,为了提高渲染效率,减少频繁的页面更新,react的更新应该也是有一个缓存异步更新的机制。所以即使调用了更新的方法之后去拿更新的值也是拿不到的。

javascript 复制代码
import React, { Component } from 'react'

export default class index extends Component {
    state={count:0}
    add=()=>{
        // 获取原来的count值
        const {count}=this.state
        // 更新状态
        this.setState({count:count+1})
        // 这里拿到的count并不是修改后的count,而是更新之前的count值,这是因为setState方法
        // 虽然是同步的,但是react操作更新的动作是异步的
        console.log('输出',this.state.count)
    }
  render() {
    return (
      <div>
        <h1>当前求和为:{this.state.count}</h1>
        <button onClick={this.add}>点我+1</button>
      </div>
    )
  }
}

为了解决1中的问题,实际开发中setState方法是可以支持传入第二个参数的,第二个参数默认是一个函数,因此我们可以从函数中拿到更新之后的状态。

javascript 复制代码
  // 更新状态
        this.setState({count:count+1},()=>{
            console.log(this.state.count)
        })

(2)、setState支持两种更新状态的方法:对象式更新和函数式更新

  • 对象式更新:

以上的代码中的更新就是对象式更新,第一个参数采用传入一个对象的方式

  • 函数式更新

(第一个参数是通过一个箭头函数返回一个对象的方式更新状态,第二个参数箭头函数的方式拿到更新后的state.)

javascript 复制代码
        this.setState(
            state=>({count:state.count+1}),
            ()=>{
                console.log(this.state.count)
            })

从上面的两种更新方式获取可以看到,第一种更新的方式是函数式更新的语法糖,写起来代码更简洁,如果项目中不需要通过state,props的值更新状态,则可以直接使用第一种对象式更新,如果需要用到state,或props中的值,则也可以通过函数式更新的方式更新。当然,其实通过对象式更新也可以实现函数式更新要实现的功能。

扩展2:路由懒加载lazyLoad

为什么要用:解决首屏幕加载慢的问题,如果一个入口页面有很多的路由栏目,可以通过路由懒加载,让路由页面在点击的时候再去加载。

这个时候其实还会存在一个问题,就是点击路由的时候如果路由加载慢应该先去展示一个其他的组件。否则会报错

扩展3:hooks

  • state
  • useEffect

相当于函数组件中的两个生命周期函数,componentdidMounted和componentdidUpdated,是那个取决于传入的第二个参数,如果传入一个空数据[],那么就相当于mounted,如果什么都不传入,就同时相当于mounted和updated。

  • 函数式组件中如何使用componentWillUnmount组件

扩展3:useRef

函数式组件中使用ref和类组件中不同

扩展4:fragment

空标签也可以实现同样的效果,区别是fragment可以接收key属性,但空标签不能接收任何属性

文档碎片,如果需要使用key遍历,可以使用fragment,如果不需要也可以使用空标签。

扩展5:上下文context

作用:一种组件间通信方式,用于祖组件与后代组件之间跨层级通信

  1. 创建上下文context对象

2.接收使用

  1. 函数式组件的使用:(consumer也需要引入)
相关推荐
Bunny021238 分钟前
SpringMVC笔记
java·redis·笔记
古蓬莱掌管玉米的神4 小时前
vue3语法watch与watchEffect
前端·javascript
林涧泣4 小时前
【Uniapp-Vue3】uni-icons的安装和使用
前端·vue.js·uni-app
雾恋4 小时前
AI导航工具我开源了利用node爬取了几百条数据
前端·开源·github
拉一次撑死狗4 小时前
Vue基础(2)
前端·javascript·vue.js
祯民5 小时前
两年工作之余,我在清华大学出版社出版了一本 AI 应用书籍
前端·aigc
热情仔5 小时前
mock可视化&生成前端代码
前端
m0_748246355 小时前
SpringBoot返回文件让前端下载的几种方式
前端·spring boot·后端
wjs04065 小时前
用css实现一个类似于elementUI中Loading组件有缺口的加载圆环
前端·css·elementui·css实现loading圆环
爱趣五科技5 小时前
无界云剪音频教程:提升视频质感
前端·音视频