当前位置: 首页 > 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.ds6.com.cn/news/85138.html

相关文章:

  • 技术培训网站免费的网页制作软件
  • 富顺做网站天天seo站长工具
  • 同步到wordpress谷歌seo工具
  • 域名和网站手机百度如何发布作品
  • 哈尔滨网站建设推广公司怎么制作一个网站5个网页
  • 做网站标题头像外包网络推广公司怎么选
  • <网站建设与运营》南通seo
  • 做网站做图电脑需要什么配置佛山抖音seo
  • 长安网站建设4a广告公司
  • 做新闻门户网站需要什么泉州百度竞价推广
  • 网站开发那个语言好seo薪酬如何
  • 模板建站3000是不是贵了中国500强最新排名
  • 网站设计的研究方案网店
  • 好的建筑设计网站推荐网站域名费一年多少钱
  • 电脑做ppt如何插入网站西安seo哪家好
  • 长沙哪家公司做网站百度推广关键词技巧定价
  • 南充做网站公司大数据营销精准营销
  • 江苏网站建设谷歌搜索引擎网页版入口
  • 大连企业建站百度的官方网站
  • 长沙制作手机网站网站设计与建设
  • 校园网站建设规划书seo外链发布平台有哪些
  • 网站做线上销售windows优化大师有用吗
  • wordpress如何去除分类怎么seo网站排名
  • 佛山专业的网页制作谷歌seo招聘
  • 用动物做网站名网站关键词优化公司
  • 政府门户网站建设方案深圳今日头条新闻
  • 东莞网站建设营销哪家好网页设计
  • 延安免费做网站公司官方百度平台
  • 旅游网站设计图公司网站排名
  • 广西网站建设公司招聘最好的营销策划公司