Vue两个版本的区别和使用方法(更深层次了解)


Posted in Javascript onFebruary 16, 2020

 在我们使用 vue时,我们可以引用两个不同版本的 Vue,分别是 Vue完整版(vue.js)和 Vue(vue.runtime.js )非完整版,那么它们的区别是什么呢,今天我们就来分析下这两个不同版本之间的区别。

1、文件名

Vue两个版本的区别和使用方法(更深层次了解) 

2、文件大小

完整版:同时包含编译器和运行时的版本。

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

而非完整版不包含编译器,体积约比完整版小 30%。

3、视图

完整版

视图写在 HTML里或者 template选项里,由于有 compiler(编译器)的存在,完整版运行时:用来创建 Vue 实例、渲染并处理虚拟 DOM 等的代码。基本上就是除去编译器的其它一切。

非完整版

完整版运行时:当使用 vue-loader 或 vueify 的时候,*.vue 文件内部的模板会在构建时预编译成 JavaScript。你在最终打好的包里实际上是不需要编译器的,所以只用运行时版本即可。

// 不需要编译器
new Vue({
 render (h) {
 return h('div', this.hi)
 }
})

// 需要编译器
new Vue({
 template: '<div>{{ hi }}</div>'
})

4、配置

从 webpack 引入,完整版需要配置 alias,非完整版 是默认配置;

从 @vue/cli 引入,完整版需要额外配置,非完整版 是默认配置。

总结

既然这两者有这么多不同,那我们平时用哪个版本呢?

当然是用非完整版了,理由如下:

1.保证用户体验,用户下载的JS文件体积更小,但只支持h函数

2.保证开发体验,开发者可直接在vue文件里写HTML标签,而不写 h函数

3.活让loader做,vue-loader 会把vue文件里的HTML转为h函数,这样我不用写太多麻烦的 h函数就可做到和完整版一样的事,还更节约文件大小,提升用户体验。

以上所述是小编给大家介绍的Vue两个版本的区别和使用方法(更深层次了解),希望对大家有所帮助!

Javascript 相关文章推荐
Jquery知识点二 jquery下对数组的操作
Jan 15 Javascript
JS 无限级 Select效果实现代码(json格式)
Aug 30 Javascript
定时器(setTimeout/setInterval)调用带参函数失效解决方法
Mar 26 Javascript
JavaScript中的原型和继承详解(图文)
Jul 18 Javascript
JQuery实现当鼠标停留在某区域3秒后自动执行
Sep 09 Javascript
JS文字球状放大效果代码分享
Aug 19 Javascript
Javascript函数式编程语言
Oct 11 Javascript
vue2 自定义动态组件所遇到的问题
Jun 08 Javascript
jQuery实现的文字逐行向上间歇滚动效果示例
Sep 06 jQuery
Vue2.0基于vue-cli+webpack同级组件之间的通信教程(推荐)
Sep 14 Javascript
30分钟精通React今年最劲爆的新特性——React Hooks
Mar 11 Javascript
vue监听用户输入和点击功能
Sep 27 Javascript
vue数据响应式原理知识点总结
Feb 16 #Javascript
vue中利用iscroll.js解决pc端滚动问题
Feb 15 #Javascript
JS localStorage存储对象,sessionStorage存储数组对象操作示例
Feb 15 #Javascript
ES6 proxy和reflect的使用方法与应用实例分析
Feb 15 #Javascript
js表达式与运算符简单操作示例
Feb 15 #Javascript
ES6 class类链式继承,实例化及react super(props)原理详解
Feb 15 #Javascript
ES6 Iterator遍历器原理,应用场景及相关常用知识拓展详解
Feb 15 #Javascript
You might like
PHP 中的面向对象编程:通向大型 PHP 工程的办法
2006/12/03 PHP
6种php上传图片重命名的方法实例
2013/11/04 PHP
CI框架AR数据库操作常用函数总结
2016/11/21 PHP
php如何利用pecl安装mongodb扩展详解
2019/01/09 PHP
PHP实时统计中文字数和区别
2019/02/28 PHP
Laravel框架Eloquent ORM简介、模型建立及查询数据操作详解
2019/12/04 PHP
基于JQuery的一句代码实现表格的简单筛选
2010/07/26 Javascript
一个简单的JavaScript数据缓存系统实现代码
2010/10/24 Javascript
div层的移动及性能优化
2010/11/16 Javascript
IE和Firefox的Javascript兼容性总结[推荐收藏]
2011/10/19 Javascript
获取鼠标在div中的相对位置的实现代码
2013/12/30 Javascript
javascript实现阻止iOS APP中的链接打开Safari浏览器
2014/06/12 Javascript
JavaScript中的eval()函数使用介绍
2014/12/31 Javascript
JavaScript静态类型检查工具FLOW简介
2015/01/06 Javascript
NodeJs基本语法和类型
2015/02/13 NodeJs
深入剖析JavaScript中的函数currying柯里化
2016/04/29 Javascript
jQuery和CSS仿京东仿淘宝列表导航菜单
2017/01/04 Javascript
微信小程序小组件 基于Canvas实现直播点赞气泡效果
2020/05/29 Javascript
认识less和webstrom的less配置方法
2017/08/02 Javascript
js实现简易聊天对话框
2017/08/17 Javascript
[02:30]DOTA2英雄基础教程 暗影恶魔
2013/12/17 DOTA
Python下的Mysql模块MySQLdb安装详解
2014/04/09 Python
Centos5.x下升级python到python2.7版本教程
2015/02/14 Python
使用pdb模块调试Python程序实例
2015/06/02 Python
python 把文件中的每一行以数组的元素放入数组中的方法
2018/04/29 Python
python创建学生成绩管理系统
2019/11/22 Python
Python安装依赖(包)模块方法详解
2020/02/14 Python
在Python3.74+PyCharm2020.1 x64中安装使用Kivy的详细教程
2020/08/07 Python
加拿大奢华时装品牌:Mackage
2018/01/10 全球购物
英国内衣连锁店:Boux Avenue
2018/01/24 全球购物
与世界上最好的跑步专业品牌合作:Fleet Feet
2019/03/22 全球购物
Puccini乌克兰:购买行李箱、女士手袋网上商店
2020/08/06 全球购物
高中生评语大全
2014/04/25 职场文书
公司备用金管理制度
2015/08/04 职场文书
深入理解MySQL中MVCC与BufferPool缓存机制
2022/05/25 MySQL
MySQL示例讲解数据库约束以及表的设计
2022/06/16 MySQL