建立你自己的react(二)----createElement方法

前端

这是我们手写react的第二季,这篇文章还是非常浅显易懂的,大家学习以后可以讲给不会的人听,那样学习效率会更高

createElement函数

让我们继续我们的应用程序,这次我们将替换react代码为我们自己的react版本

我们将开始写我们自己的createElement

让我们转换这个jsx为js,所以我们可以看到这个createElement方法的调用。

js 复制代码
const element = React.createElement(
    "div",
    { id: "foo" },
    React.createElement("a", null, "bar"),
    React.createElement("b")
)

正如前面步骤中看到的,element是一个具有type和props的对象。我们的函数仅仅需要做的是创建这个对象。

我们对props使用展开运算符,对子元素使用剩余参数语法,这样子元素属性将始终是一个数组。

例如:

  • createElement("div") 返回
js 复制代码
{
  "type": "div",
  "props": { "children": [] }
}
  • createElement("div", null, a) 返回
js 复制代码
{
  "type": "div",
  "props": { "children": [a] }
}
  • createElement("div", null, a, b) 返回:
json 复制代码
{
  "type": "div",
  "props": { "children": [a, b] }
}

children 数组也可以包含原始的值像字符串和数字。所以我们将包裹不是一个对象的内容在他自己的元素内,并且对他们创建一个特殊的类型:TEXT_ELEMENT

当children为空的时候,react并不会包裹原始的值或者创建一个空数组,但是这样做可以使我们简化代码,对于我们的库,我们更喜欢简单的代码,而不是性能好的代码。

我们将使用react的createElement

为了代替他,让我们赐予我们库一个名字。我们需要一个听起来像react的名字。

我们可以叫他Didact

js 复制代码
const Didact = {
 createElement,
}

但是我们仍然想要在这里使用JSX。我们如何告诉babel去使用Didact的createElement替换React的createElement呢?

如果我们有一个像这样的注释

js 复制代码
/** @jsx Didact.createElement */
const element = (
<div id="foo">
    <a>bar</a>
    <b />
</div>
)

那么babel编译这个jsx的时候将使用我们定义的方法

参考

相关推荐
QQ1__8115175153 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态3 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子3 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室3 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI3 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing3 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者3 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册3 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李3 小时前
2026 年 Web 前端开发的 8 个趋势!
前端
里欧跑得慢3 小时前
15. Web可访问性最佳实践:让每个用户都能平等访问
前端·css·flutter·web