当前位置: 首页 > article >正文

react高阶组件及hooks

高阶组件

一个函数可以接受另一个函数作为参数

例如

// App.js
import Children from "./children";
function App() {
    return ( 
        <div>
            <Children/>
        </div>
     );
}

export default App;
// children.js
import  Components from "./components.js";
function Children(props) {
    return ( 
        <div>我的姓名:{props.name}</div>
     );
}

export default Components(Children);
// Components.js
import { Component } from "react";

function CompentUnit(Compnent) {
    return class extends Component{
        constructor(){
            super();
            this.state = {
                name: '张三'
            }
        }
        render(){
            return (
                <Compnent {...this.state}/>
            )
        }
    }
}

export default CompentUnit;

hooks

React Hooks 的意思是,组件尽量写成纯函数,如果需要外部功能和副作用,就用钩子把外部代码"钩"进来
react hooks:
useState
useEffect
useRef
useReducer

useState

import { Component } from "react"
class App extends Component {
    constructor(props) {
        super(props);
        this.state = {
            number: 1
        } 
    }
    state = {}
    render() {
        return (
            <div>
                {this.state.number}
                <button onClick={() => this.addClick()}>点击</button>
            </div>
        );
    }
    addClick() {
        let num = this.state.number;
        this.setState(
            {
                number: ++num
            }
        )
    }
}

export default App;

useEffect

useEffect 使用方法 useEffect(()=>{ 参数方法 },[依赖参数])

useEffect未写依赖参数。为undefined

import { useEffect,useState } from "react"
function App() {
    const [name, setName] = useState('张三')
    useEffect(()=>{
        console.log('修改了');
    })
    return ( 
        <div>
            <h1>{name}</h1>
            <button onClick={()=>{
                setName('王五')
            }}>修改姓名</button>
        </div>
     );
}

export default App;

在这里插入图片描述

useEffect 未填写依赖参数 。[]

import { useEffect,useState } from "react"
function App() {
    const [name, setName] = useState('张三')
    useEffect(()=>{
        console.log('修改了');
    },[])
    return ( 
        <div>
            <h1>{name}</h1>
            <button onClick={()=>{
                setName('王五')
            }}>修改姓名</button>
        </div>
     );
}

export default App;

在这里插入图片描述

useEffect 填写依赖参数 [状态]

import { useEffect,useState } from "react"
function App() {
    const [name, setName] = useState('张三')
    useEffect(()=>{
        console.log('修改了name');
    },[name])
    return ( 
        <div>
            <h1>{name}</h1>
            <button onClick={()=>{
                setName('王五')
            }}>修改姓名</button>
        </div>
     );
}

export default App;

在这里插入图片描述

useContext

import { createContext,useContext,useState } from "react"
const context = createContext();
function Children (){
    const {name, setName} = useContext(context)
    
    return (
        <div>
            <h1>{name}</h1>
            <button onClick={()=>{
                setName('王五')
            }}>修改姓名</button>
        </div>
    )
}

function Father() {
    return (
        <Children/>
    )
}


function App() {
    const [name, setName] = useState('李四')
    return ( 
        <context.Provider value={{name,setName}}>
            <Father/>
        </context.Provider>
     );
}

export default App;

useReaducer

import { useReducer } from "react"
function App() {
    const disopseFn = (state, action) => {
        console.log(state,action);
        
        switch (action.type) {
            case 'change':
                return { ...state, ...action.value };
            default:
                throw new Error()
        }
    }
    const [props, disopse] = useReducer(disopseFn, { name: '李四', age: 12 })
    return (
        <div>
            <h1>姓名:{props.name}</h1>
            <h1>年龄: {props.age}</h1>
            <button onClick={() => 
                disopse({ type: 'change', value: { name: '张三' } })
            }>修改姓名</button>
        </div>
    );
}

export default App;

http://www.kler.cn/a/453875.html

相关文章:

  • 透视网络世界:计算机网络习题的深度解析与总结【前3章】
  • 物联网乐鑫USB方案,设备互联和数据传输应用
  • Oracle 普通表至分区表的分区交换
  • chrome缓存机制以及验证缓存机制
  • springboot/ssm图书大厦图书管理系统Java代码编写web图书借阅项目
  • uniapp抖音小程序,如何一键获取用户手机号
  • ES学习module模块化(十二)
  • 新建一个springboot项目
  • 中关村科金智能客服机器人如何解决客户个性化需求与标准化服务之间的矛盾?
  • 深度学习实战103-基于KDD Cup 99数据集的搭建神经网络的检测系统(NIDS),通过对网络流量数据进行分析,提供完整代码
  • DALFox-一款XSS自动化扫描工具
  • GA-Kmeans-Transformer时序聚类+状态识别组合模型
  • vscode修改中文显示格式
  • transformer用作分类任务
  • Golang 的并发优势
  • 数据结构(哈希表(上)纯概念版)
  • 深入理解 MySQL 架构
  • (七)循环神经网络_LSTM长短期记忆网络
  • STM32单片机芯片与内部45 UART 不定长度接收 标志位结束 定时器超时 串口空闲中断
  • 【有作图代码】KL散度与自由能F:高斯分布下的“距离度量”与“能量计算”