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

react?hooks深拷貝后無法保留視圖狀態(tài)解決方法

 更新時間:2023年06月29日 11:11:34   作者:w晚風  
這篇文章主要為大家介紹了react?hooks深拷貝后無法保留視圖狀態(tài)解決示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

問題

在使用useState做數(shù)據(jù)操作更新的時候,有一些復雜數(shù)據(jù)類型,一個對象數(shù)組里包含,函數(shù),dom等等復雜數(shù)據(jù)類型,想要進行數(shù)據(jù)更新,并且視圖更新的情況下,因useState的特性就必須進行深拷貝賦值。

方式

1、JSON.stringify配合JSON.parse 這個有限制,我們的數(shù)據(jù)類型包含,函數(shù)。它會丟失

2、Lodash 里的深拷貝方法

3、遞歸實現(xiàn)

我這里通過遞歸直接寫的方法,發(fā)現(xiàn)拷貝是可以了,但是無法保留之前dom上的視圖狀態(tài)看,查閱文檔如下

React Hooks 是 React 的一種新特性,它提供了一種更加方便和簡潔的方式來編寫組件。React Hooks 中的 state 和 props 都是可變的,當組件的狀態(tài)或?qū)傩园l(fā)生改變時,React 會重新渲染組件。在進行深拷貝時,只是將組件的 state 或 props 對象中的值復制到了一個新的對象中,新的對象和原來的對象是完全獨立的,它們的引用關系已經(jīng)被斷開。而 React 在進行組件渲染時,是根據(jù)組件的 state 和 props 來計算出組件的視圖狀態(tài)的,當組件的 state 或 props 發(fā)生改變時,React 會重新計算組件的視圖狀態(tài),并重新渲染組件。

因此,如果在進行深拷貝后,將新的對象作為組件的 state 或 props,那么組件的視圖狀態(tài)就會丟失,因為 React 認為組件的狀態(tài)或?qū)傩圆]有發(fā)生改變,所以不會重新計算組件的視圖狀態(tài)。要保留組件的視圖狀態(tài),需要確保深拷貝后的對象和原來的對象具有相同的引用關系,或者使用其他方法來進行狀態(tài)管理,例如使用 React Context 或 Redux 等狀態(tài)管理庫。

解決

我這里是找了一個npm包來處理了

首先,我們需要安裝一個不可變數(shù)據(jù)結(jié)構(gòu)庫,這里我選擇使用Immer。您可以使用以下命令進行安裝:

npm install immer

然后,我們可以使用Immer來創(chuàng)建一個新的狀態(tài)對象,而不必擔心丟失與原始狀態(tài)相關聯(lián)的視圖狀態(tài)。下面是一個示例:

代碼

import React, { useState } from 'react';
import produce from 'immer';
function MyComponent() {
  const [data, setData] = useState({ 
    name: 'John',
    age: 30,
    address: {
      city: 'New York',
      country: 'USA'
    }
  });
  const handleButtonClick = () => {
    const newData = produce(data, draftData => {
      draftData.age = 31;
      draftData.address.city = 'Los Angeles';
    });
    setData(newData);
  };
  return (
    <div>
      <p>Name: {data.name}</p>
      <p>Age: {data.age}</p>
      <p>City: {data.address.city}</p>
      <p>Country: {data.address.country}</p>
      <button onClick={handleButtonClick}>Update</button>
    </div>
  );
}

在上面的示例中,我們使用了Immer的produce方法來創(chuàng)建一個新的狀態(tài)對象newData,并在其中更新了age和address.city屬性。然后,我們使用setData方法將新的狀態(tài)對象設置為組件的狀態(tài)。由于我們使用了不可變數(shù)據(jù)結(jié)構(gòu),與原始狀態(tài)相關聯(lián)的視圖狀態(tài)將不會丟失。

請注意,我們在handleButtonClick方法中使用了produce方法來創(chuàng)建新的狀態(tài)對象。produce方法將原始狀態(tài)對象data作為第一個參數(shù),并接受一個回調(diào)函數(shù)作為第二個參數(shù)。在回調(diào)函數(shù)中,我們可以使用類似于修改原始狀態(tài)對象的方式來修改draftData對象,但實際上我們是在修改新的狀態(tài)對象。最后,produce方法將返回一個新的狀態(tài)對象newData,該對象包含所有更改。

我這里試過是ok的

以上就是react hooks深拷貝后無法保留視圖狀態(tài)解決方法的詳細內(nèi)容,更多關于react hooks深拷貝視圖狀態(tài)的資料請關注腳本之家其它相關文章!

相關文章

  • React Fiber中面試官最關心的技術(shù)話題

    React Fiber中面試官最關心的技術(shù)話題

    這篇文章主要為大家介紹了React Fiber中面試官最關心的技術(shù)話題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • react+redux的升級版todoList的實現(xiàn)

    react+redux的升級版todoList的實現(xiàn)

    本篇文章主要介紹了react+redux的升級版todoList的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • React中useTransition鉤子函數(shù)的使用詳解

    React中useTransition鉤子函數(shù)的使用詳解

    React?18的推出標志著React并發(fā)特性的正式到來,其中useTransition鉤子函數(shù)是一個重要的新增功能,下面我們就來學習一下useTransition鉤子函數(shù)的具體使用吧
    2024-02-02
  • React事件處理和表單的綁定詳解

    React事件處理和表單的綁定詳解

    這篇文章主要介紹了React事件處理和表單的綁定,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-08-08
  • 在?React?中使用?Context?API?實現(xiàn)跨組件通信的方法

    在?React?中使用?Context?API?實現(xiàn)跨組件通信的方法

    在React中,ContextAPI是一個很有用的特性,可用于組件間的狀態(tài)共享,它允許跨組件傳遞數(shù)據(jù)而無需通過每個組件手動傳遞props,本文給大家介紹在?React?中如何使用?Context?API?來實現(xiàn)跨組件的通信,感興趣的朋友一起看看吧
    2024-09-09
  • React如何實現(xiàn)視頻旋轉(zhuǎn)縮放

    React如何實現(xiàn)視頻旋轉(zhuǎn)縮放

    這篇文章主要為大家詳細介紹了React如何實現(xiàn)視頻旋轉(zhuǎn)縮放功能,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-11-11
  • react函數(shù)組件類組件區(qū)別示例詳解

    react函數(shù)組件類組件區(qū)別示例詳解

    這篇文章主要為大家介紹了react函數(shù)組件類組件區(qū)別示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • react 報錯Module build failed: BrowserslistError: Unknown browser query `dead`問題的解決方法

    react 報錯Module build failed: Browserslis

    這篇文章主要介紹了react 報錯Module build failed: BrowserslistError: Unknown browser query `dead`問題的解決方法,需要的朋友可以參考下
    2023-06-06
  • 解析React中useMemo與useCallback的區(qū)別

    解析React中useMemo與useCallback的區(qū)別

    這篇文章主要介紹了React中useMemo與useCallback的區(qū)別,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • React框架核心原理全面深入解析

    React框架核心原理全面深入解析

    React是前端開發(fā)每天都用的前端框架,自然要深入掌握它的原理。我用 React 也挺久了,這篇文章就來總結(jié)一下我對 react 原理的理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2022-11-11

最新評論