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也需要引入)
相关推荐
掘金安东尼8 小时前
让 JavaScript 更容易「善后」的新能力
前端·javascript·面试
掘金安东尼8 小时前
用 HTMX 为 React Data Grid 加速实时更新
前端·javascript·面试
灵感__idea10 小时前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
yinuo11 小时前
轻松接入大语言模型API -04
前端
袋鼠云数栈UED团队11 小时前
基于 Lexical 实现变量输入编辑器
前端·javascript·架构
cipher12 小时前
ERC-4626 通胀攻击:DeFi 金库的"捐款陷阱"
前端·后端·安全
UrbanJazzerati12 小时前
非常友好的Vue 3 生命周期详解
前端·面试
AAA阿giao12 小时前
从零构建一个现代登录页:深入解析 Tailwind CSS + Vite + Lucide React 的完整技术栈
前端·css·react.js
兆子龙13 小时前
像 React Hook 一样「自动触发」:用 Git Hook 拦住忘删的测试代码与其它翻车现场
前端·架构
兆子龙13 小时前
用 Auto.js 实现挂机脚本:从找图点击到循环自动化
前端·架构