?React Hooks 的閉包陷阱問題

這是主包在面試中遇到的一道題目,面試官的問題是:"這個頁面初次展示出來時Count和step的值是什么,我點擊按鈕count和step的值有什么變化?

這個題目主包回答的不好,所以想做一個總結。

題目

import React, { useState, useEffect } from 'react';function useInterval(callback, delay) {useEffect(() => {const id = setInterval(() => {console.log('[Timer Tick]的 count:', callback._countSnapshot);callback();}, delay);return () => clearInterval(id);}, [delay]);
}export default function BuggyCounter() {const [count, setCount] = useState(0);const [step, setStep] = useState(1);function tick() {setCount(count + step);}// 注冊定時器useInterval(tick, 1000);return (<div><h1>Count: {count}</h1><div><button onClick={() => setStep((s) => s + 1)}>Increase Step</button><span> 當前 step: {step} </span></div></div>);
}

分析?

首先,先好好閱讀代碼,主包現在發現主包在面試中有一個致命的問題就是,很多問題還沒明白面試官的意思,或者像代碼,還沒明白代碼的意思就已經開始胡說了。往往是越說越遠,其實結束面試之后主包再次閱讀這段答的稀爛的代碼的時候,發現很能看懂。所以不要著急,先明白面試官 的意思在作答。

好的,我們來解析代碼,這個函數什么作用呢。首先我們要明白這是自定義了一個Hook。傳入兩個參數:callback是一個函數,delay動態參數用于設置定時器的。useEffect的部分就是以delay作為依賴,并在return這個處理副作用的部分進行一個清空計時器。它實現的功能是:安全的實行定時器,在組件卸載或?delay?變化時,自動清除之前的定時器。

接下來看tick函數,就是去改變count的狀態為count+step;

調用定時器,每1000ms執行一次。
?

好的,現在解析完畢,開始作答。在剛進入頁面的時候,我們應該看的到一瞬間的count:0,step:1;但是1000ms后count變為1了。之后如果我們不點擊按鈕就會保持這樣一直不變。

問題

當我們點擊按鈕之后,只有step的值會增加,而count的值不會增加。

現在我們來解釋為什么會這樣:

首先,進入頁面之后,會因為初態的問題,count和step會保持初態0和1;但是1000ms后,定時器起效了此時tick函數起作用,但是它捕獲的是初態的count和step,在定時器循環的過程中,由于閉包問題,count和step一直沒有得到更新,所以count不會改變。

控制臺呢

你會發現callback函數中根本就沒有?_countSnapshot這個屬性,所以他是迷惑我們的,一直是undefined。

怎么更改

方案1

setCount((count)=> count + step);

這樣就好,我們在每一次更新時,通過回調獲取最新的count值。

方案2:將?tick?加入?useInterval?的依賴

修改?useInterval,使其響應?callback?的變化:

function useInterval(callback, delay) {useEffect(() => {const id = setInterval(callback, delay); // 直接使用最新的 callbackreturn () => clearInterval(id);}, [delay, callback]); // 依賴 callback
}

方案3:useRef
?

function useInterval(callback, delay) {const savedCallback = useRef();// 保存最新的回調useEffect(() => {savedCallback.current = callback;}, [callback]);// 設置定時器useEffect(() => {function tick() {savedCallback.current(); // 調用最新的回調}if (delay !== null) {const id = setInterval(tick, delay);return () => clearInterval(id);}}, [delay]);
}

“人間自有真情在 ,宜將寸心報春暉。”

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/909044.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/909044.shtml
英文地址,請注明出處:http://en.pswp.cn/news/909044.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

新基建浪潮下:中國新能源汽車充電樁智慧化建設與管理實踐

在新基建戰略的強力推動下&#xff0c;中國新能源汽車充電樁建設正迎來智慧化升級的重要機遇期。作為連接能源革命與交通革命的關鍵節點&#xff0c;充電基礎設施的智能化轉型不僅關乎新能源汽車產業的可持續發展&#xff0c;更是構建新型電力系統的重要支撐。當前&#xff0c;…

如何在多任務環境中設定清晰的項目優先級?

在多任務環境中設定清晰的項目優先級需要明確項目戰略價值、緊急性、資源利用效率、風險管理。其中&#xff0c;明確項目戰略價值尤為重要&#xff0c;它決定了項目對組織整體戰略目標實現的貢獻程度。例如&#xff0c;戰略價值高的項目&#xff0c;即使不緊急&#xff0c;也應…

【Django】性能優化-普通版

性能優化&#xff1a; 思路 通常無論是什么編程語言或者是什么框架&#xff0c;瓶頸通常都是數據庫相關的操作&#xff1b; 大部分的查詢慢的問題接口都是頻繁查庫、全盤掃描、多層for循環嵌套、高頻查redis、序列化時多級外鍵&#xff1b; 多用O(1)查找復雜度的數據 合理使…

數據治理域——離線數據開發

摘要 文本主要介紹了離線數據開發相關內容,包括業務與流程、阿里MaxCompute系統設計以及阿里調度系統設計。離線數據開發是大數據開發核心組成部分,用于處理批量數據,支持企業多種需求,其流程涵蓋需求調研、數據源接入等環節。阿里MaxCompute系統架構與特點被闡述,調度系…

python-docx 庫教程

Python-docx 庫介紹 官網文檔 python-docx 是一個用于創建和修改 Microsoft Word (.docx) 文件的 Python 庫。它允許你通過編程方式生成格式化的文檔&#xff0c;添加文本、段落、表格、圖片等元素&#xff0c;而無需依賴 Microsoft Word 應用程序。 主要功能 創建新的 Word…

Ansible小試牛刀

注意事項 除了安裝的zabbix相關組件 使用此腳本安裝的所有軟件版本均為系統默認版本 安裝軟件 zabbix相關組件&#xff0c;包括server&#xff0c;agent等 MySQL Redis NGINX openjdk maven nodejs keepalived iptables ipvsadm 使用劇本 --- - hosts: allname…

MCP使用

什么是MCP Model Context Protocol (MCP) 是由 Anthropic 公司于 2024 年 11 月推出的一種開放協議標準&#xff0c;目的在于標準化LLM 與外部數據源、工具及服務之間的交互方式。MCP 被廣泛類比為“AI 領域的 USB-C 接口” MCP與Function Calling的區別 MCP 的核心概念 1.…

邊緣計算一:現代前端架構演進圖譜 —— 從 SPA 到邊緣渲染

過去十年&#xff0c;前端項目架構經歷了從簡單 HTML 文件到復雜框架的飛躍&#xff0c;但很多開發者忽略了**“渲染位置”與“資源交付方式”**對體驗與性能的根本性影響。 從最初的瀏覽器渲染&#xff0c;到現在“在離用戶最近的地方動態返回 HTML”&#xff0c;架構正在悄悄…

linux學習記錄(六)三個常用命令介紹

1.vim命令 Vim是由Vi發展過來的文本編譯器&#xff0c;其代碼補全、編譯及錯誤跳轉等方便編程的功能特別豐富&#xff0c;在程序員中被廣泛使用。 1.1 語法 vim filename 1.2 vi/vim的使用 vi/vim 共分為三種模式&#xff0c;命令模式&#xff08;Command Mode&#xff09;、…

用Python獲取京東關鍵字接口的用戶指南

在電商數據分析和市場研究中&#xff0c;獲取京東平臺的關鍵字搜索結果數據具有重要意義。本文將詳細介紹如何使用Python調用京東開放平臺的API接口&#xff0c;獲取關鍵字相關的商品數據&#xff0c;并進行解析和處理。 一、準備工作 &#xff08;一&#xff09;注冊京東開發…

觀測云,全球領先的監控觀測平臺亮相亞馬遜云科技中國峰會!

觀測云每年都不會缺席亞馬遜云科技峰會 忙完一整季的產品發布&#xff0c;我們終于將目光投向這場全球頂尖的云技術盛會——2025亞馬遜云科技中國峰會。如果你也在這個領域&#xff0c;應該已經感覺到了&#xff1a;這不只是一場大會&#xff0c;而是一個信號。AI、可觀測性、…

消息隊列處理模式:流式與批處理的藝術

&#x1f30a; 消息隊列處理模式&#xff1a;流式與批處理的藝術 &#x1f4cc; 深入解析現代分布式系統中的數據處理范式 一、流式處理&#xff1a;實時數據的"活水" 在大數據時代&#xff0c;流式處理已成為實時分析的核心技術。它將數據視為無限的流&#xff0c;…

一起學習swin-transformer(一)

Transform學習鏈接 從零開始設計Transformer模型&#xff08;1/2&#xff09;——剝離RNN&#xff0c;保留Attention-CSDN博客 Transformer-PyTorch實戰項目——文本分類_transformer文本分類 pytorch-CSDN博客 從零開始設計Transformer模型&#xff08;2/2&#xff09;——…

PyQt常用控件的使用:QFileDialog、QMessageBox、QTreeWidget、QRadioButton等

文章目錄 一、控件常用函數介紹二、QFileDialog&#xff08;文件類操作&#xff09;三、QMessageBox(對話框)四、QTreeWidget&#xff08;樹結構類操作&#xff09;4.1 樹結構的初始化4.2 遞歸讀取完整樹結構4.3 兩QTreeWidget滑輪同步滑動4.4 信號槽綁定 五、QCombox改寫下拉多…

校園導航系統核心技術解析:高精度定位與 AR 實景導航的應用實踐

本文面向校園信息化建設者、技術開發者及教育行業數字化轉型關注者&#xff0c;旨在解析如何通過 “高精度定位 AR/VR 場景化服務” 技術體系&#xff0c;破解校區因建筑復雜、人流密集導致的尋路效率低下問題&#xff0c;探討如何利用現有技術解決校園內導航難題&#xff0c;…

java大文件分段下載

后端代碼 package com.jy.jy.controller;import org.springframework.http.HttpHeaders; import org.springframework.http.HttpStatus; import org.springframework.http.MediaType; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.a…

antd-vue - - - - - a-table排序

antd-vue - - - - - a-table排序 1. 重點代碼:2. 代碼示例&#xff1a;3. 進階版寫法 1. 重點代碼: sorter: {compare: (a, b) > a.columnsKeys - b.columnsKeys,multiple: 1, },解析&#xff1a; compare: 自定義排序函數&#xff0c;用于比較兩個對象。 multiple: 排序優…

【AI】模型vs算法(以自動駕駛為例)

模型vs算法&#xff08;以自動駕駛為例&#xff09; 一、自動駕駛的核心任務二、以自動駕駛為例&#xff0c;模型vs算法的實際分工1. 感知環節&#xff1a;“看懂”周圍環境&#xff08;如識別行人、車道線、車輛&#xff09;2. 預測環節&#xff1a;“預判”其他交通參與者的行…

機器學習與深度學習19-線性代數02

目錄 前文回顧6.協方差矩陣與主成分分析7.矩陣的奇異值分解8.神經網絡的前向傳播和反向傳播9.矩陣的跡10.特征工程的多項式特征擴展 前文回顧 上一篇文章鏈接&#xff1a;地址 6.協方差矩陣與主成分分析 協方差矩陣是一個對稱矩陣&#xff0c;用于衡量隨機變量之間的線性相關…

青藏高原ASTER_GDEM數據集(2011)

共享方式&#xff1a;開放獲取數據大小&#xff1a;73.69 GB數據時間范圍&#xff1a;2012-04-08 — 2012-05-08元數據更新時間&#xff1a;2021-10-15 數據集摘要 ASTER Global Digital Elevation Model &#xff08;ASTER GDEM&#xff09;是美國航空航天局 &#xff08;NAS…