实现一个递归渲染函数 Render

这段代码实现了一个递归渲染函数 Render,用于将一个简单的虚拟 DOM 树结构渲染成真实的 DOM 节点并挂载到指定的根元素 root 上。以下是函数中每一部分的解释:

  1. 创建元素:

    ini 复制代码
    const el = document.createElement(obj.tag);

    根据 obj.tag 创建一个对应的 HTML 元素。例如,如果 obj.tag'div',这行代码会创建一个 <div> 元素。

  2. 处理 children 为文本的情况:

    ini 复制代码
    if (typeof obj.children === 'string') {
        const text = document.createTextNode(obj.children);
        el.appendChild(text);
    }

    如果 obj.children 是字符串类型,则它是一个文本节点。使用 document.createTextNode 创建一个文本节点,并将其作为子节点添加到当前的元素 el 中。

  3. 处理 children 为数组的情况(递归渲染子节点):

    scss 复制代码
    else if (obj.children) {
        obj.children.forEach((child) => Render(child, el));
    }

    如果 obj.children 是一个数组,则递归调用 Render 函数,对每一个子对象进行渲染。将当前元素 el 作为根元素传递,子节点会被添加到当前元素中。

  4. 将元素添加到根节点:

    ini 复制代码
    root.appendChild(el);

    最后,将创建好的元素 el 添加到传入的根节点 root 中。

函数运行流程举例

对于下面的虚拟 DOM 结构:

css 复制代码
const obj = {
    tag: 'div',
    children: [
        { tag: 'span', children: 'hello world' }
    ]
};
  1. Render 被调用,创建一个 <div> 元素。
  2. 发现 obj.children 是一个数组,递归调用 Render,处理子节点 { tag: 'span', children: 'hello world' }
  3. 子节点的 tag'span',创建一个 <span> 元素。
  4. 子节点的 children 是字符串 'hello world',创建一个文本节点并添加到 <span> 中。
  5. <span> 添加到父节点 <div> 中。
  6. 最后将整个 <div> 挂载到传入的根节点 root 中。

渲染结果

在页面中生成的 HTML 结构为:

css 复制代码
<div>
    <span>hello world</span>
</div>
相关推荐
周周爱喝粥呀44 分钟前
【基础】Three.js 实现 3D 字体加载与 Matcap 金属质感效果(附案例代码)
前端·javascript·vue.js·3d
克喵的水银蛇1 小时前
Flutter 通用输入框封装实战:带校验 / 清除 / 密码切换的 InputWidget
前端·javascript·flutter
2501_915909061 小时前
Fiddler抓包与接口调试实战,HTTPHTTPS配置、代理设置与移动端抓包详解
前端·测试工具·ios·小程序·fiddler·uni-app·webview
我命由我123452 小时前
微信小程序开发 - 为 tap 事件的处理函数传递数据
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
百万蹄蹄向前冲5 小时前
Trae Genimi3跟着官网学实时通信 Socket.io框架
前端·后端·websocket
狂炫冰美式6 小时前
TRAE SOLO 驱动:重构AI模拟面试产品的复盘
前端·后端·面试
1024肥宅8 小时前
JavaScript 拷贝全解析:从浅拷贝到深拷贝的完整指南
前端·javascript·ecmascript 6
欧阳天风8 小时前
js实现鼠标横向滚动
开发语言·前端·javascript
局i9 小时前
Vue 指令详解:v-for、v-if、v-show 与 {{}} 的妙用
前端·javascript·vue.js
码界奇点9 小时前
Java Web学习 第15篇jQuery从入门到精通的万字深度解析
java·前端·学习·jquery