簡(jiǎn)單談一談Vue中render函數(shù)

首先我們引入的vue并不是一個(gè)完整的,而是殘缺版的vue(沒有模板解析器)
那如何證明?


翻譯如下:

大概意思是說(shuō)功能不全,沒有模板解析器。并且提供建議給你:1.使用render函數(shù) 2.引入帶有模板解析器的vue(完整的vue),那意思就是說(shuō)vue并沒有引入完整?為什么?
我們就需要去依賴的地方看看到底有沒有完整引入。由于我們?cè)谝氲臅r(shí)候,地址直接寫的就是vue,但是vue下還有很多路徑

module的意思就是如果使用的es6的模塊化引入方式,就使用 dist/vue.runtime.esm.js
import的確是es6的引入方式。這里面就是殘缺版的沒有模板解析器的vue。
如何解決?
render(createElement){
這個(gè)函數(shù)有返回值,需要return 并且這個(gè)參數(shù)createElement是一個(gè)函數(shù),該函數(shù)可創(chuàng)建具體的節(jié)點(diǎn)//
return createElement('span','我是span')
}
那他和正常的默認(rèn)生成的還是有區(qū)別的,我們先看一下常規(guī)的render函數(shù)

僅僅只是一行render:h=>h(App)
我們可以根據(jù)上方代碼寫成箭頭函數(shù)并簡(jiǎn)寫形式(僅有一個(gè)參數(shù)去掉括號(hào),return去掉改為一行)
render:createElement => createElement('span','我是span') 接下來(lái)將參數(shù)改成h或者任意字母就和上圖相似了
render:h=>h('span','我是span')于是我們發(fā)現(xiàn)這樣就顯示出來(lái)了,如下圖↓ ↓ ↓ ↓

那我們?yōu)槭裁床徊捎脠?bào)錯(cuò)提示中的第二種方式引入完整的vue呢?
vue是由兩部分組成的,
1:vue核心:包含生命周期,處理事件...
2. 模板解析器
如果合在一起,模板解析器體積占總體積的1/3,webpack在進(jìn)行打包時(shí)會(huì)生成一個(gè)大的文件夾,本身模板解析器是不需要打包的,因?yàn)閣ebpack已經(jīng)將.vue文件變成了html,js,css,解析器就不再需要了。
問題來(lái)了,為什么我們創(chuàng)建了一個(gè)app節(jié)點(diǎn)而且不需要加值就可以顯示出來(lái)內(nèi)容呢?

為啥template放在組件里就可以被解析呢???這是因?yàn)橛幸粋€(gè)插件所解決的

補(bǔ)充:vue2 小例子
# 父組件
<template>
<div>
<self :render="render"></self>
</div>
</template>
<script>
import self from '@/components/self'
export default {
components:{
self
},
data() {
return {
render:h=>{
return h(
'div',
{class:'red'},
'nihao'
)
}
}
},
}
</script>
<style>
.red {
color: red;
}
</style>
# 子組件
<script>
export default {
name: "SelfText",
props: {
render: {
type: Function,
default() {
return {};
}
}
},
render(h) {
return this.render(h);
}
};
</script>
vue3 小例子
# 父組件
<template>
<div>
<self :render="render"></self>
</div>
</template>
<script>
import self from '@/components/self'
export default {
components:{
self
},
data() {
return {
render:h=>{
return h(
'div',
{class:'red'},
'nihao'
)
}
}
},
}
</script>
<style>
.red {
color: red;
}
</style>
# 子組件
<script>
import { h } from 'vue'
export default {
props: {
render: {
type: Function,
default() {
return {};
}
}
},
render() {
return this.render(h);
}
};
</script>
在vue3中,我們還可以使用setup來(lái)返回一個(gè)渲染的函數(shù)
<script>
import { h } from 'vue'
export default {
setup() {
return ()=>h(
'div',
{class:'red'},
'nihaonihao'
)
}
}
</script>
<style>
.red {
color: red;
}
</style>
總結(jié):
vue.js和vue.runtime.xxx.js的區(qū)別
(1)vue.js是完整版的Vue。包含:核心功能+模板解析器
(2)vue.runtime.xxx.js是運(yùn)行版的Vue,只包含核心功能
因?yàn)関ue.runtime.xxx.js沒有模板解析器,所以不能使用template配置項(xiàng),需要使用render函數(shù)接收到的createElement函數(shù)去指定具體內(nèi)容
到此這篇關(guān)于Vue中render函數(shù)的文章就介紹到這了,更多相關(guān)Vue中render函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue3通過render函數(shù)實(shí)現(xiàn)菜單下拉框的示例
- vue中的render函數(shù)、h()函數(shù)、函數(shù)式組件詳解
- Vue render函數(shù)使用詳細(xì)講解
- Vue中render函數(shù)調(diào)用時(shí)機(jī)與執(zhí)行細(xì)節(jié)源碼分析
- vue中使用render封裝一個(gè)select組件
- Vue 2閱讀理解之initRender與callHook組件詳解
- vue語(yǔ)法之render函數(shù)和jsx的基本使用
- vue3中的render函數(shù)里定義插槽和使用插槽
- VUE3中h()函數(shù)和createVNode()函數(shù)的使用解讀
- Vue.js3.2的vnode部分優(yōu)化升級(jí)使用示例詳解
- Vue.js之VNode的使用
- vue中?render?函數(shù)功能與原理分析
相關(guān)文章
vue項(xiàng)目實(shí)例中用query傳參如何實(shí)現(xiàn)跳轉(zhuǎn)效果
這篇文章主要介紹了vue項(xiàng)目實(shí)例中用query傳參如何實(shí)現(xiàn)跳轉(zhuǎn)效果,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
Vue3?pinia管理數(shù)據(jù)的3種方式代碼
在Vue3中Pinia是一個(gè)狀態(tài)管理庫(kù),它提供了一種簡(jiǎn)單而強(qiáng)大的方式來(lái)管理應(yīng)用程序的狀態(tài),這篇文章主要給大家介紹了關(guān)于Vue3?pinia管理數(shù)據(jù)的3種方式,需要的朋友可以參考下2024-04-04
vue項(xiàng)目實(shí)現(xiàn)點(diǎn)擊目標(biāo)區(qū)域之外可關(guān)閉(隱藏)目標(biāo)區(qū)域
這篇文章主要介紹了vue項(xiàng)目實(shí)現(xiàn)點(diǎn)擊目標(biāo)區(qū)域之外可關(guān)閉(隱藏)目標(biāo)區(qū)域,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
解決vue項(xiàng)目跳轉(zhuǎn)同樣的頁(yè)面不刷新的問題思路詳解
做公司官網(wǎng)項(xiàng)目的時(shí)候遇到的場(chǎng)景,頂部導(dǎo)航欄分類商品跳轉(zhuǎn)到分類詳情,然后在分類詳情再次點(diǎn)擊頂部導(dǎo)航欄里另外的分類商品,跳到同樣的頁(yè)面數(shù)據(jù)不刷新,下面小編給大家分享解決方式,關(guān)于vue跳轉(zhuǎn)不刷新問題感興趣的朋友一起看看吧2023-09-09
Vue.js實(shí)現(xiàn)微信過渡動(dòng)畫左右切換效果
這篇文章主要給大家介紹了利用Vue.js仿微信過渡動(dòng)畫左右切換效果的相關(guān)資料,需要用到的技術(shù)棧是Vue+Vuex。文中通過示例代碼介紹的非常詳細(xì),對(duì)大家具一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-06-06
vue3中的watch和watchEffect實(shí)例詳解
watch和watchEffect都是監(jiān)聽器,但在寫法和使用上有所區(qū)別,下面這篇文章主要給大家介紹了關(guān)于vue3中watch和watchEffect的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05

