目录
1、Vue 的两个不同版本的介绍
2、运行时+编译器 vs 只包含运行时
3、template 和 render() 的使用区别
4、两种不同的构建版本的具体使用
5、用 codesandbox.io 写 Vue 代码
1、Vue 的两个不同版本的介绍
首先你要了解如何创建一个 Vue 项目,如果你还不熟悉的话,可以移步到这里:传送门。创建 Vue 项目的过程中会涉及到 Vue 两个不同版本的选择:(1)完整版:vue.js、(2)只包含运行时版:vue.runtime.js 下面说一下它们之间的差异:
- 完整版:同时包含编译器和运行时的版本(compiler + runtime)。
- 编译器:用来将模板字符串编译成为 JavaScript 渲染函数的代码(compiler)。
- 运行时:用来创建 Vue 实例、渲染并处理虚拟 DOM 等的代码。基本上就是除去编译器的其它一切(runtime)。
| Vue 完整版 | Vue非完整版 | 描述 |
特点 | 有 compiler 编译器 | 没有 compiler 编译器 | compiler 占 40% 体积 |
视图 | 写在 HTML 文件或 template 选项中 | 写在 render 函数里,用 h 函数来创建标签 | h 是尤雨溪写好传给 render 的 |
cdn 引入 | vue.js | vue.runtime.js | 文件名不同,生成环境后缀为 .min.js |
webpack 引入 | 需要配置 alias | 默认使用此版 | 别问,尤雨溪配置的 |
@vue/cli 引入 | 需要额外配置 | 默认使用此版 | 别问,尤雨溪、蒋豪群配置的 |
推荐使用 vue.runtime.js 非完整版,然后配合 vue-loader 和 vue 文件思路,这样可以保证用户体验,用户下载的 JS 文件体积更小,但只支持 h 函数。而且可以保证开发体验,开发者可直接在 vue 文件里写 HTML 标签,而不写 h 函数,多余的工作让 loader 做,vue-loader 把 vue 文件里的 HTML 转为 h 函数。
2、运行时+编译器 vs 只包含运行时
如果你需要在客户端编译模板 (比如传入一个字符串给 template
选项,或挂载到一个元素上并以其 DOM 内部的 HTML 作为模板),就将需要加上编译器,即完整版:
// 需要编译器
new Vue({
template: '<div>{{ hi }}</div>'
})
// 不需要编译器
new Vue({
render (h) {
return h('div', this.hi)
}
})
当使用 vue-loader
或 vueify
的时候,*.vue
文件内部的模板会在构建时预编译成 JavaScript。你在最终打好的包里实际上是不需要编译器的,所以只用运行时版本即可。
因为运行时版本相比完整版体积要小大约 30%,所以应该尽可能使用这个版本。如果你仍然希望使用完整版,则需要在打包工具里配置一个别名,详情移步:传送门
3、template 和 render() 的使用区别
在 Vue 完整版 vue.js 下可以使用 template 选项,因为其内置 compiler 编译器,可以将 template 字符串编译成 h 函数,从而达到直接从 HTML 渲染视图的效果。如果是在 Vue 非完整版 vue.runtime.js 下就只能使用 render 的 h 函数,通过 JS 构建的方法来达到渲染视图的效果。
//完整版 - 需要 compiler 编译器 - 编译 template
new Vue({ //这个vue实例封装了一些东西,类似jQuery封装的 return api
el:'#app', //el代表渲染挂在节点,会被替换,同$mount('#app') //涉及到 SEO 友好、服务端渲染
data:{ num:0 } //完整版支持从html中获取视图
template: '<div>{{ num }}</div>' //template内容可以写在html文件中,完整版都支持
})
//运行时版 - 不需要 compiler 编译器 - 只能使用 h 函数
new Vue({ //这个vue实例封装了一些东西,类似jQuery封装的 return api
render (h) { //不支持template选项或从html中获取视图
return h('div', this.num) //可以将 h 函数类别成 createElement()
}
})
补充,运行时版通过 render 和 h 函数来创建视图,看似麻烦,但是这种方式是比较提倡的,这也就是为什么在 使用 webpack 引入 或 @vue/cli 引入时 默认使用此版本,那么具体原因是什么呢?
我们知道完整版使用 运行时 vue.runtime.js + 编译器 compiler 组合的形式,支持直接将写在 template 或 html 文件中的字符串编译成 dom 节点,非完整版只有运行时 vue.runtime.js,不支持上述编译,但实际上非完整版有一个 预编译的 loader 加载器,使用 vue.runtime.js 非完整版,然后配合 vue-loader 可以将写在 vue 文件中的 HTML 标签转义为 h 函数,实现预编译的功能。
使用 vue.runtime.js 非完整版配合 vue-loader 可以保证用户体验,用户下载的 JS 文件体积更小,但只支持 h 函数。而且可以保证开发体验,开发者可直接在 vue 文件里写 HTML 标签,而不写 h 函数,多余的工作让 loader 做,vue-loader 把 vue 文件里的 HTML 转为 h 函数。
4、两种不同的构建版本的具体使用
现在我们分别使用 Vue 两种不同版本的构建工具实现一个点击按钮数字加一的功能,来具体看一下两种版本的实现方式:
(1)使用完整版(vue.runtime.js + compiler)支持将 template 选项或 html 文件中的代码直接编译成页面的 dom 节点。
<div id="app"></div>
<script src="https://cdn.bootcss.com/vue/2.6.10/vue.js"></script>
<script>
var app = new Vue({
el: "#app",
template: `<div>{{ num }} <button @click="increment">+1</button></div>`,
data: {
number: 0
},
methods: {
incremente() {
this.num ++;
}
}
});
</script>
(2)仅使用运行时版(vue.runtime.js )可以实现同样的效果,但是项目体积会更小,但是这对开发人员不友好。
<div id="app"></div>
<script src="https://cdn.bootcss.com/vue/2.6.10/vue.runtime.js"></script>
<script>
var app = new Vue({
el: "#app",
data: { num: 0 },
methods: {
increment() {
this.num ++;
}
},
render(createElement) {
return createElement("div", [
this.num,
createElement("button",{ on: { click: this.increment } }, "+1")
]);
}
});
</script>
两种方式的优缺点:第一种完整版的方式对开发人员友好,html 可以直接写到 template 或 html 文件中,完整版可以通过编译器直接将其渲染成页面给上的 dom 节点,但是较运行时版体积较大。第二种运行时版的方式对开发人员不友好,但是项目体积较少。
为应对上述问题,可以将 运行时版结合 vue-loader + *vue文件 的方式,可以将写在 vue 文件中的 html 预先转化为 h 函数的形式,这样即可以满足项目体积小用户体验好,又可以满足开发人员直接写 html 的两种需求,完美!
5、用 codesandbox.io 写 Vue 代码
如果你需要在新的环境,或在其他接触不到你自己电脑的环境下开发,推荐使用 CodeSandBox 进行在线开发。
CodeSandbox 是一个为 Web 应用程序开发而构建的在线编辑器,这个网站内置了多种 Web 开发框架的编译及运行配置,使得开发人员不需要进行繁琐的项目配置就可以着手进行开发工作,从而更好的专注于编写代码。CodeSandbox 仿佛就是一个在线的 webstorm 编译器,并且还给你设置好了所有开发前的准备配置,它还支持以 zip 的形式导出你的项目,赶快去试试吧 ~