# react 类式组件

66 阅读1分钟

react 类式组件

 在之前一篇博客说了 react 的函数组件,今天简单说一下类式组件,什么是类式组件呢? 其实和函数是组件类似。

类式组件简单案例

我们来看一个类式组件的简单案例。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>10.类式组件</title>
</head>

<body>
    <!-- 准备好一个容器 -->
    <div id="app"></div>
    <!-- 引入react核心库 -->
    <script type="text/javascript" src="../js/react.development.js"></script>
    <!-- 引入react-dom 用于支持 react 操作 dom -->
    <script type="text/javascript" src="../js/react-dom.development.js"></script>
    <!-- 引入 label,用于将 jsx 转化为 js -->
    <script type="text/javascript" src="../js/babel.min.js"></script>

    <!-- 此处必须写 text/babel -->
    <script type="text/babel">
        // 1. 创建类式组件
        // 注意:创建类式组件必须继承 React.Component
        class Demo extends React.Component {
            render() {  // render 必须写,并且必须有返回值
                // rander 是放在哪里的?—— 类的原型对象上,供实例使用
                // render 中的 this 是谁? —— Demo 的实例对象,即 Demo组件实例对象。
                return <h1>我是用类式组件定义的组件,适用于复杂组件的定义</h1>
            }
        }

        // 2. 渲染组件到页面
        ReactDOM.render(<Demo />, document.getElementById('app'))

    </script>

</body>

</html>

上边的案例就是一个类式组件的案例, 通过上面的案例,我们可以看见,创建的组件 demo 继承了 react.component ,这个是必须的,必须继承。

在类里面有一个 render 方法,里面必须有返回,不要问为什么,这是规定。

总结一下

执行ReactDOM.render 之后,React 做了两件事情:

  • 第一,解析组件标签,找到 Demo 组件;
  • 第二,发现组件是使用类定义的,随后new出该类实例,并通过改实例调用到原型上的render方法。
  • 第三,将返回的虚拟dom转为真实dom呈现在页面。

今天就到这里,没啥好说的,下面讲一下三大模块,下篇博文开始。拜拜了!

在这里插入图片描述

【本博文相关代码资料】:我是𝒆𝒅. 的 gitee