react hooks(useState、useEffect、useRef详解)
好巧不巧,工作了一年跳槽了,之前用的vue,现在用的react~ 嗯!工作使人进步!现在开始学react吧!
切入正题~
react hooks是React16.8.0之后出现的,
类组件存在的问题:
- this指向问题
- 生命周期繁琐
- 创建类的实例开销较大
而函数组件函数组件没有this,没有生命周期,没有状态state,函数的执行开销比创建类实例的开销要小。
因此,为了提高性能,尽量使用函数组件。
然而函数组件有个最大的问题就是没有状态state,所以react官方出了个hooks来解决这个问题。
项目中最常用的几个hook:
useState
import React, { useState } from 'react';// 引入state hook
export default function App() {
console.log("App render")
const [n, setN] = useState(0); //使用一个状态,该状态的默认值是0
return <div>
<button onClick={() => {
setN(n - 1);
setN(n - 2);// 传入值,只会保留最后一次setN的执行
// setN(prevN => prevN - 1);
// setN(prevN => prevN - 1);//传入函数,在事件完成之后统一执行
}}>-</button>
<span>{n}</span>
</div>
}
- 类组件:使用forceUpdate函数
- 函数组件:使用一个空对象的useState
类组件
import React, { Component } from 'react'
export default class App extends Component {
render() {
return (
<div>
<button onClick={()=>{
//不会运行shouldComponentUpdate
this.forceUpdate();//强制重新渲染
}}>强制刷新</button>
</div>
)
}
}
函数组件
import React, { useState } from 'react'
export default function App() {
const [, forceUpdate] = useState({});
return <div>
<p >
<button onClick={() => {
forceUpdate({});
}}>强制刷新</button>
</p>
</div>
}
useEffect
它能在函数组件中执行副作用,并且它与 class 中的生命周期函数极为类似。
- 副作用函数的运行时间点,是在页面完成真实的UI渲染之后。因此它的执行是异步的,并且不会阻塞浏览器
- 每个函数组件中,可以多次使用useEffect,但不要放入判断或循环等代码块中。
- useEffect中的副作用函数,可以有返回值,返回值必须是一个函数,该函数叫做清理函数
- useEffect函数,可以传递第二个参数
import React, { useState, useEffect } from 'react'
function Test() {
useEffect(() => {
console.log("副作用函数,仅挂载时运行一次")
return () => {
console.log("清理函数,仅卸载时运行一次")
};
}, []); //使用空数组作为依赖项,则副作用函数仅在挂载的时候运行
console.log("渲染组件");
const [, forceUpdate] = useState({})
return <h1>Test组件 <button onClick={() => {
forceUpdate({})
}}>刷新组件</button></h1>
}
export default function App() {
const [visible, setVisible] = useState(true)
return (
<div>
{
visible && <Test />
}
<button onClick={() => {
setVisible(!visible);
}}>显示/隐藏</button>
</div>
)
}
useRef(value)返回一个对象:{current: value}
- 在每次渲染时返回同一个 ref 对象
- 变更 .current 属性不会引发组件重新渲染
import React, { useRef } from 'react'
export default function App() {
console.log('app render')
const nRef = useRef(10); // {current:10}
return (
<div>
<h1>{nRef.current}不会变</h1>
<button onClick={() => {nRef.current--;console.log(nRef.current, 'nRef.current变化')}}>减少</button>
</div>
)
}
react hooks(useState、useEffect、useRef详解)的更多相关文章
- React源码 commit阶段详解
转: React源码 commit阶段详解 点击进入React源码调试仓库. 当render阶段完成后,意味着在内存中构建的workInProgress树所有更新工作已经完成,这包括树中fiber节点 ...
- react第五单元(事件系统-原生事件-react中的合成事件-详解事件的冒泡和捕获机制)
第五单元(事件系统-原生事件-react中的合成事件-详解事件的冒泡和捕获机制) 课程目标 深入理解和掌握事件的冒泡及捕获机制 理解react中的合成事件的本质 在react组件中合理的使用原生事件 ...
- React Hooks: useState All In One
React Hooks: useState All In One useState import React, { useState } from 'react'; function Example( ...
- React Hooks --- useState 和 useEffect
首先要说的一点是React Hooks 都是函数,使用React Hooks,就是调用函数,只不过不同的Hooks(函数)有不同的功能而已.其次,React Hooks只能在函数组件中使用,函数组件也 ...
- 翻译 | 玩转 React 表单 —— 受控组件详解
原文地址:React.js Forms: Controlled Components 原文作者:Loren Stewart 译者:小 B0Y 校对者:珂珂君 本文涵盖以下受控组件: 文本输入框 数字输 ...
- React生命周期执行顺序详解
文章内容转载于https://www.cnblogs.com/faith3/p/9216165.html 一.组件生命周期的执行次数是什么样子的??? 只执行一次: constructor.compo ...
- 王家林系列之scala--第69讲:Scala并发编程react、loop代码实战详解
刚才看了一下,群里王家林老师又更新课程了,真为王老师的勤奋感到佩服,于是迫不及待的下载下来观看学习.本期讲的是关于scala并发编程的react.loop代码实战. 信息来源于 DT大数据梦工厂微信公 ...
- React Hooks useState为什么顺序很重要
一个Function Component的state状态整体是作为memoizedState存在FIber中的. function执行时,首先取memoizedState第一个base state,作 ...
- React生命周期及事件详解
引用原文:http://blog.csdn.net/limm33/article/details/50942808 一.组件的详细说明和生命周期ComponentSpecs and Lifecycle ...
- 深入React技术栈之setState详解
抛出问题 class Example extends Component { contructor () { super() this.state = { value: 0, index: 0 } } ...
随机推荐
- 每一行输出5个字符之后换行 js
方法1 使用正则 (如果是汉字,此正则,每五个字换行,如果是英文字符,每十个英文,换行) let arrX ="这是个测试字符串,这是个测试字符串" arrX = arrX.re ...
- [资料] 设计原理图资料保存:FMC210-1路1Gsps AD、1路2.5Gsps DA的FMC子卡解决方案
FMC210-1路1Gsps AD.1路2.5Gsps DA的FMC子卡 一.板卡概述 FMC-1AD2DA是北京太速科技自主研发的一款1路1G AD采集.1路2.5G DA回放的FMC子卡.板卡采用 ...
- 肖sir__面试第十天课程__模拟面试讲解
一.面对面模拟面试1.打印好简历2.带好手机,录制自己回答的问题,总结,反思(内部),关闭手机和闹钟(外部)3.有笔试题,可以拍照发群里4.可以携带耳塞(适合女生)5.语速流程6.礼貌用语(面试官好, ...
- k8s master高可用
每台master都要部署haproxy,keepalived keepalived 配置文件:! Configuration File for keepalivedglobal_defs { rout ...
- Visaul Studio 快捷方式
1.删除光标所在行:Ctrl + shift + L : 2.剪切光标所在行:Ctrl + X : 3.在光标上方插入一行:Ctrl + Enter : 4.注释代码:Ctrl + K --> ...
- linux挂载文件服务器
smbclient -L //192.168.1.1/ -U administrator //直接挂载 使用下面这条命令就行 sudo mount -t cifs -o username=文件服务器账 ...
- 【shell脚本实战】脚本#35 分析每个用户使用的磁盘空间大小
#!/bin/bash #设置 一个变量代表临界值,看看是否能超过这个值,单位是MB MAXDISKUSAGE=20000 #cut -d: -f1,3 /etc/passwd | awk -F: ' ...
- npm config get prefer-offline
npm config get prefer-offline
- Web实时通信之SignalR
前言 对于B/S模式的项目,基础的场景都是客户端发起请求,服务端返回响应结果就结束了一次连接:但在很多实际应用场景中,这种简单的请求和响应模式就显得很吃力,比如消息通知.监控看板信息自动刷新等实时通信 ...
- arm开发环境搭建
1.smaba 在Linux PC安装smaba sudo apt-get install samba编辑/etc/samba/smb.conf配置:[yz]path = /home/yzv ...