JavaScript中的useRef 和 useState介绍
1、useState hook
useState
是一个内置的 React hook
,它允许您将信息作为状态存储在变量中。它允许您将 React
状态添加到功能组件。在下面的示例中,useState()
声明状态变量,而值存储在计数变量中。setCount
是用于更新此值的函数。
//从 react 导入 useState import React, { useState } from 'react'; function Count() { // 声明一个名为 count 的新状态变量 const [count, setCount] = useState(0);
2、useRef hook
useRef hook
是一个内置的 React hook
,它将一个参数或参数作为其初始值,并返回一个引用或持久化的可变值。此引用,或简称 ref
,包含可以使用当前属性检索的值。
我们还可以将用户输入存储在 refs 中并显示收集到的数据,如下所示:
//导入 useRef hook import React, { useRef } from "react" export default function App() { //创建一个变量来存储引用 const nameRef = useRef(); function handleSubmit(e) { //防止页面在提交时重新加载 e.preventDefault() //输出 name console.log(nameRef.current.value) } return ( <div className="container"> <form onSubmit={handleSubmit}> <div className="input_group"> <label>Name</label> <input type="text" ref={nameRef}/> </div> <input type="submit"/> </form> </div> ) }
3、useRef 与 useState
- 与状态不同,存储在引用或引用中的数据或值保持不变,即使在组件重新渲染之后也是如此。因此,引用不会影响组件渲染,但状态会影响。
useState
返回 2 个属性或一个数组。一个是值或状态,另一个是更新状态的函数。相比之下,useRef
只返回一个值,即实际存储的数据。- 当参考值发生变化时,无需刷新或重新渲染即可更新。但是在
useState
中,组件必须再次渲染以更新状态或其值。
4、何时使用 Refs 和 States
refs
在获取用户输入、DOM
元素属性和存储不断更新的值时很有用。 但是,如果您要存储组件相关信息或在组件中使用方法,states
则是最佳选择。
所以总而言之,这两种 hook
各有优缺点,会根据情况和用途来使用。
到此这篇关于 JavaScript
中的useRef
和 useState
介绍的文章就介绍到这了,更多相关 JavaScript
中的useRef
和 useState
内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
React Native基础入门之初步使用Flexbox布局
React中引入了flexbox概念,flexbox是属于web前端领域CSS的一种布局方案,下面这篇文章主要给大家介绍了关于React Native基础入门之初步使用Flexbox布局的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下2018-07-07一篇文章介绍redux、react-redux、redux-saga总结
这篇文章主要介绍了一篇文章介绍redux、react-redux、redux-saga总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2019-05-05
最新评论