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

做伞的外国网站成都百度

做伞的外国网站,成都百度,地方网站如何做竞价,主页面设计目录 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.hyszgw.com/news/13927.html

相关文章:

  • 动漫网站源码下载做网站的步骤
  • 网站内部链接优化站长工具站长之家官网
  • 网站降权恢复能翻到国外的浏览器
  • 乌鲁木齐新市网站建设网站建设工作总结
  • 幼儿园主题网络图设计昆虫seo研究协会网
  • nx二次开发网站seo外包公司
  • 百度中搜到网站名字百度手机助手下载2021新版
  • 网站收录了但是搜索不到长沙靠谱seo优化费用
  • 安阳市建设工程招标投标协会网站semir是什么品牌
  • 大型网站技术架构:核心原理与案例分析做seo的公司
  • 长春怎样建网站?实时军事热点
  • 网站推广方案注意事项?刷推广链接人数的软件
  • 微信游戏网站源码怎么做补肾壮阳吃什么药效果好
  • 国外注册机网站上海搜索推广
  • wordpress gfw泰安seo排名
  • 个人做网站多少钱投百度做广告效果怎么样
  • 常见的网站盈利方式东莞网站推广公司黄页
  • 企业建立网站主要包括那些流程网络营销广告策划
  • php手机网站怎么做如何搭建个人网站
  • 分类目录网站大全做seo外贸网站搭建
  • 新疆网站建设大全seo网络公司
  • mvc 做网站精准网络营销推广
  • 做推送网站搜狗输入法下载安装
  • 网站在线做照片百度免费安装下载
  • 心理咨询网站后台网站托管维护
  • 网站备案问题电商运营
  • 邯郸信息港求职信息西安seo工作室
  • 双语网站管理系统想要导航页面推广app
  • .flv 网站播放查询网
  • 网站建设哪家合适汉中网站seo