React基础-JSX的本质-虚拟DOM的创建过程实例分析(react 入门教程)干货满满

随心笔谈12个月前发布 admin
87 0



实际上,jsx仅仅只是 这个函数的语法糖

所有的jsx最终都会被转换成React.createElement的函数调用。

createElement需要传递三个参数:

当前元素的类型;

如果是标签元素,那么就使用字符串表示, 例如 “div”;

如果是组件元素,那么就直接使用组件的名称;

所有jsx中的属性都在config中以对象的属性和值的形式存储;

比如传入className作为元素的class;

存放在标签中的内容,以children数组的方式进行存储;

当然,如果是多个元素呢?React内部有对它们进行处理,处理的源码在下方

在这里插入图片描述

我们知道默认jsx是通过babel帮我们进行语法转换的,所以我们之前写的jsx代码都需要依赖babel; 我们可以在babel的官网中快速查看转换的过程: 链接: https://babeljs.io/repl/#?presets=react

例如有下面这样一段jsx代码

class App extends React.Component {
constructor() {
super()
}
render() {
return (
<div>
<div className=”header”>Header</div>
<div className=”content”>
<div>Banner</div>
<ul>
<li>轮播图1</li>
<li>轮播图2</li>
<li>轮播图3</li>
<li>轮播图4</li>
<li>轮播图5</li>
</ul>
</div>
<div className=”footer”>Footer</div>
</div>
)
}
}
const app=ReactDOM.createRoot(document.querySelector(“#app”))
app.render(<App/>)

在这里插入图片描述

那么也就是说我们可以自己来编写React.createElement代码:

我们没有通过jsx来书写了,界面依然是可以正常的渲染。

另外,在我们编写原生的React情况下,我们就不需要babel相关的内容了(当然真实开发中我们是不会编写原生的React的)

所以,type=”text/babel”可以被我们删除掉了;所以,也可以被我们删除掉了;

<div></div>
<script src=”https://www.jb51.net/lib/https://www.jb51.net/lib/react.js”></script>
<script src=”https://www.jb51.net/lib/react-dom.js”></script>
<script>
class App extends React.Component {
constructor() {
super()
}
render() {
const element=React.createElement(“div”, null, React.createElement(“div”, {
className: “header”
}, “Header”), React.createElement(“div”, {
className: “content”
}, React.createElement(“div”, null, “Banner”), React.createElement(“ul”, null, React.createElement(“li”, null, “轮播图1”), React.createElement(“li”, null, “轮播图2”), React.createElement(“li”, null, “轮播图3”), React.createElement(“li”, null, “轮播图4”), React.createElement(“li”, null, “轮播图5”))), React.createElement(“div”, {
className: “footer”
}, “Footer”));
return element
}
}
const app=ReactDOM.createRoot(document.querySelector(“#app”))
app.render(React.createElement(App, null))
</script>

我们通过 React.createElement 最终创建出来一个 ReactElement对象:

这个ReactElement对象是什么作用呢?React为什么要创建它呢?

原因是React利用ReactElement对象组成了一个JavaScript的对象树;

JavaScript的对象树就是虚拟DOM(Virtual DOM);

如何查看ReactElement的树结构呢?

我们可以将上面代码中的jsx返回结果进行打印;

在这里插入图片描述

**而ReactElement最终形成的树结构就是虚拟DOM (Virtual DOM) **;

虚拟DOM帮助我们从命令式编程转到了声明式编程的模式

React官方的说法:Virtual DOM 是一种编程理念

在这个理念中,UI以一种理想化或者说虚拟化的方式保存在内存中,并且它是一个相对简单的JavaScript对象

我们可以通过让 虚拟DOM 和 真实DOM同步起来,这个过程中叫做(Reconciliation);

这种编程的方式赋予了React声明式的API:

你只需要告诉React希望让UI是什么状态;

React来确保DOM和这些状态是匹配的;

你不需要直接进行DOM操作,就可以从手动更改DOM、属性操作、事件处理中解放出来;

 PS:笔者在进行相关测试或开发的时候比较喜欢实用vite搭建vue或react的运行环境,使用命令  创建基本的项目框架,再进行相关调试。

理解虚拟DOM有助于我们更加深入的理解react、vue等框架的运行原理。

您可能感兴趣的文章:Vue响应式原理与虚拟DOM实现步骤详细讲解React之虚拟DOM的实现原理Vue中简单的虚拟DOM是什么样Vue虚拟dom被创建的方法Vue源码分析之虚拟DOM详解vue 虚拟DOM快速入门react中的虚拟dom和diff算法详解vue 虚拟DOM的原理详解操作虚拟dom模拟react视图渲染浅谈React的最大亮点之虚拟DOMReact?JSX深入浅出理解React jsx转换与createElement使用超详细讲解React详细讲解JSX和组件的使用

© 版权声明

相关文章