欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React中Ref的作用小結(jié)

 更新時間:2024年11月10日 10:36:04   作者:ZL不懂前端  
本文文章介紹了React中的Ref概念,包括其基礎(chǔ)概念、使用方式,并討論了在React中通過Ref操作DOM值時避免組件不更新的問題,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

一、Ref的基礎(chǔ)概念

Ref是React提供的一個接口,允許我們訪問在渲染過程中創(chuàng)建的DOM節(jié)點或組件實例。它通常用于需要直接操作DOM或訪問組件內(nèi)部狀態(tài)的情況。值得注意的是,Ref并不屬于React的數(shù)據(jù)流的一部分,因此它的變更不會觸發(fā)組件的重新渲染。

二、Ref的使用方式

createRef方法

React 16.3引入了createRef方法,它允許我們創(chuàng)建一個可變的Ref對象,并將其賦值給一個類屬性。這個Ref對象有一個current屬性,該屬性指向被引用的DOM節(jié)點或組件實例。

class MyComponent extends React.Component {
  constructor(props) {
    super(props);
    this.myInputRef = React.createRef();
  }
 
  focusInput = () => {
    this.myInputRef.current.focus();
  };
 
  render() {
    return (
      <div>
        <input type="text" ref={this.myInputRef} />
        <button onClick={this.focusInput}>聚焦輸入框</button>
      </div>
    );
  }
}

函數(shù)組件中的useRef

在函數(shù)組件中,由于它們沒有實例,因此不能直接使用this.refs來訪問Ref。但是,React提供了useRef鉤子,它允許我們在函數(shù)組件中創(chuàng)建和使用Ref。

import React, { useRef } from 'react';
 
const MyFunctionComponent = () => {
  const inputRef = useRef(null);
 
  const focusInput = () => {
    if (inputRef.current) {
      inputRef.current.focus();
    }
  };
 
  return (
    <div>
      <input type="text" ref={inputRef} />
      <button onClick={focusInput}>聚焦輸入框</button>
    </div>
  );
};

回調(diào)函數(shù)Ref

回調(diào)函數(shù)Ref是一種更為靈活和推薦的使用方式。通過提供一個回調(diào)函數(shù),我們可以在Ref被設(shè)置或更新時執(zhí)行自定義邏輯。

class MyComponent extends React.Component {
  constructor(props) {
    super(props);
    this.myInputRef = null;
  }
 
  setMyInputRef = (element) => {
    this.myInputRef = element;
  };
 
  focusInput = () => {
    if (this.myInputRef) {
      this.myInputRef.focus();
    }
  };
 
  render() {
    return (
      <div>
        <input type="text" ref={this.setMyInputRef} />
        <button onClick={this.focusInput}>聚焦輸入框</button>
      </div>
    );
  }
}

三、ref操作值但組件不更新的問題

在 React 中,組件的更新通常是由狀態(tài)(state)或?qū)傩裕╬rops)的變化觸發(fā)的。當(dāng)使用ref直接操作組件的值時,React 并不知道這個值已經(jīng)改變了,因為ref繞過了 React 的響應(yīng)式更新機制。React 的更新機制是基于虛擬 DOM 的比較,只有當(dāng)state或props發(fā)生變化時,React 才會重新渲染組件。
在函數(shù)組件中,我們通常使用React的useState和useRef鉤子來管理狀態(tài)和引用,與類組件類似,直接通過Ref修改狀態(tài)通常不會觸發(fā)組件的重新渲染。這是因為Ref主要用于直接訪問DOM元素或組件實例,而不是用于管理狀態(tài)。

舉例

import React, { useState, useRef } from 'react';

const SimpleInputComponent = () => {
  const [inputValue, setInputValue] = useState(0); // React狀態(tài)
  const inputRef = useRef(0); // DOM引用

  // 處理輸入框變化,更新React狀態(tài)
  const handleInputChange = (event) => {
    setInputValue(event.target.value);
  };

  // 直接通過Ref修改DOM值(不推薦)
  const forceUpdateDOMValue = () => {
    if (inputRef.current) {
      inputRef.current.value = 1;
      // 注意:這里雖然DOM值變了,但React狀態(tài)inputValue沒有變
    }
  };

  // 通過useState更新狀態(tài)(推薦)
  const updateStateValue = () => {
    setInputValue(2);
  };

  return (
    <div>
      <input
        type="text"
        value={inputValue} // 這里綁定的是React狀態(tài)
        onChange={handleInputChange} // 更改時會更新React狀態(tài)
        ref={inputRef} // 綁定DOM引用
      />
      <button onClick={forceUpdateDOMValue}>通過Ref直接修改DOM值</button>
      <button onClick={updateStateValue}>通過useState更新狀態(tài)</button>
      <p>當(dāng)前React狀態(tài)值:{inputValue}</p>
    </div>
  );
};

export default SimpleInputComponent;

在這個例子中,我們有一個輸入框和兩個按鈕。當(dāng)你輸入文字時,React狀態(tài)inputValue會更新,并且組件會重新渲染以反映新的狀態(tài)。然而,當(dāng)你點擊“通過Ref直接修改DOM值”按鈕時,雖然輸入框的DOM值被改變了,但React狀態(tài)inputValue并沒有改變,因此頁面上顯示的React狀態(tài)值不會更新。相反,當(dāng)你點擊“通過useState更新狀態(tài)”按鈕時,React狀態(tài)inputValue會被更新,并且組件會重新渲染以顯示新的狀態(tài)值。

到此這篇關(guān)于React中Ref的作用小結(jié)的文章就介紹到這了,更多相關(guān)React Ref內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • react中antd文本框限制輸入中文方式

    react中antd文本框限制輸入中文方式

    這篇文章主要介紹了react中antd文本框限制輸入中文方式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • react-diagram 序列化Json解讀案例分析

    react-diagram 序列化Json解讀案例分析

    今天帶來大家學(xué)習(xí)react-diagram 序列化Json解讀的相關(guān)知識,本文通過多種案例給大家分析序列化知識,通過圖文并茂的形式給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2021-05-05
  • ES6下React組件的寫法示例代碼

    ES6下React組件的寫法示例代碼

    這篇文章主要給大家介紹了在ES6下React組件的寫法,其中包括定義React組件、聲明prop類型與默認(rèn)prop、設(shè)置初始state、自動綁定,文中分別給出了詳細(xì)的示例代碼供大家參考學(xué)習(xí),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。
    2017-05-05
  • JavaScript中的useRef 和 useState介紹

    JavaScript中的useRef 和 useState介紹

    這篇文章主要給大家分享的是 JavaScript中的useRef 和 useState介紹,下列文章,我們將學(xué)習(xí) useRef 和 useState hook是什么,它們的區(qū)別以及何時使用哪個。 這篇文章中的代碼示例將僅涉及功能組件,但是大多數(shù)差異和用途涵蓋了類和功能組件,需要的朋友可以參考一下
    2021-11-11
  • react-native 實現(xiàn)購物車滑動刪除效果的示例代碼

    react-native 實現(xiàn)購物車滑動刪除效果的示例代碼

    這篇文章主要介紹了react-native 實現(xiàn)購物車滑動刪除效果的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • React使用useImperativeHandle自定義暴露給父組件的示例詳解

    React使用useImperativeHandle自定義暴露給父組件的示例詳解

    useImperativeHandle?是?React?提供的一個自定義?Hook,用于在函數(shù)組件中顯式地暴露給父組件特定實例的方法,本文將介紹?useImperativeHandle的基本用法、常見應(yīng)用場景,需要的可以參考下
    2024-03-03
  • React中如何設(shè)置自定義滾動條樣式

    React中如何設(shè)置自定義滾動條樣式

    這篇文章主要介紹了React中如何設(shè)置自定義滾動條樣式問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • React + webpack 環(huán)境配置的方法步驟

    React + webpack 環(huán)境配置的方法步驟

    本篇文章主要介紹了React + webpack 環(huán)境配置的方法步驟,詳解的介紹了開發(fā)環(huán)境的配置搭建,有興趣的可以了解一下
    2017-09-09
  • jenkins分環(huán)境部署vue/react項目的方法步驟

    jenkins分環(huán)境部署vue/react項目的方法步驟

    這篇文章主要介紹了jenkins分環(huán)境部署vue/react項目的方法,本文分步驟給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02
  • 一篇文章教你用React實現(xiàn)菜譜系統(tǒng)

    一篇文章教你用React實現(xiàn)菜譜系統(tǒng)

    本篇文章主要介紹了React實現(xiàn)菜譜軟件的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-09-09

最新評論