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也需要引入)
相关推荐
FIRE23 分钟前
uniapp小程序分享使用canvas自定义绘制 vue3
前端·小程序·uni-app
四喜花露水24 分钟前
vue elementui el-dropdown-item设置@click无效的解决方案
前端·vue.js·elementui
jokerest1231 小时前
web——sqliabs靶场——第五关——报错注入和布尔盲注
前端
A_cot1 小时前
一篇Spring Boot 笔记
java·spring boot·笔记·后端·mysql·spring·maven
谢尔登1 小时前
前端开发调试之 PC 端调试
开发语言·前端
每天吃饭的羊1 小时前
在循环中只set一次
开发语言·前端·javascript
_默_4 小时前
adminPage-vue3依赖DetailsModule版本说明:V1.2.1——1) - 新增span与labelSpan属性
前端·javascript·vue.js·npm·开源
也无晴也无风雨6 小时前
深入剖析输入URL按下回车,浏览器做了什么
前端·后端·计算机网络
Martin -Tang7 小时前
Vue 3 中,ref 和 reactive的区别
前端·javascript·vue.js
FakeOccupational8 小时前
nodejs 020: React语法规则 props和state
前端·javascript·react.js