Vue 的三种 template 模板写法

简介: Vue 的三种 template 模板写法

1、Vue 的两个不同版本的介绍

首先你要了解如何创建一个 Vue 项目,如果你还不熟悉的话,可以移步到这里:传送门。创建 Vue 项目的过程中会涉及到 Vue 两个不同版本的选择:(1)完整版:vue.js、(2)只包含运行时版:vue.runtime.js 下面说一下它们之间的差异:


完整版:同时包含编译器和运行时的版本(compiler + runtime)。

编译器:用来将模板字符串编译成为 JavaScript 渲染函数的代码(compiler)。

运行时:用来创建 Vue 实例、渲染并处理虚拟 DOM 等的代码。基本上就是除去编译器的其它一切(runtime)。

image.png

推荐使用 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 的形式导出你的项目,赶快去试试吧 ~

目录
相关文章
|
5天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
6天前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
6天前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
6天前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
|
5天前
|
JavaScript 前端开发 UED
vue学习第二章
欢迎来到我的博客!我是一名自学了2年半前端的大一学生,熟悉JavaScript与Vue,目前正在向全栈方向发展。如果你从我的博客中有所收获,欢迎关注我,我将持续更新更多优质文章。你的支持是我最大的动力!🎉🎉🎉
|
7天前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。
|
5天前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,熟悉JavaScript与Vue,正向全栈方向发展。博客内容涵盖Vue基础、列表展示及计数器案例等,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
|
JavaScript 测试技术 容器
Vue2+VueRouter2+webpack 构建项目
1). 安装Node环境和npm包管理工具 检测版本 node -v npm -v 图1.png 2). 安装vue-cli(vue脚手架) npm install -g vue-cli --registry=https://registry.
1050 0
|
7天前
|
存储 JavaScript
Vue 组件间如何通信
Vue组件间通信是指在Vue应用中,不同组件之间传递数据和事件的方法。常用的方式有:props、自定义事件、$emit、$attrs、$refs、provide/inject、Vuex等。掌握这些方法可以实现父子组件、兄弟组件及跨级组件间的高效通信。
|
12天前
|
JavaScript
Vue基础知识总结 4:vue组件化开发
Vue基础知识总结 4:vue组件化开发