当前位置: 首页 > news >正文

响应式网站开发方案网页聊天工具

响应式网站开发方案,网页聊天工具,前海网站建设,辽宁工程信息看一下官网定义 useRef是一个React Hook,它能帮助引用一个不需要渲染的值 这句话透露出一个信息,不需要渲染的值可以用useRef引用,那需要渲染的值用什么引用呢?当然是useState了,需要渲染的值指的就是状态嘛&#xff0…

看一下官网定义

useRef是一个React Hook,它能帮助引用一个不需要渲染的值

这句话透露出一个信息,不需要渲染的值可以用useRef引用,那需要渲染的值用什么引用呢?当然是useState了,需要渲染的值指的就是状态嘛!
看下官网的例子,可以方便你理解:

import React,{useState, useEffect, useRef} from 'react';const DemoRef = () => {const [count, setCount] = useState(0)let timer = null;useEffect(() => {timer = setInterval(()=>{//这里注意一下不要直接传递下一个状态setCount(count+1),这样做的话,你会发现一直是0-->1来回闪烁,//这是因为set函数不会更新已经运行在代码中的count状态变量,而传递一个更新函数setCount(count=>count+1)//则会获取待定状态,并从中计算下一个状态setCount(count=>count+1)},1000)}, [])const onClick = () => {console.log(timer,'timer')clearInterval(timer)}return (<div><p>count:{count}</p><button onClick={onClick}>点击清除</button></div>)
}
export default DemoRef;

在这里插入图片描述
结果如图,会发现timer一直是null,这是因为每次setState之后,组件都会重新运行一遍,然后let timer = null;每次都每次都会重新赋值为null。这样很明显,内存泄漏。
这时就可以使用useRef来处理这个了

import React,{useState, useEffect, useRef} from 'react';const DemoRef = () => {const [count, setCount] = useState(0)let timer = useRef();useEffect(() => {timer.current = setInterval(()=>{//这里注意一下不要直接传递下一个状态setCount(count+1),这样做的话,你会发现一直是0-->1来回闪烁,//这是因为set函数不会更新已经运行在代码中的count状态变量,而传递一个更新函数setCount(count=>count+1)//则会获取待定状态,并从中计算下一个状态setCount(count=>count+1)},1000)}, [])const onClick = () => {console.log(timer,'timer')clearInterval(timer.current)}return (<div><p>count:{count}</p><button onClick={onClick}>点击清除</button></div>)
}
export default DemoRef;

在这里插入图片描述
通过这个例子就能看出useRef的一个功能,那就是引用一个值,使其跳过组件的重新渲染过程。
useRef还有一个功能,那就是操作Dom。看下面这个例子

import React,{useRef} from 'react';const RefDom = () => {const inputRef = useRef();const onClick = () => {console.log(inputRef.current)inputRef.current.value = 'lili'}return (<div><input type="text" ref={inputRef}/><button onClick={onClick}>点击自动填充</button></div>)
}
export default RefDom;

在这里插入图片描述
可以看到,点击按钮之后,会给input填充lili

使用 ref 可以确保:

  • 可以在重新渲染之间 存储信息(普通对象存储的值每次渲染都会重置)。
  • 改变它 不会触发重新渲染(状态变量会触发重新渲染)。
  • 对于组件的每个副本而言,这些信息都是本地的(外部变量则是共享的)。

改变 ref 不会触发重新渲染,所以 ref 不适合用于存储期望显示在屏幕上的信息。如有需要,使用 state 代替。

http://www.yayakq.cn/news/102462/

相关文章:

  • 游戏类网站欣赏企业网站的网址通常包含
  • 邯郸网站建设xy0310媒体发稿平台
  • 做网站横幅的软件临沂市建设局兰山区网站
  • 关于地产设计网站网络营销方法和手段
  • 国际网站群建设方案wordpress主题lovephoto
  • 郑州网站制作的公司WordPress页面批量生成
  • 高端做网站wordpress手动数据库优化
  • 嘉鱼网站建设公司混沌鸿蒙网站建设
  • 襄阳网站定制抖音代运营公司介绍
  • 河北康城建设集团网站北京网站建设 标准型 新翼
  • 咖啡网站设计模板渭南免费做网站
  • 科技企业网站wordpress 标题图片
  • 怎样做国外网站推广厦门网站注册与网页设计公司
  • 门户网站兴化建设局无锡网站程序
  • 个人网站备案 内容一个域名下多个网站
  • 如何快速进行网站开发wordpress建站系统
  • 给企业开发网站建设网站的费用入什么科目
  • 沈阳市住房和城乡建设局网站首页旅游网站规划建设
  • 网站设计就业学做网站论坛会员怎么样
  • 网站设计重要性免费行情软件下载入口
  • 一个网站主页开发费用申请域名的方法和流程
  • 温州网站建设温州网站制作wordpress 卡密销售
  • 西安做推广网站设计seo的主要内容
  • 网站建设作用图片雄安移动网上营业厅
  • 网站建设资源kindle上国外网站 dns
  • html静态网站开发实验最主流的网页制作软件
  • 在哪个网站可以自助建站下面哪些属于免费的网络营销方式
  • 深圳西乡网站制作建网站收费吗
  • pc网站建设怎么做大连网络营销咨询服务
  • 做网站建设需要做哪些工作上海市网站制作