React教程:4 個 useState Hook 示例

来源:https://www.cnblogs.com/fundebug/archive/2019/08/22/4-react-usestate-hook-examples.html
-Advertisement-
Play Games

摘要: React示例教程。 原文: "快速瞭解 React Hooks 原理" 譯者:前端小智 到 React 16.8 目前為止,如果編寫函數組件,然後遇到需要添加狀態的情況,咱們就必須將組件轉換為類組件。 編寫 ,將函數體複製到 方法中,修複縮進,最後添加需要的狀態。 今天,可以使用 Hook ...


摘要: React示例教程。

到 React 16.8 目前為止,如果編寫函數組件,然後遇到需要添加狀態的情況,咱們就必須將組件轉換為類組件。

編寫 class Thing extends React.Component,將函數體複製到render()方法中,修複縮進,最後添加需要的狀態。

今天,可以使用 Hook 獲得相同的功能,併為自己節省了工作時間。在本文中,主要介紹useState hook。

useState 做啥子的

useState hook 允許咱們向函數組件添加狀態,我們通常稱這些為“ hooks”,但它們實際上是函數,與 React 16.8 捆綁在一起。 通過在函數組件中調用useState,就會創建一個單獨的狀態。

在類組件中,state 總是一個對象,可以在該對象上添加保存屬性。

對於 hooks,state 不必是對象,它可以是你想要的任何類型-數組、數字、布爾值、字元串等等。每次調用useState都會創建一個state塊,其中包含一個值。

示例1:使用 useState 顯示/隱藏組件

這個示例是一個組件,它顯示一些文本,併在末尾顯示一個read more鏈接,當單擊鏈接時,它展開剩下的文本。

    import React, { useState } from 'react';
    import ReactDOM from 'react-dom';
    
    // 兩個 props:
    //   text - 顯示的內容
    //   maxLength - 在點擊“read more”之前顯示多少個字元
    function LessText({ text, maxLength }) {
      // 創建一個狀態,並將其初始化為“true”
      const [hidden, setHidden] = useState(true);
    

      if (text <= maxLength) {
        return <span>{text}</span>;
      }
    
      return (
        <span>
          {hidden ? `${text.substr(0, maxLength).trim()} ...` : text}
          {hidden ? (
            <a onClick={() => setHidden(false)}> read more</a>
          ) : (
            <a onClick={() => setHidden(true)}> read less</a>
          )}
        </span>
      );
    }
    
    ReactDOM.render(
      <LessText
        text={`專註、努力是成功的真正關鍵。把你的眼睛盯在目標上,然後朝著目標邁出下一步`}
        maxLength={35}
      />,
      document.querySelector('#root')
    );

僅用一行代碼,我們就使這個函數組件有狀態:

    const [hidden, setHidden] = useState(true);

但是這個函數到底在做什麼呢?如果每次渲染都調用它(確實如此),它又是如何保留狀態的。

Hooks 實現的技巧

這裡的“神奇”之處是,React在每個組件的幕後維護一個對象,並且在這個持久對象中,有一個“狀態單元”數組。當你調用useState時,React將該狀態存儲在下一個可用的單元格中,並遞增數組索引。

假設你的 hooks 總是以相同的順序調用(如果遵循 hooks 的規則,它們將是相同的順序),React能夠查找特定useState調用的前一個值。對useState的第一個調用存儲在第一個數組元素中,第二個調用存儲在第二個元素中,依此類推。

這也不是很神奇的事情,主要它依賴於你可能沒有想過的事實:咱們寫的的組件是由React調用 ,所以它可以在調用組件之前事先做好一些工作。 而且,渲染組件的行為不僅僅是函數調用。 像<Thing />這樣的JSX被編譯為React.createElement(Thing) - 顯然 React 可以控制它的調用方式和時間。

示例2:根據之前的狀態更新狀態

看看另一個例子:根據前一個值更新state的值。

咱們要造個計步器,每點擊一次按鈕,就計一次,點擊完後,它會告訴你你走了多少步。

    import React, { useState } from 'react';
    
    function StepTracker() {
      const [steps, setSteps] = useState(0);
    
      function increment() {
        setSteps(steps => steps + 1);
      }
    
      return (
        <div>
          總共走了 {steps} 步!
          <br />
          <button onClick={increment}>
            點點我,步數不是個事!
          </button>
        </div>
      );
    }
    
    ReactDOM.render(
      <StepTracker />,
      document.querySelector('#root')
    );

首先,通過調用useState創建一個新的state,並將其初始化為0。它返回steps的當前值0setSteps函數來更新 steps,用 increment函數來對steps進行增 1 操作。

這裡還可以優化的提取increment函數,可以直接將 increment 函數裡面的內聯到 onClick 裡面:

    <button onClick={() => setSteps(steps => steps + 1)}>
      I took another step
    </button>

示例3: state 作為數組

記住,state可以保存任何你想要的值。下麵是一個隨機數列表的例子,單擊按鈕將向列表添加一個新的隨機數:

    function RandomList() {
      const [items, setItems] = useState([]);
    
      const addItem = () => {
        setItems([
          ...items,
          {
            id: items.length,
            value: Math.random() * 100
          }
        ]);
      };
    
      return (
        <>
          <button onClick={addItem}>Add a number</button>
          <ul>
            {items.map(item => (
              <li key={item.id}>{item.value}</li>
            ))}
          </ul>
        </>
      );
    }

註意,我們state初始化為空數組[],併在addItem函數中更新值。

setItems 更新 state 不會將舊值“合併” - 它會使用新值覆蓋state。 這與this.setState在類中的工作方式不同。

示例4:具有多個鍵的 state

再來看看,state為對象的例子,創建一個包含2個欄位的登錄表單:usernamepassword

下麵示例主要展示如何在一個state對象中存儲多個值,以及如何更新單個值。

    function LoginForm() {
      const [form, setValues] = useState({
        username: '',
        password: ''
      });
    
      const printValues = e => {
        e.preventDefault();
        console.log(form.username, form.password);
      };
    
      const updateField = e => {
        setValues({
          ...form,
          [e.target.name]: e.target.value
        });
      };
    
      return (
        <form onSubmit={printValues}>
          <label>
            Username:
            <input
              value={form.username}
              name="username"
              onChange={updateField}
            />
          </label>
          <br />
          <label>
            Password:
            <input
              value={form.password}
              name="password"
              type="password"
              onChange={updateField}
            />
          </label>
          <br />
          <button>Submit</button>
        </form>
      );
    }

如果想試試,可查看 CodeSandbox

首先,我們創建一個state片段,並用一個對象初始化它

    const [form, setValues] = useState({
      username: '',
      password: ''
    })

這看起來像是在類中初始化狀態的方式。

還有一個處理提交的函數,其中,e.preventDefault來阻止頁面刷新並列印出表單值。

updateField函數更有意思。它使用setValues傳遞一個對象,為了確保現有的狀態不被覆蓋,這裡使用了展開運算(...form)。

代碼部署後可能存在的BUG沒法實時知道,事後為瞭解決這些BUG,花了大量的時間進行log 調試,這邊順便給大家推薦一個好用的BUG監控工具 Fundebug

原文:https://daveceddia.com/usestate-hook-examples/

關於Fundebug

Fundebug專註於JavaScript、微信小程式、微信小游戲、支付寶小程式、React Native、Node.js和Java線上應用實時BUG監控。 自從2016年雙十一正式上線,Fundebug累計處理了20億+錯誤事件,付費客戶有陽光保險、核桃編程、荔枝FM、掌門1對1、微脈、青團社等眾多品牌企業。歡迎大家免費試用


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 瀏覽器 1. shell: 外殼 2. core: 內核(JS執行引擎,渲染引擎) IE: Trident Firefox: Gecko Chrome: Webkit / Blink safari: Webkit opera: Presto / Blink ...
  • 1、什麼是預解析? 在當前作用域下,JS 運行之前,會把帶有 var 和 function 關鍵字的事先聲明,併在記憶體中安排好。(這個過程也可以理解為變數提升)然後再從上到下執行 JS 語句(預解析只會發生在通過 var 定義的變數和 function 上) 2、var 聲明的變數 使用 var 聲 ...
  • JavaScript 誕生於1995年,它的出現主要是用於處理網頁中的 前端驗證。 • 所謂的前端驗證,就是指檢查用戶輸入的內容是否符合一定的 規則。 • 比如:用戶名的長度,密碼的長度,郵箱的格式等。 JavaScript是由網景公司發明,起初命名為LiveScript,後來由 於SUN公司的介入 ...
  • css作用:控制網頁的樣式 css語法: 選擇符{ 屬性1:屬性值; 屬性2:屬性值; 屬性3:屬性值1 屬性值2 屬性值3; } css實例: div{ width:300px; height:400px; background:red; } css語法解釋: 1、選擇符:對標簽進行獲取 2、所有 ...
  • 預解析指的就是,在js文件或者script裡面的代碼在正式開始執行之前,進行的一些解析工作。這個工作很簡單,就是在全局中尋找var關鍵字聲明的變數和通過function關鍵字聲明的函數。 1.尋找 var function 參數 等關鍵字,根據var a提前設置為 a=未定義(undefined)  ...
  • 今天詳細講解JavaScript中的常用事件類型和功能。 一 滑鼠事件 1, click:點擊事件 等同於mousedown+mouseup,不管這兩個事件間隔多久,都會觸發一次click事件。 2, mousedown:滑鼠按下事件 3, mouseup:滑鼠彈起事件 4, mouseover/m ...
  • 問題:在H5中,我們有這樣的需求:例如有列表的時候,滾動到底部時,需要載入更多。 解決方案:可以採用window的滾動事件進行處理 分析:如果滾動是針對整個屏幕而言的(不針對於某個界面小塊),那麼這個應該是是成立的:屏幕的高度+最大滾動的距離 = 內容的高度 代碼實現: 代碼的相關說明:很多時候,列 ...
  • 百度防抖與節流,一直沒搞懂防抖與節流的區別,然後google了一下,(google大法好 _(:з」∠)_)個人理解了一下 1,比較正式的解釋他們的區別: 防抖:就是指觸發事件後在 n 秒內函數只能執行一次,如果在 n 秒內又觸發了事件,則會重新計算函數執行時間,防抖註重結果 節流::是讓一個函數無 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...