vuejs源码阅读之代码生成器

代码生成器是模版编译的最后以后,它的作用是将AST转换成渲染函数中的内容,这个内容可以称为代码字符串。

代码字符串可以被包装在函数中执行,这个函数就是我们通常说的渲染函数。

渲染函数被执行之后,可以生成一份VNode,而虚拟DOM可以通过这个VNode来渲染视图。

AST生成代码字符串

比如下面这个代码。

复制代码
<div id="el">
    hello {{name}}
</div>

它转换成AST并且经过优化器的优化之后是下面这个样子。

复制代码
{
    "type": 1,
    "tag": "div",
    "attrsList": [
        {
            "name": "id",
            "value": "el",
            "start": 5,
            "end": 12
        }
    ],
    "attrsMap": {
        "id": "el"
    },
    "rawAttrsMap": {
        "id": {
            "name": "id",
            "value": "el",
            "start": 5,
            "end": 12
        }
    },
    "children": [
        {
            "type": 2,
            "expression": "\"\\n        hello \"+_s(name)+\"\\n    \"",
            "tokens": [
                "\n        hello ",
                {
                    "@binding": "name"
                },
                "\n    "
            ],
            "text": "\n        hello {{name}}\n    ",
            "start": 13,
            "end": 41,
            "static": false
        }
    ],
    "start": 0,
    "end": 47,
    "plain": false,
    "attrs": [
        {
            "name": "id",
            "value": "\"el\"",
            "start": 5,
            "end": 12
        }
    ],
    "static": false,
    "staticRoot": false
}

代码生成器可以通过上面这个AST来生成代码字符串,生成后的代码字符串。

复制代码
with (this) {
  return _c('div',
    { attrs: { "id": "el" } },
    [_v("\n        hello " + _s(name) + "\n    ")]
  )
}

仔细观察生成后的代码字符串,这是一个嵌套的函数调用。函数_c的参数中执行了函数_v,而_v的参数中又执行了_s。

这个字符串中_c其实是createElement的别名。createElement是虚拟DOM中所提供的方法,它的作用是创建虚拟节点,有三个参数,分别是:

  • 标签名
  • 一个包含模版相关属性的数据对象
  • 子节点列表
    调用createElement方法,我们可以得到一个VNode。

这也就是是渲染函数可以生成VNode的原因:渲染函数其实是执行了createElement,而createElement可以创建一个VNode。

相关推荐
尘中客2 小时前
放弃 Echarts?前端直接渲染后端高精度 SVG 矢量图流的踩坑记录
前端·javascript·echarts·前端开发·svg矢量图·echarts避坑
FreeBuf_2 小时前
Chrome 0Day漏洞遭野外利用
前端·chrome
小彭努力中2 小时前
199.Vue3 + OpenLayers 实现:点击 / 拖动地图播放音频
前端·vue.js·音视频·openlayers·animate
2501_916007472 小时前
网站爬虫原理,基于浏览器点击行为还原可接口请求
前端·javascript·爬虫·ios·小程序·uni-app·iphone
前端大波3 小时前
Sentry 每日错误巡检自动化:设计思路与上手实战
前端·自动化·sentry
Highcharts.js4 小时前
适合报表系统的可视化图表|Highcharts支持直接导出PNG和PDF
javascript·数据库·react.js·pdf
ZC跨境爬虫4 小时前
使用Claude Code开发校园交友平台前端UI全记录(含架构、坑点、登录逻辑及算法)
前端·ui·架构
慧一居士4 小时前
Vue项目中,何时使用布局、子组件嵌套、插槽 对应的使用场景,和完整的使用示例
前端·vue.js
叫我一声阿雷吧4 小时前
JS 入门通关手册(35):执行上下文、调用栈与作用域链深度解析
javascript·作用域链·js进阶·执行上下文·调用栈·变量提升·闭包原理
Можно4 小时前
uni.request 和 axios 的区别?前端请求库全面对比
前端·uni-app