Vue 源码阅读(八) JSX

栏目: 编程语言 · 发布时间: 6年前

内容简介:Vue 推荐在绝大多数情况下使用模板来创建你的 HTML。然而在一些场景中,你真的需要 JavaScript 的完全编程的能力。这时你可以用渲染函数,它比模板更接近编译器。渲染函数在某些场景下,编写时没有模板直观、简单。这就是为什么会有一个

介绍

Vue 推荐在绝大多数情况下使用模板来创建你的 HTML。然而在一些场景中,你真的需要 JavaScript 的完全编程的能力。这时你可以用渲染函数,它比模板更接近编译器。

渲染函数在某些场景下,编写时没有模板直观、简单。

这就是为什么会有一个 Babel 插件 ,用于在 Vue 中使用 JSX 语法,它可以让我们回到更接近于模板的语法上。

起因

在官方给的 使用文档 中,只是简单的介绍了一些基础用法,使用过程中遇到如下问题:

ElementUI 中 Form 组件有一个叫做 model 的 props,通常会这么写 JSX :

{
    render() {
        <el-form model={{ }}>
            ...
        </el-form>
    }
}

通过 Vue DevTools,可以查看到 Form 组件绑定的 model 值为 undefined

分析

查看 源码 时,可以发现 model 是 root attributes,被当做 attributes 而不是 props

const rootAttributes = ['staticClass', 'class', 'style', 'key', 'ref', 'refInFor', 'slot', 'scopedSlots', 'model']

// ...

if (rootAttributes.includes(name)) {
    attributes[name] = value
} else {
    
}

解决方案

设计组件 props 时,应该避免使用 rootAttributes 包含的值。如果已经那么设计,可以这样处理:

{
    render() {
        <el-form props={{ model: { } }}>
            ...
        </el-form>
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

失业的程序员

失业的程序员

沈逸 / 2014-5-1 / 39.00元

这是一个程序员从失业到自行创业的奋斗历程,虽然囧事连连、过程曲折,却充满了趣味。本书以作者的真实创业经历为主线,文字幽默诙谐,情节生动真实,包括了招聘、团队管理和用户公关,以及技术架构设计、核心代码编写、商务谈判、项目运作等场景经验。 从初期的创业伙伴、领路人,到商业竞争对手,各种复杂的关系在各个关键时刻却都发生了意想不到的逆转。在历经千辛万苦,眼看快要成功时,主人公却几乎再次失业。 ......一起来看看 《失业的程序员》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

在线进制转换器
在线进制转换器

各进制数互转换器

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具