一个useState学会React的主要思想
admin
2024-02-14 04:04:59
0

正经学徒,佛系记录,不搞事情

皮毛React开发者:一个useState有什么好学的,hook那么多,哪个不比useState难
自身React开发者:学的不是如何使用,而是为什么会这样

直接进入主题,对React文档案例进行分析,可以先给出点击按钮后numebr的值再看解释

import { useState } from 'react';export default function Counter() {const [number, setNumber] = useState(0);return (<>

{number}

) }

反正肯定不是3,是3还有什么好学的,理解这个问题首先要知道React的渲染机制,React为了能够更快的渲染,会挣对state的值的变化去渲染对应的组件,而不是整个页面重新渲染,并且会自动渲染全部相关嵌套的组件。

对于普通的JavaScript的变量 let number = 0; 即使是对number的值进行操作,也是不会重新渲染组件,这是因为React遵循两个基本原则

  • 内存变量不会在每次重新渲染中保存下来
  • 改变内存变量不会触发重新渲染

因此引入了useState的hook,而上面例子useState的setNumber改变会触发重新渲染。React渲染的机制是等待整个event handler完成后才会触发渲染,它有一个队列的概念,而上面的例子就是将三个 setNumber(number + 1); 加入到Queue中后在一次性渲染,要问为什么,三次计算完成后渲染一次快,还是计算三次的同时渲染三次快呢,尤其是在如果三次计算都是操作同一个值的情况,多次渲染将会是非常浪费的一个动作。

有了这些概念,再来看例子,上面例子的解释就是useState setNumber在某个event hander中并不会改变变量number的值,numebr的值只在重新渲染后生效,即,整个onClick方法执行完才会渲染number的值,因此console.log的值全都是0,而Queue里是同时执行了三次setNumber(0 + 1);,最终的结果是 1


import { useState } from 'react';export default function Counter() {const [number, setNumber] = useState(0);return (<>

{number}

) }

这一个例子的关键点在于 n => n+1,这意味着每次setNumber的 n 都是用上一次的值,结果是3

queued updatenreturns
n => n + 100 + 1 = 1
n => n + 111 + 1 = 2
n => n + 122 + 1 = 3

第一个例子中的setNumber(number + 1); 其实等同于setNumber(n => number + 1);

queued updatenreturns
n => number + 100 + 1 = 1
n => number + 110 + 1 = 1
n => number + 120 + 1 = 1

import { useState } from 'react';export default function Counter() {const [number, setNumber] = useState(0);return (<>

{number}

) }

一样的,画出表格就知道最终的值,6

queued updatenreturns
n => number + 500 + 5 = 5
n => n + 155 + 1 = 6

import { useState } from 'react';export default function Counter() {const [number, setNumber] = useState(0);return (<>

{number}

) }

结果42

queued updatenreturns
n => number + 500 + 5 = 5
n => n + 155 + 1 = 6
n => 42642 = 42

相关内容

热门资讯

安卓系统屏幕复制软件,轻松实现... 你是不是也和我一样,有时候想分享手机屏幕上的精彩瞬间,但又不知道怎么操作呢?别急,今天就来给你揭秘安...
流量充值软件安卓系统,畅享无忧... 你有没有想过,手机里的流量用完了,却不想再办新卡或者去营业厅充值?现在,有了这些神奇的流量充值软件,...
soc系统和安卓系统的区别,架... 你有没有想过,为什么你的手机里装的是安卓系统而不是soc系统呢?这两种系统各有各的特色,今天就来给你...
宝马连不上安卓系统蓝牙,宝马车... 最近有个事儿让不少宝马车主头疼不已,那就是他们的爱车竟然连不上安卓系统的蓝牙!这可真是让人摸不着头脑...
安卓系统安装gps模块,安卓系... 你有没有想过,为什么你的安卓手机在户外旅行时总是能精准地告诉你位置呢?这背后可大有学问呢!今天,就让...
安卓手机如何修复系统,安卓手机... 手机突然卡顿,系统崩溃,是不是让你头疼不已?别担心,今天就来教你几招,让你的安卓手机焕然一新!一、重...
系统更新华为安卓,引领智能科技... 亲爱的手机控们,是不是最近你的华为手机突然变得有点儿“慢吞吞”了呢?别急,这可不是你的错觉哦!华为安...
安卓系统拦截怎么解除,轻松恢复... 你是不是也遇到了安卓系统拦截的问题,心里直痒痒想要解除它呢?别急,今天就来给你详细说说怎么搞定这个小...
老式平板装安卓系统,重温经典体... 你有没有想过,那些曾经陪伴我们度过无数时光的老式平板电脑,竟然还能装上安卓系统呢?这可不是什么天方夜...
系统如何与安卓互通,技术融合与... 你有没有想过,你的手机系统竟然能和安卓系统这么默契地互通有无?这就像是一场跨越科技界的友谊赛,让我们...
安卓系统 扫码枪,安卓系统下扫... 你有没有想过,在繁忙的超市收银台,那些快速流畅的扫码操作,背后其实隐藏着一个小小的英雄——安卓系统扫...
平板插卡推荐安卓系统,安卓系统... 你有没有想过,你的平板电脑是不是也能像智能手机一样,随时随地扩充存储空间呢?没错,这就是今天我要跟你...
安卓系统固件安装失败,原因排查... 最近是不是你也遇到了安卓系统固件安装失败的问题?别急,让我来给你详细说说这个让人头疼的小麻烦,让你一...
ios系统和安卓区别,系统差异... 你有没有发现,现在手机市场上,iOS系统和安卓系统就像是一对双胞胎,长得差不多,但性格却截然不同。今...
安卓系统2.3优酷,优酷的崛起... 你有没有发现,安卓系统2.3时代的那股怀旧风?那时候,优酷可是视频界的巨头,多少人都是看着优酷长大的...
安卓导航系统密封,安卓导航系统... 你有没有发现,现在手机导航系统越来越智能了?尤其是安卓系统的导航,简直就像一个贴心的导航小助手,带你...
a版安卓11系统,a版深度解析... 你知道吗?最近手机界可是炸开了锅,各大品牌纷纷发布了搭载a版安卓11系统的手机。这可不是什么小打小闹...
安卓系统的模拟吉他,随时随地弹... 你有没有想过,在手机上也能弹奏吉他呢?没错,就是那种模拟吉他的安卓系统应用,让你随时随地都能享受音乐...
王者适配的安卓系统,深度解析适... 你有没有发现,最近玩《王者荣耀》的小伙伴们都在议论纷纷,说新出的安卓系统简直是为王者量身定做的!没错...
安卓系统自动定位关闭,隐私保护... 你有没有发现,手机里的安卓系统有时候会自动定位,这可真是让人又爱又恨啊!有时候,我们并不想让别人知道...