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也需要引入)
相关推荐
逆旅行天涯2 分钟前
【Threejs】从零开始(六)--GUI调试开发3D效果
前端·javascript·3d
m0_7482552623 分钟前
easyExcel导出大数据量EXCEL文件,前端实现进度条或者遮罩层
前端·excel
web147862107231 小时前
C# .Net Web 路由相关配置
前端·c#·.net
m0_748247801 小时前
Flutter Intl包使用指南:实现国际化和本地化
前端·javascript·flutter
飞的肖1 小时前
前端使用 Element Plus架构vue3.0实现图片拖拉拽,后等比压缩,上传到Spring Boot后端
前端·spring boot·架构
青灯文案11 小时前
前端 HTTP 请求由 Nginx 反向代理和 API 网关到后端服务的流程
前端·nginx·http
车轮滚滚__1 小时前
uniapp对接unipush 1.0 ios/android
笔记
m0_748254881 小时前
DataX3.0+DataX-Web部署分布式可视化ETL系统
前端·分布式·etl
用户30587584891251 小时前
Connected-react-router核心思路实现
react.js
ZJ_.1 小时前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps