前端框架原理自测题:根据 JSX / Vue 模板写出 render 函数 / VNode

简介: 前端框架原理自测题:根据 JSX / Vue 模板写出 render 函数 / VNode

JSX

<div className="container">
    <p onClick={onClick} data-name="p1">
        hello <b>{name}</b>
    </p>
    <img src={imgSrc}/>
    <MyComponent title={title}></MyComponent>
</div>

Vue 模板

<div class="container">
    <p @click="onClick" data-name="p1">
        hello <b>{{name}}</b>
    </p>
    <img :src="imgSrc"/>
    <my-component :title="title"></my-component>
</div>

render 函数

技术要点:

  • render 函数即 function render(){}
  • 返回值为 return h() 函数
  • h() 函数的第一个参数为标签、第二个参数为属性事件等组成的对象,第三个参数为子元素数组(用数组是因为子元素有顺序)
  • 标签自带的属性放 props 里(避开关键字 class ,改用 className)
        props: {
            className: 'container'
        },
  • 自定义数据属性放 dataset 里
            dataset: {
                name: 'p1'
            },
  • 事件放 on 里
            on: {
                click: onClick // 变量
            }
  • 子元素为纯变量时
[name]
  • 子组件的写法
h(MyComponent, { // MyComponent 变量
            title: title // 变量
        }, [ /* 无子节点*/ ])

最终答案

function render() {
    return h('div', {
        props: {
            className: 'container'
        },
    }, [
        // <p>
        h('p', {
            dataset: {
                name: 'p1'
            },
            on: {
                click: onClick // 变量
            }
        }, [
            'hello ',
            h('b', {}, [name]) // name 变量
        ])
        
        // <img>
        h('img', {
            props: {
                src: imgSrc // 变量
            }
        }, [ /* 无子节点*/ ])

        // <MyComponent>
        h(MyComponent, { // MyComponent 变量
            title: title // 变量
        }, [ /* 无子节点*/ ])
    ])
}

VNode

技术要点:

  • VNode 是一个对象
  • tag 属性是标签,值为字符串
  • props 属性是标签的属性,值为对象
  • children 属性是子元素,值为数组
  • 原生标签属性(避开关键字 class ,改用 className)
className: 'container'
  • 自定义属性用
dataset: {
    name: 'p1'
},
  • 事件用
on: {
    click: onClick // 变量
}
  • 子元素为纯文本时
'hello ',
  • 属性为空也要写
props: {},
  • 子组件写法
{
    tag: MyComponent, // 变量
    props: {
        title: title // 变量
    },
    children: [ /* 无子节点*/ ]
}

最终答案

const vnode = {
    tag: 'div',
    props: {
        className: 'container'
    },
    children: [
        // <p>
        {
            tag: 'p',
            props: {
                dataset: {
                    name: 'p1'
                },
                on: {
                    click: onClick // 变量
                }
            },
            children: [
                'hello ',
                {
                    tag: 'b',
                    props: {},
                    children: [name] // name 变量
                }
            ]
        },

        // <img>
        {
            tag: 'img',
            props: {
                src: imgSrc // 变量
            },
            children: [ /* 无子节点*/ ]
        },

        // <MyComponent>
        {
            tag: MyComponent, // 变量
            props: {
                title: title // 变量
            },
            children: [ /* 无子节点*/ ]
        }
    ]
}

目录
打赏
0
相关文章
抛弃node和vscode,如何用记事本开发出一个完整的vue前端项目
本文探讨了在不依赖Node和VSCode的情况下,仅使用记事本和浏览器开发一个完整的Vue3前端项目的方法。通过CDN引入Vue、Vue Router、Element-UI等库,直接编写HTML文件实现页面功能,展示了前端开发的本质是生成HTML。虽然日常开发离不开现代工具,但掌握这种基础方法有助于快速实现想法或应对特殊环境限制。文章还介绍了如何用Node简单部署HTML文件到服务器,提供了一种高效、轻量的开发思路。
70 10
前端必须掌握的设计模式——模板模式
模板模式(Template Pattern)是一种行为型设计模式,父类定义固定流程和步骤顺序,子类通过继承并重写特定方法实现具体步骤。适用于具有固定结构或流程的场景,如组装汽车、包装礼物等。举例来说,公司年会节目征集时,蜘蛛侠定义了歌曲的四个步骤:前奏、主歌、副歌、结尾。金刚狼和绿巨人根据此模板设计各自的表演内容。通过抽象类定义通用逻辑,子类实现个性化行为,从而减少重复代码。模板模式还支持钩子方法,允许跳过某些步骤,增加灵活性。
174 11
深入理解前端路由:原理、实现与应用
本书《深入理解前端路由:原理、实现与应用》全面解析了前端路由的核心概念、工作原理及其实现方法,结合实际案例探讨了其在现代Web应用中的广泛应用,适合前端开发者和相关技术人员阅读。
JavaScript前端路由的实现原理及其在单页应用中的重要性,涵盖前端路由概念、基本原理、常见实现方式
本文深入解析了JavaScript前端路由的实现原理及其在单页应用中的重要性,涵盖前端路由概念、基本原理、常见实现方式(Hash路由和History路由)、优点及挑战,并通过实际案例分析,帮助开发者更好地理解和应用这一关键技术,提升用户体验。
153 1
Vue的数据驱动视图与其他前端框架的数据驱动方式有何不同?
总的来说,Vue 的数据驱动视图在诸多方面展现出独特的优势,其与其他前端框架的数据驱动方式的不同之处主要体现在绑定方式、性能表现、触发机制、组件化结合、灵活性、语法表达以及与后端数据交互等方面。这些差异使得 Vue 在前端开发领域具有独特的地位和价值。
122 58
超实用开源前端商城模板,助力电商项目飞速启航!免费直接可用!
分享一款精心设计的开源前端商城模板,涵盖商品展示、购物车、订单处理、用户登录注册等核心功能,使用HTML、CSS、JS和jQuery构建,结构清晰,适合新手和资深开发者,助力电商项目快速启动。
253 0
超实用开源前端商城模板,助力电商项目飞速启航!免费直接可用!
本文将深入探讨 BEM 的概念、原理以及其在前端开发中的应用
BEM(Block-Element-Modifier)是一种前端开发中的命名规范和架构方法,旨在提高代码的可维护性和复用性。通过将界面拆分为独立的模块,BEM 提供了一套清晰的命名规则,增强了代码的结构化和模块化设计,促进了团队协作。本文深入探讨了 BEM 的概念、原理及其在前端开发中的应用,分析了其优势与局限性,为开发者提供了宝贵的参考。
113 8
Jenkins 在前端项目持续部署中的应用,包括其原理、流程以及具体的实现方法
本文深入探讨了Jenkins在前端项目持续部署中的应用,涵盖其基本原理、流程及具体实现方法。首先介绍了Jenkins的基本概念及其在自动化任务中的作用,随后详细解析了从前端代码提交到生产环境部署的全过程,包括构建、测试、部署等关键步骤。最后,强调了持续部署中的代码质量控制、环境一致性、监控预警及安全管理等注意事项,旨在帮助开发者高效、安全地实施持续部署。
108 5
前端大模型应用笔记(五):大模型基础能力大比拼-计数篇-通义千文 vs 文心一言 vs 智谱 vs 讯飞vsGPT
本文对比测试了通义千文、文心一言、智谱和讯飞等多个国产大模型在处理基础计数问题上的表现,特别是通过链式推理(COT)提示的效果。结果显示,GPTo1-mini、文心一言3.5和讯飞4.0Ultra在首轮测试中表现优秀,而其他模型在COT提示后也能显著提升正确率,唯有讯飞4.0-Lite表现不佳。测试强调了COT在提升模型逻辑推理能力中的重要性,并指出免费版本中智谱GLM较为可靠。
143 0
前端大模型应用笔记(五):大模型基础能力大比拼-计数篇-通义千文 vs 文心一言 vs 智谱 vs 讯飞vsGPT

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等