關于Vue腳手架中render 理解
在vue的腳手架中, 我們會看到在入口文件 main.js中的 new Vue的代碼中有一段代碼 render:h=>h(App);

這段代碼不像我們 一般的使用vue 時的代碼
我寫一下 一般的Vue 代碼
import Acomponent from "../Acomponent"
vm = new Vue({
el:"#app"
data(){
return {
a:"aaa",
b:"bbb"
}
},
template:`<div>
<span>this is a test</span>
<Acomponent></Acomponent>
</div>`,
components:{
Acomponent
}
})
上面的代碼是我們正常能懂的代碼, 有template , 在template中可以引入其它的組件, 但為什么腳手架中卻給了一個 render 的方法呢
根據(jù)自已的想法, 我們可以把腳手架的代碼更改一下看看

啟動腳手架, npm run serve 看一下結果, 報錯了, 信息如下

所以, 我們可以說 , 腳手架給我們引入的 vue 是沒有模板解析器的一個vue , 如果要解析模板, 就要使用 render 函數(shù)的幫助
我們來到 項目的 node_modules 文件夾中看一下 我們引入的到底是 哪一個 vue
import Vue from 'vue'

我們打開 vue / dist 的文件, 可以看到很多的文件, 如圖

錯誤提示上說我們有兩種方法解決, 一種是引入完整的vue.js 另一種是使用 render ,
我們來引入完整版的來看一下, 可不可以解決

我們再看第二種,引入沒有模板解析器的vue, 使用 render,
先說一個 render
render 是一個函數(shù), 并且有一個參數(shù), 這個參數(shù)的使用就是創(chuàng)建一個 節(jié)點


通過console.log, 我們可以看到 參數(shù) createElement 也是一個函數(shù), 它創(chuàng)建了一個 VNode 的對象

下面我們使用 箭頭函數(shù)來對 render 來進行精簡
render(createElement){
return createElement("h1","123");
}
//使用箭頭函數(shù)簡化
render:(createElement)=>{return createElement("h1","123")}
//箭頭函數(shù)中 只有一個參數(shù), 可以不寫 小括號 如果方法體中只有一行, 可以不用寫 大括號, 返回值也可以不用寫return
//所以上面的代碼可以簡化成這樣
render:createElemnet=>crementElement("h1","123")
//同樣, createElement 本來就是自已自定義的, 我們可以把名稱也改一下
render: h=>h("h1","123")
//這樣就很像腳手架中的代碼了
h函數(shù)中, 如果是原生的html 標簽的話, 就是這樣寫, 如果是vue 的組件的話, 可以直接傳入
所有就有了
render:h=>h(App)
render 的寫法就是這樣來的
下面說一下,為什么 腳手架會引入一個不完整的vue來使用
我們知道, vue代碼完成之后是要打包的, 其中少不了vue的核心代碼,當我們打包好之后, 我們其實是不需要再來解析模板的, 那么, vue的核心代碼中的模板解析器根本用不著, 所以,vue為了使代碼的體積減少, 就去掉了模板解析器,但是我們開發(fā)的時候, 又要使用, 所以就創(chuàng)建了一個 render 方法來解析模板,
總之, 它的目的就是讓打包后的代碼體積盡量小
到此這篇關于Vue腳手架中的 render 理解的文章就介紹到這了,更多相關Vue render 理解內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Vue重要修飾符.sync對比v-model的區(qū)別及使用詳解
這篇文章主要為大家介紹了Vue中重要修飾符.sync與v-model的區(qū)別對比及使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07

