Web3

2025年07月12日更新 6 人订阅
原价: ¥ 10 限时优惠
专栏简介 Web3 学习之私钥保护 ——将私钥导入加密密钥库 Web3实战:使用web3modal SDK实现钱包连接并部署在Vercel React 学习之 createElement Web3 学习之钱包与链上交易速度问题以及与传统交易系统的对比 Web3 学习之GAS 机制与手续费详解 Web3学习之去中心化交易所(DEX) Web3学习之Uniswap Web3学习之Uniswap V2 的手续费计算 Web3学习之 ERC20 Web3学习之使用Foundry开发部署和开源ERC20合约 Foundry 高级实战:实现一个可升级的工厂合约 UpgradeableTokenFactory 升级合约源码分析 OpenZeppelin Foundry Upgrades upgradeProxy 深入解析 Uniswap V2 的手续费计算:公式推导与代码详解 全面指南:构建与部署以太坊多签钱包(MultiSigWallet)智能合约的最佳实践 利用 Chainlink Automation 自动化 Bank 合约:使用 Solidity 实现动态存款管理和自动转账 利用 Chainlink VRF 实现100 Token抽奖:从名单中随机选出幸运得主的完整指南 Op-Stack架构全景图:Layer 2 架构详解 钱包地址生成和作用 浏览器扩展、网页工具 require,revert,和assert的使用场景分别是什么样的? library 在使用上有什么限制 fallback 如何防范 ApproveScam 漏洞 透明代理 vs UUPS:智能合约升级模式全景解析与实用指南 MPC钱包和多签钱包的区别:一文看懂 BIP39和BIP44:你的加密货币钱包安全基石 Qtum 量子链:UTXO 交易的深度解析与实操指南 探索数据库系统:从概念到应用的全景概览 Solidity on Polkadot: Web3 实战开发指南 Web3 实践:在 Polkadot 上用 Solidity 玩转 Delegatecall Web3 新星:Monad 打造 NFT 全解 Ethers.js 实战:带你掌握 Web3 区块链开发 Web3 开发入门:用 Ethers.js 玩转以太坊交易与合约 玩转 Web3:用 Viem 库实现以太坊合约部署与交互 Web3新速度:Monad与BuyEarth DApp重塑虚拟世界 Web3开发必知:Solidity内存布局(Storage、Memory、Stack)解析 以太坊大变革:Vitalik 提议用RISC-V重塑未来! Web3实战:打造属于你的NFT数字资产 Web3 数据索引新利器:用 The Graph 打造 NFT 市场子图全攻略 用 Python 解锁 Web3:以太坊日志解析实战 Web3 数据神器:用 Go 解锁以太坊事件解析 用 Rust 解锁 Web3:以太坊事件解析实战 Web3 实战:解锁 Monad MCP,轻松查询 MON 余额 Web3 开发神器:Arbitrum Stylus 智能合约全攻略 解锁Web3未来:Rust与Solidity智能合约实战 Web3 新体验:Blink 一键解锁 Monad 未来 Alloy 赋能 Web3:Rust 区块链实战 Web3 开发实战:用 Foundry 高效探索以太坊区块链 Web3 金融:Uniswap V2 资金效率深度剖析 Uniswap V3 流动性机制与限价订单解析:资金效率提升之道 用 Rust 打造 Web3 区块链浏览器:从零开始的实战指南 探索Web3新速度:Sonic高性能Layer-1上的BlindAuction智能合约实践 Uniswap V2 合约部署全攻略:Web3 实践指南 重磅!国家级智库为人民币稳定币“出招”,上海香港或将联动!

React 学习之 createElement

React 学习之 createElement

React 元素

在 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>

参考

点赞 0
收藏 0
分享
本文参与登链社区写作激励计划 ,好文好收益,欢迎正在阅读的你也加入。

0 条评论

请先 登录 后评论