码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • react 学习 —— 15、使用 ref 引用值


    什么时候使用 ref?

    当你希望组件“记住”某些信息,但又不想让这些信息 触发新的渲染 时,你可以使用 ref 。以下是使用的几个场景:

    • 存储 timeout ID
    • 存储和操作 DOM 元素
    • 存储不需要被用来计算 JSX 的其他对象

    怎么使用 ref?

    1、引入 ref。

    import { useRef } from 'react';
    
    • 1

    2、在你的组件内,调用 useRef Hook 并传入你想要引用的初始值作为唯一参数。

    const ref = useRef(0);
    
    • 1

    3、useRef 返回一个这样的对象:

    { 
      current: 0 // 你向 useRef 传入的值
    }
    
    • 1
    • 2
    • 3

    4、你可以用 ref.current 属性访问该 ref 的当前值。这个值是有意被设置为可变的,意味着你既可以读取它也可以写入它。

    ref.current = 3;
    
    • 1

    useRef 内部是如何运行的?

    原则上 useRef 可以在 useState 的基础上 实现。 你可以想象在 React 内部,useRef 是这样实现的:

    // React 内部
    function useRef(initialValue) {
      const [ref, unused] = useState({ current: initialValue });
      return ref;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    第一次渲染期间,useRef 返回 { current: initialValue }。 该对象由 React 存储,因此在下一次渲染期间将返回相同的对象。 请注意,在这个示例中,state 设置函数没有被用到。它是不必要的,因为 useRef 总是需要返回相同的对象!

    ref 和 state 的不同之处

    refstate
    useRef (initialValue) 返回 { current: initialValue }useRef(initialValue) 返回 { current: initialValue }
    更改时不会触发重新渲染更改时触发重新渲染
    可变 —— 你可以在渲染过程之外修改和更新 current 的值。“不可变” —— 你必须使用 setState 设置函数来修改 state 变量,从而排队重新渲染。
    在渲染期间读取(或写入) current 值页面不会改变。你可以随时读取 state。但是,每次渲染都有自己不变的 state 快照。
  • 相关阅读:
    PMP每日一练 | 考试不迷路-8.20(包含敏捷+多选)
    leetcode792:匹配子序列的单词数
    化工厂4G+蓝牙+GPS/北斗RTK人员定位系统解决方案
    【数据库】04_语法
    Xilinx FPGA 编程技巧之常用时序约束
    VisualAssist 10.9.2 Crack-2022-09-15
    在线论坛系统
    预制菜还没火,加盟商已经亏惨了
    【深度学习实验】网络优化与正则化(六):逐层归一化方法——批量归一化、层归一化、权重归一化、局部响应归一化
    自主专利和转让专利的区别
  • 原文地址:https://blog.csdn.net/wron_path/article/details/133969451
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号