ReactHooks学习记录

简介: ReactHooks学习记录

1.useState
引入useState

import React, { useState } from 'react';
复制代码
在无状态组件中去声明一个useState

function test() {
// 解构赋值 useState传递的参数为初始值 跟前面的[num,setUnm] 没有关系。。
const [num,setNum] = useState(0)
//在页面渲染这个值
return(

   <div>
     你点击了 {num}次 <br/><br/>

//每点击一次 即可增加

      <button onClick={()=>{setNum(num+1)}}>点我</button>
     </div>

)
}
复制代码
使用这样的方式写组件很方便..

2.useEffect
引入useEffect:

import React, { useEffect,useState } from 'react';
复制代码
在组件中使用:

function tesst(){
const [num,setNum] = useState(0)

// useEffect相当于是一个生命周期 异步
// 组件渲染完成后和组件更新时 调用
// componentDidMount 和 componentDidUpdate
useEffect(()=>{
    console.log(num)

//return意思为解绑 当组件销毁时调用
return()=>{

        console.log('老弟走了!')
    }

// 空数组[]时,就是当组件将被销毁时才进行解绑
// 实现了componentWillUnmount的生命周期函数

},[])

}
复制代码
3.useContext和createContext
// 1引用userContext和createContext来传参

import React, { useState,useContext,createContext } from 'react';
复制代码
//2创建一个createContext上下文

const NumContent = createContext();
复制代码
// 4.创建子路由

function Didi(){

// 4.1使用useContext来接收父组件传递的参数
let Num = useContext(NumContent)
return(
    <h1>我是弟弟{Num}</h1>
)

}
function Exp2(){

const [Num,setNum] = useState(0)
return(
    <div>
        <h1>{Num}</h1>
        <button onClick={()=>{setNum(Num+1)}}>点击增加</button>
        {/* 3.在组件中是引入NumContent.Provider 固定写法  value是要传递的参数 */}
        <NumContent.Provider value={Num}>
            {/* 5在组件NumContent.Provider内部写入 子组件 */}
            <Didi/>
        </NumContent.Provider>
    </div>
    
)

}
export default Exp2;
复制代码
4.useReducer
import React, { useReducer } from 'react';

// 创建一个reducer 传递两个参数 一个是传递的值 一个是如何控制这个值
function ReducerDemo(){
    // useReducer需要传递两个参数 1一个是reducer本身,一个是初始值
    // 前面的两个变量count是初始值,dispatch是派发器用来控制初始值
    // useReducer本身中的state对应的是初始值,action对应的是dispatch传递的参数
    const [count,dispatch]  = useReducer((state,action)=>{
            switch(action){
                case 'add':{
                    return state+1
                }
                case 'sub':{
                    return state-1
                }
                default:{
                    return state
                }
            }
        },0)
        return(
            <div>
                <h2>现在的分数是{count}</h2>
                <button onClick={()=>dispatch('add')}>Increment</button>
                <button onClick={()=>dispatch('sub')}>Decrement</button>
            </div>
        )
}

export default ReducerDemo
复制代码
5.useMemo
useMemo主要用来解决使用React hooks产生的无用渲染的性能问题

问题描述:点击志玲按钮的时候 子组件的小白changeXiaobai()也会执行 又重复的渲染了一次

期望:点击相对应的按钮 只渲染相对应的组件 无相关的组件不重复的去渲染

解决方案:使用useMemo来规避重复渲染的问题

import React,{useState,useMemo} from 'react';
function Exp5(){

const [xiaobai,setXiaobai] = useState('小白正在等待')
const [zhiling,setZhiling] = useState('志玲正在等待')
return (
    <div>
        <hr/>
        <button onClick={()=>{
            setXiaobai(new Date().toLocaleTimeString())
        }}>
            小白
        </button>
        <button onClick={()=>{
            setZhiling(new Date().toLocaleTimeString()+'志玲来了')
        }}>
            志玲
        </button> <br/> <br/>
        {/* 向子组件传递两个值 */}
        {/* 如果传递在组件中 而不是以属性的方式传递,在子组件中使用children接收 */}
        <Child name={xiaobai} name2={zhiling}></Child>
    </div>
)

}
//子组件
function Child({name,name2,children}){

function changeXiaobai(name){
    console.log('小白来了')
    return name +'你喊了一声小白 小白走过来了'
}
//使用useMemo 两个参数第一个是渲染的组件的方法 ,第二个是对应参数变化(条件) 下面的例子解释为只有name变化时候才 执行actionXiaobai() 这个函数
const actionXiaobai = useMemo(()=>changeXiaobai(name),[name])
return(
    <div>
        <div>{actionXiaobai}</div>
        <div>{name2}</div>
    </div>
)

}
export default Exp5
复制代码
6.useRef:
两个用处:用useRef获取React JSX中的DOM元素、用useRef来保存变量

import React,{useRef,useState,useEffect} from 'react';
// useRef获取React JSX中的DOM元素
// useRef来保存变量
function Exp6(){

// 声明一个dom变量 默认为Null 下面进行绑定
const inputEl = useRef(null)
// 声明一个方法
const onButtonClick = ()=>{
    inputEl.current.value = '你好彪哥'
    // console.log(inputEl.current.value )
}
//保存变量
const textRef = useRef()
const [text,setText] = useState('彪哥')
useEffect(()=>{
    textRef.current = text
    console.log('textRef.current',textRef.current)
})
return (
    <div>
        {/* 跟上面声明的inputEl进行绑定 */}
        <input ref={inputEl} type="text"></input>
        <button onClick={onButtonClick}>展示文字</button>
        <hr/>
        <input value={text} onChange={(e)=>{setText(e.target.value)}}></input>
    </div>
)

}
export default Exp6
复制代码
7.自定义hooks函数
一个自定义Hooks函数,要用use开头,区分出什么是组件,什么是自定义函数。
下面自定义Hooks函数获取窗口大小
import React,{useEffect,useState} from 'react';
function useSizeChange(){

//获取当前浏览器的宽高
let [size,setSize] = useState({
    width:document.documentElement.clientWidth,
    height:document.documentElement.clientHeight
})
//声明一个改变浏览器宽高的方法
let setSizeAction = () =>{
    setSize({
        width:document.documentElement.clientWidth,
        height:document.documentElement.clientHeight
    })
}
//在useEffect周期函数中调用
useEffect(()=>{
    window.addEventListener('resize',setSizeAction)
    //离开页面时解绑resize事件
    return()=>{
        window.removeEventListener('resize',setSizeAction)
    }
},[])
// 把size返回出去 在下面Exp7函数中使用(相当于是一个闭包)
return size

}
function Exp7(){

var size = useSizeChange()
return (
    <div>
        窗口的Sizi:{size.width}*{size.height}
    </div>
)

}
export default Exp7
复制代码

作者: Bill 本文地址: http://biaoblog.cn/info?id=1574931180000

版权声明: 本文为原创文章,版权归 biaoblog 个人博客 所有,欢迎分享本文,转载请保留出处,谢谢!

相关文章
|
4月前
taichi学习记录
关于Taichi编程语言学习的记录,涉及Taichi的安装方法、运行结果截图以及相关学习资源的链接,包括中文语音视频教程、系统学习课程和知乎资料。
|
8月前
|
SQL 安全 调度
网安预习课程笔记(九到十节)
本文是一篇关于渗透测试案例的分享,案例主要包括弱口令、SQL注入、内网渗透等多个环节,详细描述了渗透测试工作者如何通过一系列步骤获取不同服务器和系统的管理员权限。提到了一些关键的IP地址、数据库和服务器的发现,以及利用这些漏洞如何获取的权限。文章最后讨论了漏洞报告的组成部分,强调了报告的规范性和清晰度对于有效沟通和解决问题的重要性。 请注意,由于原始内容包含多个图片和链接,摘要中并未包含这些元素。
78 11
|
8月前
|
算法 程序员 开发工具
代码随想录 学习记录(1)
代码随想录 学习记录(1)
195 0
|
存储 Ubuntu 算法
KNIME学习记录
KNIME学习记录
803 0
|
区块链 C# 开发工具
520快给你喜欢的女生发个表白软件吧!【手把手教学】
520快给你喜欢的女生发个表白软件吧!【手把手教学】
168 0
|
存储 安全 算法
web渗透听课笔记
web渗透听课笔记
102 0
|
机器学习/深度学习 人工智能 编译器
C#学习记录
C# 是一个简单的、现代的、通用的、面向对象的编程语言,它是由微软(Microsoft)开发的。 本文章用于记录博主学习c#学习经历–学习笔记 文章目录前言一、工具和环境二、结构1.第一个程序2.读入数据三、数据类型四、运算符号五、判断语句六、C# 循环七、C# 数组(Array)总结 前言 提示:这里可以添加本文要记录的大概内容: 例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。 一、工具和环境 Microsoft Visu.
112 0
C#学习记录
|
Java 编译器
Janino学习记录
Janino学习记录
1056 0
|
关系型数据库 MySQL Apache
冬季实战营学习记录三
冬季实战营第三期主要是对mysql数据库的进一步学习,并将实验一学习到的知识做了深一步的提高,看完之后让我对mysql更加熟悉和了解,借此将操作步骤记录下来,以供日后学习参考。
135 0
冬季实战营学习记录三
|
关系型数据库 MySQL PHP
冬季实战营学习记录一
主要记录如何配置apache和php,安装mysql和phpmyadmin
128 0
冬季实战营学习记录一

热门文章

最新文章

下一篇
开通oss服务