学习React-19-useDebugValue

useDebugValue 概述

useDebugValue 是 React Hooks 提供的一个工具函数,用于在 React 开发者工具中为自定义 Hook 添加调试标签。其核心目的是提升自定义 Hook 的可读性和调试体验,尤其在复杂逻辑中能直观展示内部状态或计算值。

基本语法

javascript 复制代码
useDebugValue(value, formatFn);
  • value: 需要展示的调试值(任何类型)。
  • formatFn (可选): 对 value 进行格式化转换的函数,仅在开发者工具中检查时调用,避免生产环境性能损耗。

使用场景

直接显示简单值
javascript 复制代码
function useCustomHook() {
  const [state] = useState(42);
  useDebugValue(state); // 开发者工具中显示: 42
  return state;
}
格式化复杂值

通过第二个参数延迟格式化计算,避免生产环境不必要的开销:

javascript 复制代码
function useTimestampConverter(timestamp) {
  const date = new Date(timestamp);
  useDebugValue(date, (d) => `格式化的值: ${d.toLocaleString()}`);
  return date;
}

小栗子

复制代码
需求: 实现自定义Cookie的更改和删除。
ts 复制代码
import React, {useDebugValue, useState} from "react";

const useCookie = (name: string, initialValue: string) => {

const getCookie = () => {
    const match = document.cookie.match(new RegExp(`(^| )${name}=([^;]*)(;|$)`)) 
  return match ? match[2] : initialValue
}

const [cookie, setCookie] = useState(getCookie())

// 更新Cookie
const updateCookie = (newValue: string) => {
    document.cookie = `${name}=${newValue}`
    setCookie(newValue)
}

// 删除Cookie  
const deleteCookie = () => {
    // 通过设置过期时间为过去的时间来删除cookie
    document.cookie = `${name}=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;`
    setCookie("")
}

useDebugValue(cookie, () => {
    return `格式化显示Cookie: ${cookie}`
})
return [cookie, updateCookie, deleteCookie, getCookie] as const

    
}

export const TestDebugValue = () => { 
		// useCookie(名称, 默认值)
    const [cookie, updateCookie, deleteCookie] = useCookie("name", "黑子")
    return (

        <div>
            <h3>Cookie: {cookie}</h3>
            <button onClick={() => updateCookie('ikun')}>更改Cookie值</button>
            <button onClick={deleteCookie}>删除获取的Cookie值</button>
        </div>
    )
}

export default TestDebugValue;

效果展示:

注意事项

  • 仅用于自定义 Hook:在普通组件中使用无效。
  • 生产环境无影响:调试值仅在开发模式下显示,不会增加生产包体积或性能负担。
  • 避免滥用:仅对需要高优先级调试信息的 Hook 使用,过度使用可能干扰开发者工具的可读性。

小工具

React Developer Tools

React Developer Tools 是官方提供的浏览器扩展,用于调试 React 应用。支持 Chrome、Firefox 及 Edge 等浏览器,可检查组件层级、状态、props 及性能分析。

安装方法
  1. Chrome/Firefox/Edge 扩展商店
  2. 打开浏览器扩展商店(如 Chrome Web Store)。Chrome 需要开魔法
  3. 搜索 "React Developer Tools"。
  4. 点击"添加至浏览器"完成安装。
相关推荐
烟袅20 小时前
JavaScript 是如何“假装”多线程的?深入理解单线程与 Event Loop
前端·javascript
on_pluto_20 小时前
【推荐系统14】数据分析:以阿里天池新闻推荐为例学习
人工智能·学习·数据挖掘·数据分析·推荐算法
数学难20 小时前
数据分析学习路线
学习·数据挖掘·数据分析
烟袅20 小时前
一文看懂 Promise:异步任务的“执行流程控制器”
前端·javascript
冴羽20 小时前
从 useState 到 URLState:为什么大佬们都在删状态管理代码?
前端·javascript·vue.js
郑州光合科技余经理20 小时前
乡镇外卖跑腿小程序开发实战:基于PHP的乡镇同城O2O
java·开发语言·javascript·spring cloud·uni-app·php·objective-c
搞机械的假程序猿21 小时前
普中51单片机学习笔记-前言
笔记·学习·51单片机
Jonathan Star21 小时前
在 React 生态中,有多个成熟的 虚拟列表 npm 库
react.js·arcgis·npm
不爱吃糖的程序媛21 小时前
Electron 桌面应用开发入门指南:从零开始打造 Hello World
前端·javascript·electron
Dontla21 小时前
前端状态管理,为什么要状态管理?(React状态管理、zustand)
前端·react.js·前端框架