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

目录
相关文章
|
27天前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
3天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
27天前
|
JavaScript 前端开发 开发者
Vue是如何劫持响应式对象的
Vue是如何劫持响应式对象的
24 1
|
27天前
|
JavaScript 前端开发 API
介绍一下Vue中的响应式原理
介绍一下Vue中的响应式原理
30 1
|
27天前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
27天前
|
存储 JavaScript 前端开发
介绍一下Vue的核心功能
介绍一下Vue的核心功能
|
29天前
|
JavaScript 前端开发 开发者
vue 数据驱动视图
总之,Vue 数据驱动视图是一种先进的理念和技术,它为前端开发带来了巨大的便利和优势。通过理解和应用这一特性,开发者能够构建出更加动态、高效、用户体验良好的前端应用。在不断发展的前端领域中,数据驱动视图将继续发挥重要作用,推动着应用界面的不断创新和进化。
|
1月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
36 1
vue学习第一章
|
1月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
27 1
vue学习第三章
|
1月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
35 1
vue学习第四章