第二節:React 基礎篇-受控組件 vs 非受控組件

一、場景題:設計一個實時搜索輸入框,說明選擇依據

受控組件 vs 非受控組件

核心區別
特征受控組件非受控組件
數據管理由React狀態(state)控制通過DOM元素(ref)直接訪問
更新時機每次輸入觸發onChange提交時通過ref獲取值
實時性即時響應輸入延遲獲取最終值
典型場景需實時驗證/反饋的輸入表單提交后處理

實時搜索輸入框設計

場景需求

? 用戶輸入時立即觸發搜索請求(需防抖優化)
? 輸入內容需要動態高亮匹配結果
? 支持清空輸入后重置搜索結果

方案選擇:受控組件

代碼實現

import { useState, useEffect } from 'react';function SearchInput() {const [query, setQuery] = useState('');const [results, setResults] = useState([]);// 防抖處理(300ms延遲)useEffect(() => {const handler = setTimeout(() => {if (query) {fetchResults(query).then(setResults);} else {setResults([]);}}, 300);return () => clearTimeout(handler);}, [query]);return (<div><inputtype="text"value={query}onChange={(e) => setQuery(e.target.value)}placeholder="Search..."/><ul>{results.map((result) => (<li key={result.id}>{result.text}</li>))}</ul></div>);
}
選擇依據
  1. 實時反饋需求
    ? 輸入內容需要立即觸發搜索邏輯(防抖優化避免頻繁請求)。
    ? 受控組件的onChange可精準捕獲每次輸入變化,適合高頻交互。

  2. 狀態同步性
    ? 搜索結果的渲染依賴當前輸入值(如query清空時需同步清空結果)。
    ? 受控組件通過useState保證UI與狀態嚴格同步。

  3. React 18優化
    ? 自動批處理(Automatic Batching)合并多次setQuery導致的渲染,減少性能損耗。
    ? useTransition可標記搜索為低優先級更新,避免輸入卡頓。


為何不選非受控組件?

  1. 延遲問題
    ? 非受控組件需通過ref.current.value手動獲取值,無法實時響應輸入變化。

  2. 防抖實現復雜
    ? 需自行監聽input事件并添加定時器,代碼冗余易出錯。

  3. 狀態追溯困難
    ? 清空輸入框時需手動操作DOM(如ref.current.value = ""),違背React數據流原則。


總結

? 優先受控組件:實時交互、狀態依賴型場景(搜索、表單驗證)。
? 選非受控組件:僅需最終結果的文件上傳、大型表單性能優化(如1000+字段)。
? React 18+優化:利用useDeferredValue進一步降低高頻輸入的性能開銷:

const deferredQuery = useDeferredValue(query); // 延遲更新派生值

二、場景:自己實現一個非受控組件的案例

以下是一個簡單的非受控組件實現案例,通過 ref 直接訪問輸入框的值:

import { useRef } from 'react';function UncontrolledInput() {// 1. 創建ref引用const inputRef = useRef(null);// 2. 提交時獲取值const handleSubmit = (e) => {e.preventDefault();alert("輸入的值: " + inputRef.current.value);inputRef.current.value = ""; // 直接操作DOM清空輸入};return (<form onSubmit={handleSubmit}><input type="text" ref={inputRef}  // 3. ref綁定到inputplaceholder="非受控輸入" /><button type="submit">提交</button></form>);
}
核心特點:
  1. 直接DOM操作:通過 inputRef.current.value 直接讀寫輸入框值
  2. 無狀態管理:無需 useState 控制輸入內容
  3. 適用場景:表單提交后只需最終值,無需實時驗證或中間狀態
對比受控組件優勢:

? 更少渲染:輸入過程不會觸發組件重渲染
? 代碼更簡:適合簡單表單(如一次性文件上傳)

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

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

相關文章

局部路由守衛

局部路由守衛為我們提供了更細粒度的路由控制&#xff0c;允許我們在特定的路由或組件級別添加鑒權和邏輯處理。局部路由守衛分為 path 守衛和 component 守衛&#xff0c;它們分別適用于不同的場景。 path 守衛&#xff08;路由守衛&#xff09; path 守衛用于在進入特定路由…

Android 16應用適配指南

Android 16版本特性介紹 https://developer.android.com/about/versions/16?hlzh-cn Android 16 所有功能和 API 概覽 https://developer.android.com/about/versions/16/features?hlzh-cn#language-switching Android 16 發布時間 Android 16 適配指南 Google開發平臺&…

android display 筆記(十二)CPU,GPU,DPU的區別

CPU&#xff08;Central Processing Unit&#xff09;通用計算&#xff1a;處理復雜邏輯、分支預測、多任務調度。 低延遲&#xff1a;優先快速響應單線程任務。 GPU&#xff08;Graphics Processing Unit&#xff09; 高吞吐量并行計算&#xff1a;適合大規模數據并行處理。…

音頻轉文本:如何識別音頻成文字

Python腳本:MP4轉MP3并語音識別為中文 以下是一個完整的Python腳本,可以將MP4視頻轉換為MP3音頻,然后使用語音識別模型將音頻轉換為中文文本。 準備工作 首先需要安裝必要的庫: pip install moviepy pydub SpeechRecognition openai-whisper完整腳本 import os from m…

理解 MCP 協議的數據傳遞:HTTP 之上的一層“殼子

以下是以 CSDN 博客的風格記錄你對 MCP 協議數據傳遞的理解和發現&#xff0c;內容涵蓋了 MCP 協議基于 HTTP 的本質、JSON-RPC 的“殼子”作用&#xff0c;以及為什么熟悉 HTTP 協議就足以理解 MCP 的數據傳遞。文章面向技術社區&#xff0c;結構清晰&#xff0c;適合分享。 理…

基于ssm網絡游戲推薦系統(源碼+lw+部署文檔+講解),源碼可白嫖!

摘要 當今社會進入了科技進步、經濟社會快速發展的新時代。國際信息和學術交流也不斷加強&#xff0c;計算機技術對經濟社會發展和人民生活改善的影響也日益突出&#xff0c;人類的生存和思考方式也產生了變化。傳統網絡游戲管理采取了人工的管理方法&#xff0c;但這種管理方…

vue入門:指令

文章目錄 vue的內置指令說明&#xff1a; 自定義指令 vue的內置指令 Vue 指令的本質是&#xff1a; 聲明式的 DOM 操作接口&#xff08;隱藏底層 JavaScript 代碼&#xff09;。響應式數據的綁定媒介&#xff08;連接數據和視圖&#xff09;。模板編譯的標記&#xff08;最終…

oracle 索引失效

在 Oracle 11g 中&#xff0c;索引失效的常見原因包括函數修改列、隱式類型轉換、統計信息過時等&#xff0c;解決方法需結合版本特性&#xff08;如虛擬列、索引跳躍掃描&#xff09;。通過執行計劃分析、統計信息維護和合理使用提示&#xff08;Hints&#xff09;&#xff0c…

k8s藍綠發布

k8s藍綠發布 什么是藍綠部署K8S中如何實現藍綠部署k8s藍綠部署流程圖 什么是藍綠部署 參考: https://youtu.be/CLq_hA0lAd0 https://help.coding.net/docs/cd/best-practice/blue-green.html 藍綠部署最早是由馬丁福勒 2010年在他的博客中提出. 藍綠部署是一種軟件部署策略,用…

stm32面試

數據結構相關問題 stm32面試 數據結構相關問題 目錄基礎數據結構樹與圖排序與查找算法 Linux相關問題Linux系統基礎Linux命令與腳本Linux網絡與服務 操作系統相關問題操作系統基礎概念操作系統調度算法操作系統同步與通信 STM32相關問題STM32硬件基礎STM32編程與開發STM32應用與…

Mybatis 中 mappers標簽 package的使用

MyBatis 的配置文件中&#xff0c;<mappers> 標簽用于指定 MyBatis 應該加載哪些映射器&#xff08;Mapper&#xff09;。其中 package 屬性是一種便捷的方式來批量注冊多個映射器接口 package 屬性允許你指定一個包名&#xff0c;MyBatis 會自動掃描該包下的所有映射器…

設計模式 --- 訪問者模式

訪問者模式是一種行為設計模式&#xff0c;它允許在不改變對象結構的前提下&#xff0c;定義作用于這些對象元素的新操作。 優點&#xff1a; 1.??符合開閉原則&#xff1a;新增操作只需添加新的訪問者類&#xff0c;無需修改現有對象結構。 ??2.操作邏輯集中管理??&am…

監控docker中的java應用

1)進入指定的容器 docker exec -it demo /bin/bash 2)下載curl root89a67e345354:/# apt install curl -y 3)下載arthas root89a67e345354:/# curl -O https://arthas.aliyun.com/arthas-boot.jar 4)運行 root89a67e345354:/# java -jar arthas-boot.jar 5)監控 […

最新版RubyMine超詳細圖文安裝教程,帶補丁包(2025最新版保姆級教程)

目錄 前言 一、RubyMine最新版下載 二、RubyMine安裝 三、RubyMine補丁 四、運行RubyMine 前言 RubyMine是由JetBrains開發的集成開發環境&#xff08;IDE&#xff09;&#xff0c;專為Ruby和Ruby on Rails開發者設計&#xff0c;提供智能代碼補全、調試、測試、版本控制集…

數字政府與智慧城市區別報告分析

數字政府與智慧城市區別報告分析 一、引言 隨著信息技術的飛速發展&#xff0c;數字政府和智慧城市成為推動城市現代化和治理能力提升的兩個重要概念。雖然它們都依托于信息技術&#xff0c;但二者在目標、內涵、實施路徑等方面存在顯著差異。本文旨在深入探討數字政府與智慧…

[MRCTF2020]ezpop wp

本題考點:php反序列化的pop鏈 首先來了解一下pop鏈是什么,它類似于多米諾骨牌一環套一環,要調用這個成員方法然后去找能調用這個方法的魔術方法,最后一環接一環,完成一個鏈子,最終形成payload。 那么來了解一下這些魔術方法 __construct() //類的構造函數&#xff0…

spark架構和RDD相關概念

運行架構&#xff1a; Spark采用master - slave結構&#xff0c;Driver作為master負責作業任務調度&#xff0c;Executor作為slave負責實際執行任務。 核心組件 Driver&#xff1a;執行Spark任務的main方法&#xff0c;將用戶程序轉化為作業&#xff0c;在Executor間調度任務&…

安全是基石

“安全是基石”這句話強調了安全在個人、企業、社會等各個層面中的基礎性和不可替代的重要性。無論是物理安全、網絡安全、數據安全&#xff0c;還是生產安全、公共安全&#xff0c;都是保障穩定發展的前提。以下是不同領域中“安全”作為基石的體現&#xff1a; 1. 個人安全 基…

Linux Makefile-概述、語句格式、編寫規則、多文件編程、Makefile變量分類:自定義變量、預定義變量

目錄 1.make 1.1 make 命令格式 2.Makefile 核心概念? ? 2.1創建并運行 Makefile步驟 3. Makefile編寫 3.1最基礎Makefile 3.1.1使用默認make命令 3.1.2使用make -f 命令 3.1.2.1 使用make -f 命令執行默認make操作 3.1.2.2使用 make [ ‐f file ] [ targets ]命令 …

城市應急安防系統EasyCVR視頻融合平臺:如何實現多源視頻資源高效匯聚與應急指揮協同

一、方案背景 1&#xff09;項目背景 在當今數字化時代&#xff0c;隨著信息技術的飛速發展&#xff0c;視頻監控和應急指揮系統在公共安全、城市應急等領域的重要性日益凸顯。尤其是在關鍵場所&#xff0c;高效的視頻資源整合與傳輸能力對于應對突發公共事件、實現快速精準的…