React 學習之 createElement

来源:https://www.cnblogs.com/QiaoPengjun/p/18120002
-Advertisement-
Play Games

React 學習之 createElement React 元素 在 React 中,元素是 React 應用的最小構建塊。 一個 React 元素是 React 對象的一個輕量級、靜態的表示。 它們被 React 用於知道屏幕上什麼應該被渲染,併在數據改變時保持 UI 的更新。 React 元素是 ...


React 學習之 createElement

React 元素

在 React 中,元素是 React 應用的最小構建塊。
一個 React 元素是 React 對象的一個輕量級、靜態的表示。
它們被 React 用於知道屏幕上什麼應該被渲染,併在數據改變時保持 UI 的更新。

React 元素是不可變的:一旦創建,就不能更改它的子元素或屬性。
一個元素就像電影的單幀:它代表 UI 在某一時間點的樣子。

儘管 React 元素在技術上是一個對象,但它們並不是實際的 DOM 元素。
React 使用這些對象來構建 DOM,併在必要時更新它。
React 元素是 React 的抽象表示,而不是 DOM 的直接表示。

總的來說,React 元素確實可以被視為普通的 JavaScript 對象,但它們在 React 的工作流中扮演著特殊的角色,用於描述 UI 的結構和屬性。

React.createElement

用來創建一個React元素

參數:

  • 標簽名 元素的名稱(HTML標簽必須小寫)
  • 屬性 標簽中的屬性
    • 在設置事件時,屬性名需要修改為駝峰命名法 值為一個函數
    • 例如:onClick 需要修改為 onClick
    • Warning: Invalid DOM property class. Did you mean className? class -> className
  • 子元素 標簽中的子元素
    • 例如:這是一個div 子元素為"這是一個div"
    • 子元素可以是字元串、數字、React元素、數組、布爾值、null、undefined
  • 返回值:一個React元素
  • 註意點:
    • React 元素最終會通過虛擬DOM轉換為真實的DOM元素
    • React 元素是一個普通的JS對象

React.createElement 是 React 庫中的一個函數,用於在 JavaScript 中創建 React 元素。在 JSX 語法被引入之前,React.createElement 是創建 React 組件樹的主要方式。儘管現在 JSX 在 React 社區中非常流行,但理解 React.createElement 仍然很重要,因為它實際上是 JSX 在編譯時轉換為的東西。

React.createElement 函數接受三個參數:

類型 (type):這通常是一個字元串(表示一個 DOM 元素,如 'div' 或 'span')或一個 React 組件類(或函數)。
配置對象 (config):一個可選的對象,包含該元素的 props。
子元素 (children):可以是任何有效的 React 子元素,可以是一個或多個。
示例:

const element = React.createElement(  
  'div',  
  { id: 'myDiv', className: 'myClass' },  
  'Hello, world!',  
  React.createElement('span', null, 'This is a span.')  
);

這個示例創建了一個 div 元素,它有一個 ID 和一個類名,以及兩個子元素:一個文本節點和一個 span 元素。

當你使用 JSX 時,上述代碼可以寫為:

const element = (  
  <div id="myDiv" className="myClass">  
    Hello, world!  
    <span>This is a span.</span>  
  </div>  
);

儘管 JSX 提供了更簡潔、更易於理解的語法,但理解 React.createElement 仍然有助於你理解 React 的底層工作原理。

React createElement 示例

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>React learning</title>
    <script src="script/react.development.js"></script>
    <script src="script/react-dom.development.js"></script>
  </head>

  <body>
    <button id="btn">我是一個按鈕</button>
    <div id="root"></div>

    <script>
      /*

        在 React 中,元素是 React 應用的最小構建塊。一個 React 元素是 React 對象的一個輕量級、靜態的表示。
        它們被 React 用於知道屏幕上什麼應該被渲染,併在數據改變時保持 UI 的更新。

        React 元素是不可變的:一旦創建,就不能更改它的子元素或屬性。一個元素就像電影的單幀:它代表 UI 在某一時間點的樣子。

        儘管 React 元素在技術上是一個對象,但它們並不是實際的 DOM 元素。
        React 使用這些對象來構建 DOM,併在必要時更新它。React 元素是 React 的抽象表示,而不是 DOM 的直接表示。

        總的來說,React 元素確實可以被視為普通的 JavaScript 對象,但它們在 React 的工作流中扮演著特殊的角色,用於描述 UI 的結構和屬性。
        
        React.createElement
            - 用來創建一個React元素
            - 參數:
                - 標簽名 元素的名稱(HTML標簽必須小寫)
                - 屬性 標簽中的屬性
                    - 在設置事件時,屬性名需要修改為駝峰命名法 值為一個函數
                    - 例如:onClick 需要修改為 onClick 
                    - Warning: Invalid DOM property `class`. Did you mean `className`? class屬性需要使用 className 設置
                - 子元素 元素的內容(子元素)
            - 返回值:一個React元素
            - 註意點:
                - React 元素最終會通過虛擬DOM轉換為真實的DOM元素
                - React 元素是一個普通的JS對象
                - React 元素是不可變的,一旦創建,就不能更改它的子元素或者屬性 React 元素一旦創建就無法修改,
                    如果想要修改,只能重新創建新的元素,即只能通過新創建的元素進行替換
        
        */
      // 創建一個React元素
      const button = React.createElement(
        "button",
        {
          id: "btn",
          type: "button",
          className: "hello",
          onClick: () => {
            alert(123);
          },
        },
        "點我一下"
      );

      // 創建一個div
      const div = React.createElement("div", {}, "這是一個div", button);

      // 獲取根元素
      const root = ReactDOM.createRoot(document.getElementById("root"));

      // 將React元素渲染到根元素中 將元素在根元素中顯示
      root.render(div);

      // 獲取按鈕對象
      const btn = document.getElementById("btn");
      btn.addEventListener("click", () => {
        // 點擊按鈕後,修改div中button中的文字為 click me
        const button = React.createElement(
          "button",
          {
            id: "btn",
            type: "button",
            className: "hello",
            onClick: () => {
              alert(123);
            },
          },
          "click me"
        );

        // 創建一個div
        const div = React.createElement("div", {}, "這是一個div", button);

        // 修改React元素後,必須重新渲染React根元素
        // 當調用render渲染頁面時,React會自動比較兩次渲染的元素,只在真實DOM中更新發生變化的部分,沒發生變化的保持不變
        // 這樣可以提高頁面的性能
        // 重新渲染React根元素
        root.render(div);
      });
    </script>
  </body>
</html>

參考

本文來自博客園,作者:尋月隱君,轉載請註明原文鏈接:https://www.cnblogs.com/QiaoPengjun/p/18120002


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

-Advertisement-
Play Games
更多相關文章
  • 一、TextInput/TextArea TextInput和TextArea組件通常用於收集用戶輸入的文本數據。 TextInput組件通常用於單行文本的輸入,它允許用戶通過一個游標來輸入文字,並支持多種樣式和佈局選項來提高用戶體驗。例如,在用戶輸入錯誤時可以顯示錯誤消息或在用戶輸入時自動完成 ...
  • Android 音視頻開發 - VideoView 本篇文章主要介紹下Android 中的VideoView. 1: VideoView簡介 VideoView是一個用於播放視頻的視圖組件,可以方便地在應用程式中播放本地或網路上的視頻文件。 VideoView可以直接在佈局文件中使用,也可以在代碼中 ...
  • Android音視頻開發 - MediaMetadataRetriever 相關 MediaMetadataRetriever 是android中用於從媒體文件中提取元數據新的類. 可以獲取音頻,視頻和圖像文件的各種信息,如時長,標題,封面等. 1:初始化對象 private MediaMetada ...
  • 關鍵詞:Android Framework 動態庫 動態鏈接 Binder 1、事件起因 Android Studio一次更新後發現install App,設備就重啟了,跑了一遍開機動畫但不是從開機第一屏開始重啟,tombstones內容查看發現是surfaceflinger掛在libbinder. ...
  • XPath(XML Path Language)是XSLT標準的主要組成部分。它用於在XML文檔中瀏覽元素和屬性,提供了一種強大的定位和選擇節點的方式。 XPath的基本特點 代表XML路徑語言: XPath是一種用於在XML文檔中導航和選擇節點的語言。 路徑樣式語法: XPath使用路徑表達式的“ ...
  • 一、是什麼 WebSocket,是一種網路傳輸協議,位於OSI模型的應用層。可在單個TCP連接上進行全雙工通信,能更好的節省伺服器資源和帶寬並達到實時通迅 客戶端和伺服器只需要完成一次握手,兩者之間就可以創建持久性的連接,併進行雙向數據傳輸 從上圖可見,websocket伺服器與客戶端通過握手連接, ...
  • 1. Module Module是NestJS 的基本組織單位。 模塊系統基於 Node.js 的 CommonJS 模塊系統,但提供了更高級別的抽象和組織方式。通過使用模塊,你可以將應用程式拆分成多個獨立且可復用的部分,每個模塊都負責實現特定的功能或業務邏輯。 模塊可以封裝相關的代碼、配置和依賴關 ...
  • 使用defineModel時,為什麼子組件內沒有任何關於props的定義和emit事件觸發的代碼?修改defineModel返回值會修改父組件上綁定的變數,這是否破壞了vue的單向數據流呢? ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...