vue 开发2017年变化回顾及2018年展望
vue.js 变化
从 github 的发布记录我们可以看到2017年 vue.js 的第一个发布为 v2.1.9,最后一个为 v2.5.13,主要发布小版本 2.2~2.5。这些发布提升了vue 与 TypeScript 的结合、改进了对服务端渲染(SSR)和 native 渲染的支持、提供了更好的测试、开发体验及其他的一些功能与优化。
vue@2.2 变化
1)使用 v-for 必须要添加 key 属性。
2)单文件组件(SFC)标签需要闭合,尽管 html5 中标签没有闭合也是有效的。
3)prop 属性和 computed 属性定义在组件的原型上,而不是作为每个实例自身的属性。
4)更好的错误处理 Vue.config.errorHandler
vue.config.errorHandler = function(err, vm, info) {
// handle error
}
在 2.2.0+,这个钩子函数可以捕获组件生命周期钩子中产生的错误,如果这个函数为 undefined,捕获的错误将会使用 console.error 打印出来而不会使应用崩溃。
在 2.4.0+,也会捕获 vue 自定义事件的 handler 中抛出的错误。
错误追踪服务如 Sentry 和 Bugsnag 提供了和这个选项的官方集成。
5)Vue.util 中暴露的一些方法和属性被移除了。
6)服务端渲染改进
7)组件自定义 v-model
自定义组件允许使用 v-model 时自定义属性和事件,默认使用 value 属性和 input 事件。
8)provide 和 inject
9)vm.$props
可以通过 this.$props 获取组件当前属性
10)<transition> 和 <transition-group> 支持 duration 属性
11)性能分析 Vue.config.performance
12)keep-alive 增加 activated 和 deactivated 钩子函数
13)vm.$on 支持多事件
14)v-on 支持新的 mouse event 修饰符 .left, .right, .middle
15)使用驼峰风格属性将会警告(实际上单文件组件并没有此问题,因为会自动转化为短横线分隔式命名)
vue@2.3 变化
1)许多重要的服务端渲染的改进,发布了 ssr guide。
2)异步组件改进、函数式组件改进
3).sync 修饰符回归。不过只是一个简单的语法糖,:foo.sync 等价于 :foo="bar" @update:foo="val => var = val",子组件更新 foo 的值时,需要明确地触发事件:
this.$emit('update:foo', newValue)
4)Vue.config.errorHandler 支持自定义指令和 nextTick 回调中抛出的错误
5)v-on 支持 .passive 修饰符
6)属性验证支持 type: Symbol
7)style 绑定支持数组
<div :style="{ display: ["-webkit-box", "-ms-flexbox", "flex"] }">
vue@2.4 变化
1)完全的服务端渲染 + 异步组件支持。这意味着在服务端渲染中异步组件/代码分割不再局限于路由级别。
2)inheritAttrs 选项和 $attrs, $listeners
<div>
<input v-bind="$attrs" v-on="$listeners">
</div>
3)v-on 支持对象
<button v-on="{ mousedown: doThis, mouseup: doThat }"></button>
4)增加 comments 选项
默认 false,设置为 true 时,将会保留 tempalte 里面的 html 注释
5)服务端渲染性能提升了2~8倍(取决于你的组件可以优化多少)
vue@2.5 变化
1)增加 errorCaptured 钩子来增强错误处理
2)TypeScript 声明改进
3)函数式组件改进
template 支持函数式组件
<template functional>
<div>{{ props.foo }}</div>
</template>
4)v-on 改进
添加了 .exact 修饰符
<!-- this will fire even if Alt or Shift is also pressed -->
<button @click.ctrl="onClick">A</button>
<!-- this will only fire when only Ctrl is pressed -->
<button @click.ctrl.exact="onCtrlClick">A</button>
key 修饰符,如:
<input @keyup.page-down="onPageDown">
5)简化的 scoped slot
6)nextTick 内部实现改变
在 v-on 内绑定的事件处理函数中的 DOM 更新延迟由 micro task 改成了 macro task
vue-router 变化
1)传递属性给路由组件
在组件中使用 $route 耦合性非常强,通过传递属性的方式可以解耦,大大增强组件的灵活性。
2)组件内的钩子函数 beforeRouteUpdate
使用这个钩子函数,可以不用像之前那样必须 watch $route
3)router.addRoutes
动态添加路由的利器
4)router.push() 和 router.replace() 支持可选的第二个回调参数(onComplete)和第三个回调参数(onAbort)
5)导航的 next 函数支持接收一个错误作为参数
6)新的 router guard 方法 router.beforeResolve()
7)新的路由实例选项 fallback
控制路由当浏览器不支持 history.pushState 时是否 fallback 到 hash 模式。当服务端渲染需要兼容 ie9 时,设置为 false,因为服务端渲染不能使用 hash 路由模式,而 ie9 不支持 history.pushState。
8)当浏览器支持 history.pushState 时,hash 模式也可以支持 scrollBehavior,同时这个函数也支持返回 Promise。
9)发布了 v3.x,主要是为了兼容 TypeScript。
vuex
vuex 没有大的变化,有添加一下方法。和 vue-router 一样发布了 v3.x,也是为了兼容 TypeScript。
2018 展望
vue 3.x
2018年很有可能发布 Vue 3,这个版本只支持长期更新的浏览器,如 Edge,不会支持 IE。主要改变的是 vue.js 内部,外部 api 会尽量 100% 兼容。对于低版本浏览器,可以使用 vue 2.x,因为2.x 和 3.x 将会同时维护。查看计划
vue-cli 3.x
vue-cli 2.x 暴露了一堆配置,对新手很不友好,更重要是这样很难直观地知道项目相对于默认配置的修改,而且这些配置直接从 github 拉取下来,也没有版本的概念。
vue-cli 3.x 将会只暴露一个配置的 js 文件,并且会预设很多默认配置,可能会类似于 Nuxt.js,具体查看讨论
vue-devtools 4.x(已发布)
新发布的 vue-devtools 比上一个版本强大了很多,支持从页面中选择组件、Inspect DOM、过滤观察的 data/state 等,直接编辑 data 等。
服务端渲染
随着 Nuxt 1.0 正式版本的发布,相信接下来很多公司都会将其用于部分对 SEO 有要求的官网页面。
移动端
weex 和 nativescript-vue 被越来越多的公司用于生产环境了,但是成熟度、流行程度相对于 react 的 react-native 有一段距离。ios11.3 也支持了 Service Workers,也许接下来 PWA 会很流行?
style guide
目前官方只发布了 beta 版的 style guide,接下来可能会发布正式版,配合 eslint-plugin-vue 让我们写出更好的 vue 代码。
vue 开发2017年变化回顾及2018年展望的更多相关文章
- 【转】[总结]vue开发常见知识点及问题资料整理(持续更新)
1.(webpack)vue-cli构建的项目如何设置每个页面的title 2.vue项目中使用axios上传图片等文件 3.qs.stringify() 和JSON.stringify()的区别以及 ...
- 使用vue开发微信公众号下SPA站点的填坑之旅
原文发表于本人博客,点击进入使用vue开发微信公众号下SPA站点的填坑之旅 本文为我创业过程中,开发项目的填坑之旅.作为一个技术宅男,我的项目是做一个微信公众号,前后端全部自己搞定,不浪费国家一分钱^ ...
- vue开发体验
*:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...
- 使用vue开发项目需要注意的问题和可能踩到的坑
最近,在公司给一些刚刚使用vue进行开发的同学做了一次分享, 其中包括一些vue开发中需要注意的点, 以及一些可能会踩到的坑.具体内容如下: 一.生命钩子使用需要注意的地方 1.beforeCreat ...
- vue开发项目详细教程(第一篇 搭建环境篇)
最近做vue做项目碰到了不少坑,看了三天文档便开始上手做项目了,不是我牛b,是因为项目紧,我没有时间去深入学习,所以只能一边学一边做了. 我要做的项目是一个官方网站(包括管理后台),也因为是我第一次使 ...
- vue开发小结(上)
前言: 18年年底,就一个字,忙,貌似一到年底哪个公司都在冲业绩,包括我们自己开发自己公司的项目也一样得加把劲.自从18年年初立了个flag17年年终总结——走过2017,迎来2018Flag到现在又 ...
- weex和vue开发环境配置详解(配置系统变量等等)
本文详细讲解如何搭建weex和vue开发环境 安装java 现在java安装包,网上的安装包都是国外的,很难下载下来 就用这个链接下载,亲测无毒,http://www.wmzhe.com/soft-3 ...
- Vue开发入门看这篇文章就够了
摘要: 很多值得了解的细节. 原文:Vue开发看这篇文章就够了 作者:Random Fundebug经授权转载,版权归原作者所有. 介绍 Vue 中文网 Vue github Vue.js 是一套构建 ...
- 十分钟上手-搭建vue开发环境(新手教程)
想写一些关于vue的文章已经很久了,因为这个框架已经火了很久,在公司里用的框架都比较老旧,但怎么也得跟上前端发展变化的潮流,这不,开始使用vue开发项目了,一遍开发一边踩坑中,今天要记录的是五分钟搭建 ...
随机推荐
- Vue 爬坑之路(九)—— 用正确的姿势封装组件
迄今为止做的最大的 Vue 项目终于提交测试,天天加班的日子终于告一段落... 在开发过程中,结合 Vue 组件化的特性,开发通用组件是很基础且重要的工作 通用组件必须具备高性能.低耦合的特性 为了满 ...
- Python核心编程笔记--私有化
一.私有化的实现 在Python中想定义一个类是比较简单的,比如要定义一个Person类,如下代码即可: # -*- coding: utf-8 -*- # __author : Demon # da ...
- linux下vsftpd的安装及配置使用详细步骤
vsftpd 是“very secure FTP daemon”的缩写,安全性是它的一个最大的特点. vsftpd 是一个 UNIX 类操作系统上运行的服务器的名字,它可以运行在诸如 Linux.BS ...
- delphi各种错
1. 保存文件form_spml时出上面的错,点yes后还是会出错. 解决:有时间要关闭delphi2006软件才会跳出“remove/redirect the links to another mo ...
- Centos6.5搭建分布式压力测试工具Tsung的环境搭建
各软件版本: 1.otp_src_17.1.tar.gz 2.tsung_1.5.1.tar.gz 3.7.0的Java编译环境 因工作需要,需要用TSung工具测试xmpp协议,经历了一段时间的挣扎 ...
- 【转1】Appium 1.6.3 在Xcode 8, iOS 10.2(模拟器)测试环境搭建 经验总结
Appium 1.6.3 在Xcode 8, iOS 10.2(模拟器)测试环境搭建 经验总结 关于 Appium 1.6.3 在Xcode 8, 10.2 的iOS模拟器上的问题很多,本人也差点放弃 ...
- SP3精密星历简介
IGS精密星历采用sp3格式,其存储方式为ASCII文本文件,内容包括表头信息以及文件体,文件体中每隔15 min给出1个卫星的位置,有时还给出卫星的速度.它的特点就是提供卫星精确的轨道位置.采样率为 ...
- 浅谈我的MongoDB学习(一)
这是第一次写博客,不当之处敬请见谅,最近由于项目需要,对mongodb略有研究,网上也有一些相关资料,下面是我自己摸索的一些东西,希望能跟大家分享一下当然,这也是我自己第一次在项目中使用,若理解有误, ...
- Python编程笔记 - 列表
这篇文章开始介绍Python中的容器.Python容器包括列表.元组.集合与字典.这些数据结构中都涉及到很多的方法,这里对比较常用的一些方法进行介绍,不用每个方法都记住,熟悉常用的即可. 首先,我们先 ...
- 洛谷 P3370 【模板】字符串哈希
洛谷 P3370 [模板]字符串哈希 题目描述 如题,给定N个字符串(第i个字符串长度为Mi,字符串内包含数字.大小写字母,大小写敏感),请求出N个字符串中共有多少个不同的字符串. 友情提醒:如果真的 ...