内容简介: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> } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 【源码阅读】AndPermission源码阅读
- 【源码阅读】Gson源码阅读
- 如何阅读Java源码 ,阅读java的真实体会
- 我的源码阅读之路:redux源码剖析
- JDK源码阅读(六):HashMap源码分析
- 如何阅读源码?
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Java程序设计与应用开发
於东军 / 清华大学出版社 / 2005-3 / 27.00元
本书作为Java程序的入门与应用教材,共分为3部分:第一部分讲解Java程序设计的基础知识,包括Java基本编程语言、面向对象设计思想、类、对象、接口以及异常处理。第二部分讲解Java程序设计的高级知识,包括:GUI编程、套接口编程、I/O系统、数据库访问以及多线程编程。第三部分详细分析一个实际项目的开发过程,包括系统分析及功能实现。在项目实例中综合应用第一、二部分的Java知识,能够帮助读者进一......一起来看看 《Java程序设计与应用开发》 这本书的介绍吧!