React状态管理-对state进行保留和重置

相同位置的相同组件会使得 state 被保留下来


当你勾选或清空复选框的时候,计数器 state 并没有被重置。不管 isFancytrue 还是 false,根组件 App 返回的 div 的第一个子组件都是 <Counter />

你可能以为当你勾选复选框的时候 state 会被重置,但它并没有!这是因为 两个 标签被渲染在了相同的位置。 React 不知道你的函数里是如何进行条件判断的,它只会"看到"你返回的树。在这两种情况下,App 组件都会返回一个包裹着 作为第一个子组件的 div。这就是 React 认为它们是 同一个 的原因。

你可以认为它们有相同的"地址":根组件的第一个子组件的第一个子组件。不管你的逻辑是怎么组织的,这就是 React 在前后两次渲染之间将它们进行匹配的方式。

相同位置的不同组件会使 state 重置


在相同位置重置 state

相关推荐
A923A7 分钟前
【从零开始学 React | 第四章】useEffect和自定义Hook
前端·react.js·fetch·useeffect
前端摸鱼匠17 分钟前
Vue 3 的defineProps编译器宏:详解<script setup>中defineProps的使用
前端·javascript·vue.js·前端框架·ecmascript
天外天-亮18 分钟前
Vue2.0 + jsmind:开发思维导图
javascript·vue.js·jsmind
LIO21 分钟前
React 零基础入门,一篇搞懂核心用法(适合新手)
前端·react.js
蜡台1 小时前
JavaScript async和awiat 使用
开发语言·前端·javascript·async·await
tzy2331 小时前
AI 对话的流式输出详解——不止于SSE
javascript·ai·llm·sse·readablestream
挖稀泥的工人1 小时前
能够插入 DOM 的输入框
前端·javascript·vue.js
没有故事、有酒1 小时前
Vue2中el-table修改表头高度和行高
javascript·vue.js·elementui
把csdn当日记本的菜鸡1 小时前
Vue3 响应式 API 简单学习
javascript·vue.js·学习
小李子呢02111 小时前
前端八股5---组件通信
前端·javascript·vue.js