精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

探索 useSyncExternalStore,一個鮮為人知的 React Hook

開發 前端
React 提供了很多內置的 Hook,其中一些在開發人員中非常常用。然而,像 useSyncExternalStore 這樣真正有用的 Hook 經常會被掩蓋。

原文鏈接:https://blog.logrocket.com/exploring-usesyncexternalstore-react-hook/

原文作者:Abhinav Anshul 翻譯:一川

您可能已經熟悉 React 提供的一組內置 Hook,例如 useState、useEffect、useMemo 等等。其中包括 useSyncExternalStore Hook,它在庫作者中非常常用,但在客戶端 React 項目中很少見到。

在本文中,將探討 useSyncExternalStore Hook,以更好地了解它是什么、它如何工作、為什么有用以及何時應該在前端項目中利用它。

useSyncExternalStore 簡介

如果您想訂閱外部數據存儲,useSyncExternalStore 可能是完美的 API。大多數時候,開發人員選擇 useEffect Hook。但是,如果您的數據存在于 React 樹之外,則 useSyncExternalStore 可能更合適。

基本的 useSyncExternalStore API 接受三個參數:

useSyncExternalStore(subscribe, getSnapshot, getServerSnapshot)
  • subscribe 是一個回調,它接收訂閱外部存儲數據的函數
  • getSnapshot 是一個返回外部存儲數據當前快照的函數
  • getServerSnapshot 是一個可選參數,用于發送初始存儲數據的快照。可以在服務器數據的初始水合作用期間使用它

useSyncExternalStore 返回訂閱的外部數據的當前快照。

考慮這樣一種情況,外部數據不在React 樹中——換句話說,它存在于你的前端代碼或一般應用程序之外。在這種情況下,可以使用 useSyncExternalStore 訂閱該數據存儲。

為了更好地理解 useSyncExternalStore Hook,讓我們看一個非常簡單的實現。可以將其分配給一個變量(例如下面示例中的 list ),并根據需要將其呈現給 UI:

import { useSyncExternalStore } from 'react';
import externalStore from './externalStore.js';

function Home() {
const list = useSyncExternalStore(externalStore.subscribe, externalStore.getSnapshot);

  return (
    <>
      <section>
        {list.map((itm, index) => (
          <div key={index}>
            <div>{itm?.title}</div>
          </div>
        ))}
      </section>
    </>
  );
}

如您所見, externalStore 現已訂閱,將獲得對 externalStore 數據執行的任何更改的實時快照。您可以使用 list 進一步映射外部源中的項目并進行實時 UI 渲染。

外部存儲中的任何更改都會立即反映出來,React 將根據快照更改重新渲染 UI。

useSyncExternalStore 的用例

useSyncExternalStore Hook 是許多利基用例的理想解決方案,例如:

  • 緩存來自外部 API 的數據:由于此 Hook 主要用于訂閱外部第三方數據源,因此緩存數據也變得更簡單。可以使應用程序的數據與外部數據源保持同步,以后還可以將其用于離線支持
  • WebSocket 連接:由于 WebSocket 是一個“持續”連接,因此可以使用此 Hook 來實時管理 WebSocket 連接狀態數據
  • 管理瀏覽器存儲:在這種情況下,需要在 Web 瀏覽器存儲(例如 IndexedDB 或 localStorage )與應用程序狀態之間同步數據,可以使用 useSyncExternalStore 訂閱更新外部store

在很多這樣的情況下,這個 Hook 可能比流行的 useEffect Hook 非常有用并且更容易管理。讓我們在下一節中比較這兩個 Hook。

useSyncExternalStore 與 useEffect

您可以選擇更常用的 useEffect Hook 來實現與上面示例類似的功能:

const [list, setList] = useState([]);

  useEffect(() => {
    const fetchData = async () => {
      try {
        // assuming externalStore has a fetchData method or it is an async operation
        const newList = await externalStore.fetchData();
        setList(newList);
      } catch (error) {
        console.error(error);
      }
    };
    // calling the async function here
    fetchData();
  }, []);

但是, useEffect Hook 不提供每次狀態更新的當前快照,并且它比 useSyncExternalStore Hook 更容易出錯。此外,它還存在臭名昭著的重新渲染問題。接下來我們簡單回顧一下這個問題。

在處理 useEffect Hook 時,可能會遇到的一個主要問題是渲染順序。瀏覽器完成繪制后,只有 useEffect Hook 會觸發。這種延遲(盡管是故意的)會在管理正確的事件鏈方面帶來意想不到的錯誤和挑戰。

考慮以下示例:

function Counter() {
  const [count, setCount] = useState(0);

  useEffect(() => {
    console.log('count- ', count);
    // Imagine some asynchronous task here, like fetching data from an API
    // This could introduce a delay between the state update and the effect running
    // afterwards.
  }, [count]);

  const increment = () => {
    setCount(count + 1);
  };

  console.log('outside the effect count - ', count);

  return (
    <div>
      <div>Counter</div>
      <div>Count: {count}</div>
      <button onClick={increment}>Increment</button>
    </div>
  );
}

export default Counter;

您可能期望計數器應用程序以簡單的方式運行,其中狀態更新,組件重新渲染,最后運行效果。然而,由于 API 調用的延遲,事情變得有點棘手,并且事件的順序可能不是我們所期望的。

現在考慮一個具有許多此類副作用和不同依賴項數組的應用程序。在這種情況下,以正確的順序跟蹤狀態更新將是一場噩夢。

如果您的數據位于外部并且不依賴于現有的 React API 來處理,那么您可以避免所有這些并使用 useSyncExternalStore Hook 來修復此性能差距。與 useEffect Hook 不同,此 Hook 會立即觸發,不會造成任何延遲。

useSyncExternalStore 還可以防止前面提到的重新渲染問題,只要狀態發生變化,您就可能會遇到 useEffect 問題。有趣的是,使用 useSyncExternalStore 訂閱的狀態不會重新渲染兩次,從而解決了巨大的性能問題。

useSyncExternalStore 與 useState

使用 useSyncExternalStore Hook 時,您可能會覺得您只是訂閱一個狀態并將其分配給一個變量,類似于使用 useState Hook。然而, useSyncExternalStore 不僅僅是簡單地分配狀態。

useState Hook 的一個限制是它被設計為以“每個組件”的方式管理狀態。換句話說,你定義的狀態僅限于它自己的React組件,無法全局訪問。您可以使用回調、全局強制狀態,甚至可以在組件中使用 prop-drilling 狀態,但這可能會減慢您的 React 應用程序的速度。

useSyncExternalStore Hook 通過設置一個全局狀態來防止此問題,您可以從任何 React 組件訂閱該狀態,無論其嵌套有多深。更好的是,如果您正在處理非 React 代碼庫,您只需關心訂閱事件。

useSyncExternalStore 將向您發送可以在任何 React 組件中使用的全局存儲當前狀態的正確快照。

使用 useSyncExternalStore 構建待辦事項應用

讓我們通過構建一個演示待辦事項應用程序來看看 useSyncExternalStore Hook 在實際項目中有多有用。首先,創建一個用作外部全局狀態的 store.js 文件。稍后我們將為我們的待辦事項訂閱此狀態:

let todos = [];
let subscribers = new Set();

const store = {
  getTodos() {
    // getting all todos
    return todos;
  },

 // subscribe and unsubscribe from the store using callback
  subscribe(callback) {
    subscribers.add(callback);
    return () => subscribers.delete(callback);
  },

// adding todo to the state
  addTodo(text) {
    todos = [
      ...todos,
      {
        id: new Date().getTime(),
        text: text,
        completed: false,
      },
    ];

    subscribers.forEach((callback) => {
      callback();
    });
  },
// toggle for todo completion using id
  toggleTodo(id) {
    todos = todos.map((todo) => {
      return todo.id === id ? { ...todo, completed: !todo.completed } : todo;
    });
    subscribers.forEach((callback) => callback());
  },
};

// exporting the default store state
export default store;

您的 store 現在已準備好在 React 組件中訂閱。繼續創建一個簡單的 Todo 組件,該組件將通過訂閱您之前創建的商店將待辦事項呈現到 UI:

import { useSyncExternalStore } from "react";
import store from "./store.js";

function Todo() {
// subscribing to the store  
const todosStore = useSyncExternalStore(store.subscribe, store.getTodos);

  return (
    <div>
      {todosStore.map((todo, index) => (
        <div key={index}>
           <input
              type="checkbox"
              value={todo.completed}
              onClick={() => store.toggleTodo(todo.id)}
            />
            // toggle based on completion logic 
            {todo.completed ? <div>{todo.text}</div> : todo.text}
        </div>
      ))}
    </div>
  );
}

export default Todo;

至此,我們使用 useSyncExternalStore 的迷你演示項目就完成了。結果應如下所示:

圖片圖片

總結

React 提供了很多內置的 Hook,其中一些在開發人員中非常常用。然而,像 useSyncExternalStore 這樣真正有用的 Hook 經常會被掩蓋。

在這篇文章中,您已經了解了此 Hook 有許多出色的使用示例,它們不僅可以改善整體應用程序體驗,還可以防止您在使用 useEffect Hook 時可能遇到的討厭的錯誤。

如果您是 JavaScript 庫作者,可能已經在使用它來獲得使用 useEffect Hook 或 useState Hook 無法實現的性能提升。正如我們在本文中探討的那樣,如果正確使用,useSyncExternalStore Hook 可以為您節省大量的開發時間。

責任編輯:武曉燕 來源: 宇宙一碼平川
相關推薦

2017-11-08 14:55:16

Linux命令sudo

2009-09-14 09:45:20

Chrome谷歌操作系統

2019-10-08 16:24:33

Chrome瀏覽器

2014-07-29 14:25:43

Unix命令

2023-04-23 15:11:26

2010-01-07 10:05:51

IT顧問特質

2024-03-04 16:32:02

JavaScript運算符

2019-12-12 20:49:05

JavaScript語言運算符

2014-04-22 16:38:12

GitHubGitHub 使用技巧

2011-05-03 13:13:52

編程PHPJava

2013-07-15 09:14:00

2021-08-01 22:41:07

微信功能技巧

2009-01-03 09:00:00

2019-11-20 10:54:32

Python數據結構數據庫

2013-11-19 11:59:49

Linux命令Shell腳本

2024-05-07 00:00:00

工具類開發者功能

2024-09-10 08:35:57

2018-12-10 19:30:45

2024-10-31 11:19:33

2015-06-09 11:12:31

Swift語言Swift特性
點贊
收藏

51CTO技術棧公眾號

亚洲成av人片乱码色午夜| www在线看| 精品一区二区综合| 欧美精品videos另类日本| 91精品人妻一区二区| 四虎国产精品免费久久| 午夜视频在线观看一区二区| 神马一区二区影院| 二区三区在线视频| 日本免费新一区视频 | 日韩大片在线永久免费观看网站| 国产一区二区三区美女| 国产91精品最新在线播放| 国产又黄又爽又无遮挡| 韩日一区二区三区| 亚洲成人免费网站| 亚洲xxx在线观看| 亚洲人成午夜免电影费观看| 亚洲精品综合在线| 亚洲人久久久| 日本一二三区在线视频| 国产.欧美.日韩| 91久久久久久久一区二区| 天天操天天操天天操天天| 欧美va亚洲va日韩∨a综合色| 国产午夜一区二区| 日本免费福利视频| 黑人久久a级毛片免费观看| 欧美影视一区二区三区| 国产网站免费在线观看| 污视频网站在线免费| 中文字幕在线不卡| 亚洲精品一区二区毛豆| 黄色电影免费在线看| 91麻豆视频网站| 国产伦精品一区二区三区在线| 99久久精品免费看国产交换| 美女www一区二区| 国产精品va在线播放| 欧美在线观看不卡| 亚洲专区在线| 国产91成人video| 国产高潮久久久| 99av国产精品欲麻豆| 国内久久久精品| 欧美日韩中文视频| 亚洲电影av| 久久免费视频在线观看| 久久视频免费在线观看| 99热这里只有精品8| 久久噜噜噜精品国产亚洲综合 | 欧美性猛交xxxx富婆| 国产l精品国产亚洲区久久| 交100部在线观看| 精品久久久一区| 精品中文字幕av| 在线毛片观看| 在线国产电影不卡| 蜜臀av免费观看| 99er精品视频| 亚洲精品一区二区三区在线观看| 国产伦精品一区二区三区精品| 精品国产乱子伦一区二区| 日韩电影第一页| 欧美 日韩 国产 成人 在线观看| 国产一区二区电影在线观看| 色噜噜狠狠色综合网图区| 亚洲女人久久久| 欧美三级网页| 欧美最猛性xxxxx(亚洲精品)| 日本高清不卡码| 奇米精品一区二区三区四区| 91在线视频导航| 日本精品999| 久久久久久久久97黄色工厂| 夜夜爽99久久国产综合精品女不卡| 国产91在线视频蝌蚪| 亚洲丶国产丶欧美一区二区三区| 亚洲午夜精品久久久久久人妖| av一区在线| 欧美一区二区三区在线电影 | 国产一区二区在线视频观看| 国产成人精品免费网站| 欧美二区三区在线| 日本高清中文字幕在线| 亚洲一区二区三区四区在线观看 | 97色婷婷成人综合在线观看| 亚洲国产精品视频在线观看| 黄色av免费播放| 欧美日韩一区二区三区四区在线观看 | 欧美视频观看一区| 国产高清一区二区三区视频| 五月婷婷综合网| 欧美激情国内自拍| 欧美电影在线观看免费| 另类图片亚洲另类| 色屁屁影院www国产高清麻豆| 狠狠色狠狠色综合系列| 久久www免费人成精品| 欧美69xxx| 欧美性少妇18aaaa视频| 一区二区在线免费观看视频| 欧美精品一二| 午夜精品在线观看| 国产精品久久久久久久久久久久久久久久久久 | 9l视频自拍9l视频自拍| 中文字幕成在线观看| 欧美一二三区精品| 欧美日韩国产黄色| 亚洲免费在线| 成人自拍爱视频| 亚洲视频tv| 色999日韩国产欧美一区二区| 亚洲 自拍 另类 欧美 丝袜| 欧美日韩亚洲在线观看| 欧美亚洲在线观看| 六月丁香色婷婷| 亚洲欧美激情小说另类| 日韩欧美在线免费观看视频| 欧美三级午夜理伦三级在线观看| 久久精品国产视频| 日本三级一区二区三区| 久久一区二区三区国产精品| 无码 制服 丝袜 国产 另类| 我要色综合中文字幕| 中文字幕自拍vr一区二区三区| 日本a级c片免费看三区| 99re视频这里只有精品| 日b视频免费观看| 精品伊人久久| 麻豆国产精品va在线观看不卡 | 日韩高清免费观看| 国产精品xxxx喷水欧美| 国产91精品入口| 8x8x华人在线| 免费观看性欧美大片无片| 久久亚洲影音av资源网| 国产精品乱码久久久| √…a在线天堂一区| 在线观看免费污视频| 成人情趣视频网站| 国产精品亚洲аv天堂网| 91福利在线视频| 欧美日韩在线播放一区| 国产又黄又粗又猛又爽的| 蜜桃视频一区二区| 超碰成人在线免费观看| www.成人在线.com| 欧美乱大交xxxxx另类电影| 不卡的日韩av| 亚洲国产日日夜夜| 18禁裸乳无遮挡啪啪无码免费| 亚洲欧美高清| 久久伊人一区| 88xx成人永久免费观看| 中文字幕成人在线| 97人妻精品一区二区三区软件 | 天天综合天天干| 久久久高清一区二区三区| 人人干人人视频| 香港欧美日韩三级黄色一级电影网站| 91精品在线国产| 人人澡人人添人人爽一区二区| 亚洲电影av在线| youjizz在线视频| 中文av一区二区| 亚洲国产欧美91| 99精品国产99久久久久久福利| 久久亚洲免费| 在线视频成人| 久久久免费电影| 国产一二三区在线| 538在线一区二区精品国产| 国产在线视频在线观看| 久久婷婷成人综合色| 色婷婷综合网站| 国精品一区二区| 欧美一区免费视频| 日韩在线成人| 国产精品96久久久久久| 50度灰在线| 亚洲精品视频免费| 国产视频在线观看免费| 欧美色道久久88综合亚洲精品| 一级在线观看视频| 成人午夜又粗又硬又大| 亚洲老女人av| 亚洲精品激情| 在线看视频不卡| 性人久久久久| 亚洲影院高清在线| 国产免费不卡| 欧美高清性猛交| av亚洲在线| 日韩电影中文字幕av| 国产福利资源在线| 欧美曰成人黄网| 国产精品黄色大片| 自拍偷拍欧美激情| 99精品国产高清一区二区| 麻豆视频网站在线观看| 日韩av在线一区| 99久久精品无免国产免费| 色视频成人在线观看免| 久久精品国产亚洲AV无码麻豆 | 欧美人妻精品一区二区三区| 久久久综合精品| 国产成人精品一区二区在线小狼| 日本不卡在线视频| 91免费视频网站在线观看| 好看不卡的中文字幕| 五月天色一区| 欧美精美视频| 精品久久蜜桃| 草莓视频一区二区三区| 亚洲最大成人在线| 狼人综合视频| 国产一区二区三区视频免费| 日韩中文字幕影院| 91精品国产欧美一区二区| 夜夜躁日日躁狠狠久久av| 天天操天天干天天综合网| 精品99在线观看| 自拍偷拍国产亚洲| 亚洲欧美精品久久| 欧美激情在线一区二区| 中文字幕一区二区三区人妻不卡| 不卡高清视频专区| 性活交片大全免费看| 国产精品亚洲综合一区在线观看| 女同激情久久av久久| 免费看欧美美女黄的网站| 成人羞羞国产免费网站| 免播放器亚洲| 国产亚洲精品网站| 久久久久久黄| 人人干人人视频| 日韩成人一级片| 中文字幕在线观看第三页| 水野朝阳av一区二区三区| 免费在线激情视频| 另类av一区二区| 少妇人妻互换不带套| 日韩精品91亚洲二区在线观看| 37pao成人国产永久免费视频| 亚洲精品极品| 日本在线视频www| 日韩电影免费在线看| 最新中文字幕2018| 国产剧情一区二区三区| 香蕉视频1024| av亚洲精华国产精华精| 成年人在线观看av| 国产欧美一二三区| 少妇高潮在线观看| 亚洲精品日韩综合观看成人91| 成年人av电影| 香蕉加勒比综合久久| 在线观看日本视频| 欧美三级电影一区| 国产人妖一区二区| 精品国产免费视频| 日韩三级电影网| 中文字幕不卡在线视频极品| h视频在线免费观看| 久久久爽爽爽美女图片| 欧美18—19sex性hd| 国产精品视频一区二区三区四| 国产精品视频一区二区三区综合| 91手机在线观看| 亚洲综合图色| 亚洲伊人婷婷| 日韩视频精品在线观看| 91色国产在线| 国产成人激情av| 91国模少妇一区二区三区| 中文字幕一区二区三中文字幕| 欧美日韩人妻精品一区二区三区| 欧美日韩在线视频一区| 亚洲综合精品视频| 精品国产电影一区二区| 国产视频网址在线| 欧美黄色小视频| 国产精品亚洲d| 国产高清精品一区| av在线不卡顿| 国产手机免费视频| 久久精品理论片| a天堂视频在线观看| 国产精品久久久一本精品| 日本视频www| 欧美日韩电影一区| 天天爱天天干天天操| 久久久999精品| 日本免费一区二区六区| 成人精品久久av网站| 影视先锋久久| 久久久久福利视频| 蜜臀av一区二区三区| 人妻无码中文久久久久专区| 日韩美女久久久| 日本熟女毛茸茸| 欧美精品一区二区三区久久久| 在线免费看黄网站| 欧洲中文字幕国产精品| 日韩在线观看中文字幕| 亚洲精品中文综合第一页| 国产亚洲高清视频| 亚洲少妇一区二区| 国产精品久久久久久久第一福利| 黑人一级大毛片| 精品久久久久av影院| 欧美性videos| 国产精品久久久久久搜索 | 久久婷婷开心| 很黄很黄激情成人| 超碰中文字幕在线观看| 国产精品免费网站在线观看| 男人的天堂av网站| 亚洲剧情一区二区| 欧美伦理91| 国产视频99| 亚洲国产精品第一区二区| 亚洲av无一区二区三区久久| 中文字幕一区在线观看| 中文字幕一区二区三区波野结| 亚洲天堂免费在线| 欧美日韩免费看片| 欧美日本韩国国产| 国产一级一区二区| 北岛玲一区二区| 舔着乳尖日韩一区| 欧美一级特黄aaaaaa大片在线观看| 超碰97人人做人人爱少妇| 亚洲高清国产拍精品26u| 一区二区av| 久久国产精品无码网站| 日本 欧美 国产| 欧美精品 国产精品| 国产剧情在线| 91久久爱成人| 欧美日本在线| 精品国产免费久久久久久婷婷| 一区二区三区四区视频精品免费| 国产肥老妇视频| 欧美激情在线观看| 九九热hot精品视频在线播放| 国产午夜大地久久| 久久亚洲二区三区| 国产污视频网站| 日韩中文第一页| 在线观看亚洲精品福利片| 99久热在线精品视频| 懂色av一区二区夜夜嗨| 日本一级黄色大片| 国产性色av一区二区| 黄色成人小视频| 欧美大片免费播放| av在线这里只有精品| 天堂网视频在线| 精品国偷自产在线视频99| 欧美日本三级| 野外做受又硬又粗又大视频√| 99re热视频精品| 高潮无码精品色欲av午夜福利| 色婷婷综合久久久久中文字幕1| 蜜桃精品视频| 97成人在线观看视频| 欧美极品美女视频| www国产一区| 欧洲成人免费aa| 欧美gay男男猛男无套| 永久看看免费大片| 婷婷久久综合九色国产成人| 五月香视频在线观看| 成人国产1314www色视频| 久久久久久夜| 欧美在线视频第一页| 日韩精品视频在线观看网址| 成人毛片免费| 国产精品网站免费| 国产精品久久久久三级| 欧美 日韩 人妻 高清 中文| 国产精品h在线观看| 欧美国产免费| 亚洲欧美va天堂人熟伦 | 国产日本欧美在线观看| 激情国产一区| 亚洲色图100p| 日韩精品视频免费专区在线播放 | 成入视频在线观看| 伊人精品久久久久7777| 91免费视频观看| 99久久精品国产成人一区二区| 日本久久久久久久久久久| 欧美激情日韩| 国产探花在线视频| 亚洲欧美中文日韩v在线观看| 国产精品igao视频网网址不卡日韩| 国模吧无码一区二区三区|