本文最后更新于 1746 天前,其中的信息可能已经有所发展或是发生改变。
render: h => h(App)含义?
看代码我自己看出这个分为两个知识点:
一个是vue render的知识点;另外一个是es6的箭头函数知识点~
首先render是一个渲染函数,直接到vue看文档:https://cn.vuejs.org/v2/guide/render-function.html
而es6的箭头函数呢:
以前我们函数的定义方法:
var fn1 = function(a, b) { return a + b } function fn2(a, b) { return a + b }
但使用ES6箭头函数语法定义函数,将原函数的“function”关键字和函数名都删掉,并使用“=>”连接参数列表和函数体。
var fn1 = (a, b) => { return a + b } (a, b) => { return a + b }
当函数参数只有一个,括号可以省略;但是没有参数时,括号不可以省略。
// 无参 var fn1 = function() {} var fn1 = () => {} // 单个参数 var fn2 = function(a) {} var fn2 = a => {} // 多个参数 var fn3 = function(a, b) {} var fn3 = (a, b) => {} // 可变参数 var fn4 = function(a, b, ...args) {} var fn4 = (a, b, ...args) => {}
箭头函数相当于匿名函数,并且简化了函数定义。箭头函数有两种格式:
一种只包含一个表达式,省略掉了{ … }和return:
() => return 'hello' (a, b) => a + b
还有一种可以包含多条语句,这时候就不能省略{ … }和return:
(a) => { a = a + 1 return a }
所以,现在render: h => h(App)含义是什么?
官方文档上没有使用ES6写法是这样:
render: function (createElement) { return createElement( 'h' + this.level, // 标签名称 this.$slots.default // 子节点数组 ) }
所以 createElement就是h,一个形参,没有任何意义,可以随意改变书写,还原下:
render:function(createElement){ return createElement(App); }