React 学习之 createElement

这篇具有很好参考价值的文章主要介绍了React 学习之 createElement。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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 的底层工作原理。文章来源地址https://www.toymoban.com/news/detail-844274.html

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>

参考

  • React 官方中文文档 https://react.docschina.org/

到了这里,关于React 学习之 createElement的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • web前端之多行文本擦除效果、文本逐个显示或展示、创建元素标签、querySelector、createElement、appendChild、requestAnimationFrame

    前言 window.requestAnimationFrame()告诉浏览器——你希望执行一个动画,并且要求浏览器在下次重绘之前调用指定的回调函数更新动画。该方法需要传入一个回调函数作为参数,该回调函数会在浏览器下一次重绘之前执行。 备注:若你想在浏览器下次重绘之前继续更新下一帧动画

    2024年03月24日
    浏览(12)
  • uni-app:Uncaught TypeError: Cannot read property ‘createElement‘ of undefined移动端调试基座白屏报错问题

    uni-app:Uncaught TypeError: Cannot read property ‘createElement‘ of undefined移动端调试基座白屏报错问题

    云打包后也是白屏!!!    这里打包后在手机上安装启动后一样白屏而且还看不到报错!!手机模拟器基座调试运行后可以看到报错,所以这里建议用手机模拟器基座调试!!! 手机模拟器基座调试: 手机打开开发人员选项后打开USB调试: 开发人员选项这里因为每个手机

    2024年02月13日
    浏览(11)
  • 6、机器学习之随机森林

    使用更复杂的机器学习算法。 本课程所需数据集夸克网盘下载链接:https://pan.quark.cn/s/9b4e9a1246b2 提取码:uDzP 决策树给你留下了一个困难的选择。一个深度很大、有很多叶子的树会因为每个预测都来自其叶子上仅有的几个房屋的历史数据而过拟合。但是一个浅树,叶子较少,

    2024年01月19日
    浏览(9)
  • 深度学习之反向传播

    (在pytorch包中)Tensor数据成员:data(存放数据w,也是Tensor变量,但是取data不会构建计算图)和grad(存放梯度loss对w的导,调用bacward之后grad也是个Tensor,每次引用结束要zero) backward会释放计算图,每一次运行神经网络时计算图可能是不同的,所以没进行一次反向传播就释放

    2024年02月16日
    浏览(9)
  • 大数据学习之Hadoop

    大数据学习之Hadoop

    ​​​​​ 1.分布式:将多台服务器集中在一起,每台服务器都能实现整个中的不同的业务,可以做不同的事。 举例:做一顿年夜饭,一个人的话花费时间会很久,但我可以多叫两个人来帮助我,一个人去买菜,一个人切菜,一个人炒菜,这样做完年夜饭的效率就大大提高了

    2024年02月02日
    浏览(3)
  • 大数据学习之HiveSQL

    大数据学习之HiveSQL

    数据定义语言 (Data Definition Language, DDL),是SQL语言集中对数据库内部的对象结构进行创建,删除,修改等的操作语言,这些数据库对象包括database(schema)、table、view、index等。核心语法由 CREATE 、 ALTER 与 DROP 三个所组成。DDL并不涉及表内部数据的操作。 2.1 完整建表语法树 蓝

    2024年02月07日
    浏览(3)
  • Python学习之-分支语句

    任务描述: 从键盘输入年份t,如果年份t 能被 400整除,或者能被4整除但不能被100整除,则输出“t年是 闰年”,否则输出“t年不是闰年”,t用输入的年份代替。 任务描述: 满足以下两个条件之一: (1)25岁及以下且是重点大学“金融工程”专业的应届学生。 (2)具备至少

    2023年04月24日
    浏览(10)
  • Python综合练习之图表

    Python综合练习之图表

    Python学习了约一个月的时间,这是一篇综合练习的文章。主要做的内容是通过封装对象、实现抽象方法生成统计图、数据表格的功能。 是我的csdn文章的标题、得分、阅读量的数据 这个模块相当于我要对外开放的接口汇总,其中包含了: init :构造函数 time_bar:生成统计图的

    2024年01月19日
    浏览(8)
  • 机器学习之支持向量机

    实现如下: 输出结果: 得出sigmoid分类后,结果很差 对数据进行处理,归一化处理后,在进行分类: 输出结果: 我们会发现除了sigmoid都提升了准确性rbf不擅长处理数据分布不均匀的情况。

    2024年02月05日
    浏览(10)
  • 机器学习之逻辑回归

    机器学习之逻辑回归

    1.1 监督学习 1.1.1 回归(线性回归) 1.1.1.1 描述 线性回归模型公式: 多元线性关系:一个通过特征的的线性组合来进行预测的函数 其中,h(x)是因变量,x1、x2、…、xn是自变量,o1、o2、…、bn是回归系数。回归系数表示自变量对因变量的影响程度,可以通过最小二乘法来求解

    2023年04月13日
    浏览(9)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包