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有不同的版本,那么我们在import引入vue的时候,到底用的是哪个版本呢?
查看vue包中的package.json文件可以发现,es6模块化的入口文件是vue.runtime.esm.js,即vue默认帮我们引入的是vue的运行版,其中不包括模板解析器部分代码。
运行版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: `<h1>hello</h1>`, }).$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函数内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!