react之useState详解

news/2024/10/18 14:26:06/

在这里插入图片描述

1. 为什么要用useState?

  • 它是React 16.8 的新特性,我们在React里面一般都是用Class去写组件,但是有时候会发现不用它更方便,但是问题来了:不用Class的时候,数据的状态改变如何存储呢?
  • 如果你用 var,let,const 等等,你会发现:值虽然改变了,但是页面并没有重新渲染,也就是说,这些关键字定义的值并不是响应式的
  • 这个时候,就轮到 useState 上场了,它允许我们定义状态变量,并且能保证在页面上能重新渲染,数据是响应式的。

2. 基本语法

javascript">const [state, setState] = useState(initialState);
  • state => 存储的状态值
  • setState => 用来修改状态的函数
  • initialState => 首次渲染的初始值
  • 比如 useState 返回一个数组,长度为 2
javascript">// 通常使用的定义方法
const [key, setKey] = useState(0);
// 但是怕大家不好理解,所以也可以拆开,如下:
const keyArr = useState(0);
const key = keyArr[0];
const setKey = keyArr[1];

3. 实践案例

javascript">const initData = [{imgSrc: '',contentStr: '第一条评论',},{imgSrc: '',contentStr: '第二条评论',},{imgSrc: '',contentStr: '第三条评论',},
];
import { useState, useEffect } from "react";
// useEffect  用于监听数据变化,不要也可以的
const BuyComment = () => {// 带入初始值const [dataList, setDataList] = useState(initData);// 重点在这里// 往数组里添加数据const addRule = () => {let obj = {imgSrc: [],contentStr: '新的评论',};// 有深拷贝的必要,防止数据出问题const addItems = JSON.parse(JSON.stringify(dataList));addItems.push(obj);// 在这里完成值的修改setDataList(addItems);};return (<div>{dataList.map((item, i) => {return (<div className={styles.mianBorder} key={i}>{item.contentStr}</div>);})}<div className={styles.addDiv}><span className={styles.addCom} onClick={addRule}>+ 添加评论</span></div></div>)
};
// 用于监听数据变化的
useEffect(() => {console.log(dataList);
}, [dataList]);
export default BuyComment;
  • 做完以上的步骤,点击 添加评论 就会发现数据同步更改了。

4. useState 的惰性初始化

  • useState 初始值是支持惰性初始化的,所以我们可以传递一个函数给它。
  • 这个函数会在组件第一次渲染的时候执行,当然,后续的渲染就不会执行了。
  • 之所以有这个特性,是为了优化性能。因为有时候我们会遇到非常庞大的数据处理,可能还要进行深拷贝,这些操作还是很耗性能的,如果每次组件渲染的时候都会执行,那代价是很大的,但又不是必须的,所以 useState 的优点就体现出来了:只执行一次,大大的减少了操作的性能和代价。
javascript">// 假设这里数据量非常大:jsonObj,我们需要对它进行解析,计算等等操作
const jsonObj = "{...}"; // 可能是一个很大的js 对象 或者json字符串function DemoComponent() {const [data, setData] = useState(() => {console.log("执行了")// 这种深拷贝是很耗性能的,所以我们在这里先把数据处理好,并且只处理一次return JSON.parse(JSON.stringify(jsonObj ));});
}
  • 上面的代码中,打印只会执行一次。
  • 避免重复的操作,提高代码性能。

1. 希望本文能对大家有所帮助,如有错误,敬请指出

2. 原创不易,还请各位客官动动发财的小手支持一波(关注、评论、点赞、收藏)
3. 拜谢各位!后续将继续奉献优质好文
4. 如果存在疑问,可以私信我(主页有Q)

在这里插入图片描述


http://www.ppmy.cn/news/1436565.html

相关文章

代码随想录算法训练营day9 | 28. 实现 strStr()、459.重复的子字符串

28. 实现 strStr() 暴力解法&#xff1a;双重循环&#xff0c;外层是haystack字符串&#xff0c;内层是needle字符串 KMP算法&#xff1a;当haystack字符串和needle字符串已经匹配部分之后&#xff0c;如果下一个不匹配后&#xff0c;暴力法将会从头开始匹配&#xff0c;已经…

websocket消息处理失败排查(redis大key)

排查问题: websocket 断连问题 客户端连接成功后&#xff0c;会发起消息watchroom&#xff0c; 表示需要加入某个房间进行协同 技术栈&#xff1a; nodejs pm2 socket.io socket.redis.adapter.io grpc watchroom -> websocket -> grpc -> emit 调用grpc 超时失…

vue快速入门(三十五)组件通信-父传子

注释很详细&#xff0c;直接上代码 上一篇 新增内容 父组件传值子组件接收父组件传来的数据 源码 App.vue <template><div id"app"><!-- :item"item"为将item的值传递给MyTest组件 --><MyTest v-for"item in roles" :key&q…

Vue-条件渲染(初识vue渲染)

目录 一、Vue条件渲染-介绍 1.概念 2.特点 3.功能 4.好处 5.应用 二、Vue条件渲染-使用 1.初识渲染 2.条件v-if的使用 3.条件v-if-else的使用 4.条件v-else-if使用 5.template元素使用 6.条件渲染-阶段案例 7.条件v-show 三、Vue条件渲染-实例 1.权限管理系统 …

Python打怪升级(4)

在计算机领域常常有说"合法"和"非法"指的是:是否合理&#xff0c;是否有效&#xff0c;并不是指触犯了法律。 random.randint(begin,end) 详细讲解一下这个random是指模板&#xff0c;也就是别人写好的代码直接来用&#xff0c;在Python当中&#xff0c;…

ONES 功能上新|ONES Wiki 新功能一览

支持在 ONES Wiki 页面中使用分栏进行横向排版&#xff0c;丰富排版方式&#xff0c;帮助用户以更丰富的版式展示内容。 应用场景&#xff1a; 页面的布局对内容的阅读有很大的影响。当页面中有图文混排的需求时&#xff0c;可以通过分栏来组织页面结构&#xff0c;以更清晰、更…

AjaxAxios

Ajax 注&#xff1a;AJAX很少使用&#xff0c;现在都使用更简单的Axios所以只需要了解Ajax即可 概念 AJAX&#xff0c;全称“Asynchronous JavaScript and XML”&#xff08;异步JavaScript和XML&#xff09; 作用&#xff1a; 与服务器进行数据交换&#xff0c;通过Ajax可…

如何批量跟踪京东物流信息

随着电商行业的快速发展&#xff0c;快递业务日益繁忙&#xff0c;无论是商家还是消费者&#xff0c;都需要一种高效、便捷的快递查询工具。快递批量查询高手软件应运而生&#xff0c;以其强大的功能和便捷的操作体验&#xff0c;赢得了广大电商、微商精英们的青睐。 快递批量…