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

做伞的外国网站电脑培训学校

做伞的外国网站,电脑培训学校,wordpress主题 微软,网站充值系统怎么做目录 1,介绍2,和 React.createRef() 的区别3,计时器的问题 目前来说,因为函数组件每次触发更新时,都会重新运行。无法像类组件一样让一些内容保持不变。 所以才出现了各种 HOOK 函数:useState,u…

目录

  • 1,介绍
  • 2,和 React.createRef() 的区别
  • 3,计时器的问题

目前来说,因为函数组件每次触发更新时,都会重新运行。无法像类组件一样让一些内容保持不变。
所以才出现了各种 HOOK 函数:useStateuseCallbackuseMemo 等来辅助实现和类组件相似的功能。

useRef 也是这样的目的。

1,介绍

在之前的文章中介绍了 ref,用于获取组件或真实DOM元素的引用。

useRef 作用相同,不过可以在函数组件中使用。同时它会返回对象的固定引用。

换句话说,当函数组件重新运行时,useRef() 前后2次返回的对象引用地址相同。
一个节点(React元素)对应一个唯一的对象。

React.createRef() 使用举例:

import React, { useState } from "react";export default function App() {const refInput = React.createRef();return (<><input ref={refInput}></input><buttononClick={() => {console.log(refInput.current.value);}}>获取 inputRef</button></>);
}

换成 useRef仅需要替换一行代码:

const refInput = React.createRef();
// 替换为
const refInput = useRef();

2,和 React.createRef() 的区别

上面的代码中,看起来只是一行代码的区别,但本质上处理逻辑不同。

  • React.createRef(),如果 ref 的值发生变动(函数组件重新渲染),则将旧值设为 null
  • useRef(),函数组件重新渲染多次时,所有返回的对象的引用地址相同。

验证下:
简单修改下,将每次更新后的新 ref 放到 window 对象中对比下:

import React, { useRef, useState } from "react";window.arr = [];
export default function App() {const refInput = React.createRef();window.arr.push(refInput);const [n, setN] = useState(); // 只是为了重新渲染组件。return (<><inputref={refInput}type="text"value={n}onChange={(e) => {setN(e.target.value);}}/></>);
}

多次改变 input.value 时,检查 window.arr

在这里插入图片描述

替换为 const refInput = useRef();

在这里插入图片描述

3,计时器的问题

在之前介绍 useEffect 时,提到了下面的写法是有问题的。

因为 useEffect 只会执行一次,所以在计时器中通过闭包获取的状态变量 n 永远都是10,

export default function App() {const [n, setN] = useState(10);useEffect(() => {const timer = setInterval(() => {setN(n - 1);}, 1000);return () => {clearInterval(timer);};}, []);return <div>{n}</div>;
}

该问题,通过将依赖项 n 传入即可。但会引起另一个问题:
每次函数重新运行,都会再次执行 useEffect,开启计时器又销毁计时器,开销很大。

export default function App() {const [n, setN] = useState(10);useEffect(() => {const timer = setInterval(() => {setN(n - 1);}, 1000);return () => {clearInterval(timer);};}, [n]);return <div>{n}</div>;
}

所以,可通过 useRef 来将函数重新运行后的新值传递给计时器,同时 useEffect 也只会运行一次,开启一次计时器!

注意,useRef() 返回的虽然是同一个对象,但 setN 修改的是它的 current 属性。所以计时器每次获取的都是新值。

export default function App() {const [n, setN] = useState(10);const refN = useRef(n);useEffect(() => {const timer = setInterval(() => {setN(--refN.current);}, 1000);return () => {clearInterval(timer);};}, []);return <div>{n}</div>;
}

以上。

http://www.ds6.com.cn/news/54324.html

相关文章:

  • 怎么把网站做的小程序爱站数据官网
  • 自学网官方网站入口360建网站
  • 国外做储物的网站百度权重提升
  • 网站商城开发青岛百度seo代理
  • 淄博头条新闻今天公司seo是什么意思
  • 泊头网站建设的有哪些台湾新闻最新消息今天
  • 华为网站哪个公司做的搭建网站的五大步骤
  • 江苏苏州网站建设搜索关键词怎么让排名靠前
  • 沧州建设网站公司个人推广平台
  • 品牌官方网站建设欧美seo查询
  • 网站详情页用什么软件做sem代运营推广公司
  • 数据库对网站开发的作用手机免费建站系统
  • 做网站开始要注意什么海底捞口碑营销
  • 销售型企业网站友情链接查询结果
  • 2021年建站赚钱足球比赛统计数据
  • 小加工厂做网站销售渠道及方式
  • 6东莞做网站爱用建站
  • 新手如何入侵一个网站下载百度免费
  • 买服务器做网站流量大的推广平台有哪些
  • 网站备案号添加超链接网上销售方法
  • 做网站如何自己寻找客户北京网站优化企业
  • 网站开发与优化课程总结宁波企业seo外包
  • 公司做的网站账务处理百度一下百度网页版
  • wordpress java版苏州网站优化公司
  • 视频上传网站建设打开百度首页
  • 淄博张店网站建设提高工作效率英语
  • 用html5做的网站素材友情链接是外链吗
  • 如何建设和优化网站宁波优化seo是什么
  • 怎么在抖音上卖东西seo模拟点击软件源码
  • 口碑好的邯郸网站建设武汉seo工厂