React中useRef hook的简单用法
更新时间:2024年01月10日 15:06:29 作者:卡卡舅舅
useRef是react的自定义hook,它用来引用一个不需要渲染的值,这篇文章介绍useRef的简单用法,感兴趣的朋友一起看看吧
介绍
useRef是react的自定义hook,它用来引用一个不需要渲染的值。这篇文章会介绍useRef的简单用法。
使用场景
1.实现节流
通过useRef实现节流功能,在限制时间内多次提交,已第一次提交为准。
useThrottle.jsx
import {useEffect, useRef, useState} from "react"; import {useEffect, useRef, useState} from "react"; export const useThrottle = (state, timeout) => { // 计时器引用 const timeoutRef = useRef(null); // 计时器执行结束 const existTimeOut = useRef(false); // 节流值 const [throttleValue, setThrottleValue] = useState(state); useEffect(()=>{ // 存在定时器 if (existTimeOut.current){ return; } existTimeOut.current = true; // 设置节流值 timeoutRef.current = setTimeout(()=>{ setThrottleValue(state); existTimeOut.current = false; }, timeout) },[state]) return throttleValue; }
app.jsx(使用样例)
import './App.css'; import {useEffect, useState} from "react"; import {useThrottle} from "./demo/UseRefDemo"; const App =()=>{ const [state, setState] = useState('') const throttleState = useThrottle(state, 10000); useEffect(()=>{ console.log('延迟执行:' + throttleState); }, [throttleState]) return <> 用戶名: <input type='text' value={state} onChange={(e)=> setState(e.target.value)}/> </> } export default App
实现效果
2.操作dom元素
export default function Form() { const inputRef = useRef(null); function handleClick() { inputRef.current.focus(); } return ( <> <input ref={inputRef} /> <button onClick={handleClick}> 聚焦输入框 </button> </> ); }
实现效果
到此这篇关于React之useRef hook的文章就介绍到这了,更多相关React useRef hook内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
- React Hooks的useState、useRef使用小结
- React Hooks中 useRef和useImperativeHandle的使用方式
- react如何利用useRef、forwardRef、useImperativeHandle获取并处理dom
- React Hooks之useRef获取元素示例详解
- react中useRef的应用使用详解
- 重新理解 React useRef原理
- 教你react中如何理解usestate、useEffect副作用、useRef标识和useContext
- React中useRef的具体使用
- React组件设计过程之仿抖音订单组件
- react如何使用useRef模仿抖音标题里面添加标签内容
相关文章
详解React中传入组件的props改变时更新组件的几种实现方法
这篇文章主要介绍了详解React中传入组件的props改变时更新组件的几种实现方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-09-09React Native中导航组件react-navigation跨tab路由处理详解
这篇文章主要给大家介绍了关于React Native中导航组件react-navigation跨tab路由处理的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。2017-10-10JavaScript的React Web库的理念剖析及基础上手指南
这篇文章主要介绍了JavaScript的React Web库的理念剖析及基础上手指南,React Web的目的即是把本地的React Native应用程序项目变为Web应用程序,需要的朋友可以参考下2016-05-05React使用xlsx和js-export-excel实现前端导出
这篇文章主要为大家详细介绍了React如何分别使用xlsx和js-export-excel实现前端导出功能,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下2024-02-02
最新评论