若是使用render函数来写比较复杂的vue组件,对于可读性和可维护性都很不友好,而使用jsx就会让咱们回到更接近于模板的语法。babel转译器会将jsx转译为render函数渲染。vue
配置node
须要用到babel插件react
安装npm
1编程 2babel 3dom 4ide 5函数 6this |
|
.babelrc配置
在plugins中添加transform-vue-jsx
1 2 3 4 |
|
基础示例
转义前
1 |
|
转译后
1 2 3 4 5 |
|
Note:h
函数为vue实例的$createElement
方法,必须存在于jsx的做用域中,在渲染函数中必须以第一个参数传入,如:
1 2 3 |
|
自动注入h函数
从3.4.0开始,在用ES2015语法声明的方法和getter
访问器中(使用function
关键字或箭头函数除外),babel会自动注入h
(const h = this.$createElement
)函数,因此能够省略(h)参数。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
|
Vue JSX 和 React JSX对比
首先, Vue2.0 的vnode 格式与react不一样,createElement
函数的第二个参数是一个数据对象,接受一个嵌套的对象,每个嵌套对象都会有对应的模块处理。
Vue2.0 render语法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 |
|
对应的Vue2.0 JSX语法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
|
JSX展开运算符
支持JSX展开,插件会智能的合并数据属性,如:
1 2 3 4 |
|
合并后的数据为:
1 |
|
Vue 指令
JSX对大多数的Vue内建指令都不支持,惟一的例外是v-show
,该指令能够使用v-show={value}
的语法。大多数指令均可以用编程方式实现,好比v-if
就是一个三元表达式,v-for
就是一个array.map()
等。
若是是自定义指令,能够使用v-name={value}
语法,可是改语法不支持指令的参数arguments
和修饰器modifier
。有如下两个解决方法:
将全部内容以一个对象传入,如:v-name={{ value, modifier: true }}
使用原生的vnode指令数据格式,如:
1 2 3 4 5 |
|