91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue中如何引入render函數

發布時間:2022-01-10 10:43:07 來源:億速云 閱讀:285 作者:iii 欄目:開發技術

這篇文章主要講解了“Vue中如何引入render函數”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Vue中如何引入render函數”吧!

前言

使用Vue腳手架創建項目的入口文件main.js中,默認代碼如下:

import Vue from 'vue'
import App from './App.vue'

Vue.config.productionTip = false

new Vue({
  render: h => h(App),
}).$mount('#app')

可以看到,代碼中通過import引入了App組件,但是卻并沒有通過components注冊,還使用了一個render函數,而沒有利用template屬性

//上述代碼的等價寫法
import Vue from 'vue/dist/vue'//注意此處差異
import App from './App.vue'

Vue.config.productionTip = false

new Vue({
    template: `<App/>`,
    components: { App },
}).$mount('#app')

想要知道上述代碼為什么等價,就需要從Vue的不同版本說起

背景

Vue有兩大部分組成,一個是核心功能,包括生命周期、事件處理等內容,另一部分是模板解析器,用來對Vue模板進行解析。

Vue.js中包括了這兩部分的全部內容(即完整版的vue),但是這樣會有一個問題,當項目開發完畢進行打包時,打包后的文件會引入完整版vue的全部代碼,但是實際上打包后的輸出文件中已經不需要Vue模板解析器部分的代碼了(模板已經被解析好了,瀏覽器可以直接運行),引入完整版Vue只會增大打包后文件的體積。

為了解決這個問題,Vue團隊提供了不同版本的Vue,vue.js為完整版的Vue,其他版本都是在vue.js完整版上進行的精簡,比如vue.runtime.*為Vue的運行版,不包括Vue模板解析器部分代碼。

Vue中如何引入render函數

既然Vue有不同的版本,那么我們在import引入Vue的時候,到底用的是哪個版本呢?

查看Vue包中的package.json文件可以發現,ES6模塊化的入口文件是vue.runtime.esm.js,即Vue默認幫我們引入的是vue的運行版,其中不包括模板解析器部分代碼。

Vue中如何引入render函數

運行版Vue想要進行模板解析,就需要使用render函數。Vue官方案例中,入口文件main.js的內容如下,其中使用了render函數進行模板解析。

import Vue from 'vue'
import App from './App.vue'

Vue.config.productionTip = false

new Vue({
  render: h => h(App),
}).$mount('#app')

如果我們使用template屬性進行模板解析,會報錯You are using the runtime-only build of Vue where the template compiler is not available. Either pre-compile the templates into render functions, or use the compiler-included build.

//通過 import Vue from 'vue/dist/vue'引入完整版的vue,則代碼不會報錯

import Vue from 'vue'//默認引入運行版的vue,使用template編寫模板會報錯

Vue.config.productionTip = false

new Vue({
    template: `<h2>hello</h2>`,
}).$mount('#app')

注意:上邊說的模板解析指的是解析vm配置對象的template屬性中定義的模板

組件中的模板(.vue中template標簽中的內容),vue使用了vue-template-compiler幫助我們解析,而且可以看到他只在開發依賴中,在生產依賴中是沒有的,這也很好解釋,因為打包后的文件瀏覽器已經可以直接運行了,不存在vue模板語法,也就不需要vue-template-compiler了。

"dependencies": {
    "core-js": "^3.6.5",
    "vue": "^2.6.11"
},
"devDependencies": {
    "@vue/cli-plugin-babel": "~4.5.0",
    "@vue/cli-plugin-eslint": "~4.5.0",
    "@vue/cli-service": "~4.5.0",
    "babel-eslint": "^10.1.0",
    "eslint": "^6.7.2",
    "eslint-plugin-vue": "^6.2.2",
    "vue-template-compiler": "^2.6.11"
},

原理

在vm的配置對象中使用template屬性,可以通過HTML語法,創建vue模板頁面,我們編寫的Vue模板在底層先會被轉換成虛擬Dom,才會渲染到頁面中(真實Dom)。

在vm的配置對象中使用 render函數 ,可以直接用js構建虛擬DOM,免去了轉譯(Vue模板轉譯成虛擬Dom)的過程。

感謝各位的閱讀,以上就是“Vue中如何引入render函數”的內容了,經過本文的學習后,相信大家對Vue中如何引入render函數這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

门头沟区| 齐齐哈尔市| 康保县| 新宾| 沐川县| 措美县| 千阳县| 南昌市| 东丽区| 阳新县| 民和| 南江县| 东至县| 泽库县| 齐齐哈尔市| 桂东县| 磐石市| 福鼎市| 宿松县| 怀集县| 大荔县| 敦煌市| 德钦县| 凤庆县| 桃江县| 江山市| 开远市| 凤山县| 明光市| 固原市| 隆安县| 微山县| 门头沟区| 黔江区| 东丰县| 德钦县| 二连浩特市| 外汇| 林州市| 四川省| 石棉县|