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