vue2升3不靠谱指南

1、Vue全局命令替换为app.XXX

为了能在一个页面使用多个vue的实例,并且不相互污染。原本的Vue.XXX都替换成app.XXX

20211106161340.png

2、原本Vue上的实例方法变为静态导出。

不再能直接Vue.nextTick(),而需要先从Vue当中导出nextTick再使用。

为了支持Vue的tree-shake,这些没有用到的方法不再会被webpack打包进去。减少体积。

// 原本
import Vue from 'vue'

Vue.nextTick(() => {
  // 一些和 DOM 有关的东西
})

// ---------------------------------------

// Vue3
import { nextTick } from 'vue'

nextTick(() => {
  // 一些和 DOM 有关的东西
})
受影响的API
Vue.nextTick
Vue.observable (用 Vue.reactive 替换)
Vue.version
Vue.compile (仅完整构建版本)
Vue.set (仅兼容构建版本)
Vue.delete (仅兼容构建版本)

3、v-model语法修改

为了支持自定义组件可以有多个双向绑定值

1、.sync的部分替换为v-model的新用法。

<ChildComponent :title.sync="pageTitle" />

<!-- 替换为 -->

<ChildComponent v-model:title="pageTitle" />

2、不带参数的v-model,确保其子组件的prop和event替换成了modelValue和update:modelValue

// 组件
<ChildComponent v-model="pageTitle" />
// ChildComponent.vue

export default {
  props: {
    modelValue: String // 以前是`value:String`
  },
  emits: ['update:modelValue'],
  methods: {
    changePageTitle(title) {
      this.$emit('update:modelValue', title) // 以前是`this.$emit('input', title)`
    }
  }
}

4、v-if v-for在同一元素运用时优先级改变

2.x 版本中在一个元素上同时使用 v-if 和 v-for 时,v-for 会优先作用

3.x 版本中 v-if 总是优先于 v-for 生效。

(不要在同一元素上同时使用v-if v-for,以避免歧义)

5、v-bind="object" 现在排序敏感

原本直接写的同名组件参数会更加优先。

<!-- 模板 -->
<div id="red" v-bind="{ id: 'blue' }"></div>
<!-- 结果 -->
<div id="red"></div>

现在顺序敏感

<!-- 模板 -->
<div id="red" v-bind="{ id: 'blue' }"></div>
<!-- 结果 -->
<div id="blue"></div>

<!-- 模板 -->
<div v-bind="{ id: 'blue' }" id="red"></div>
<!-- 结果 -->
<div id="red"></div>

(尽量不要同时存在两种语法,如果必须,请注意顺序)

6、 v-on的.native修饰符删除

v-on 的 .native 修饰符已被移除。同时,新增的 emits 选项允许子组件定义真正会被触发的事件。

(删除 .native 修饰符的所有实例。
确保所有组件都使用 emits 选项记录其事件。)

7、只能使用普通函数创建函数式组件

8、异步组件写法改变

9、组件事件现在需要在 emits 选项中声明

Vue 3 现在提供一个 emits 选项,和现有的 props 选项类似。这个选项可以用来定义一个组件可以向其父组件触发的事件。

提供事件验证,处理原生事件的问题(移除了.native修饰)

<template>
  <div>
    <p>{{ text }}</p>
    <button v-on:click="$emit('accepted')">OK</button>
  </div>
</template>
<script>
  export default {
    props: ['text'],
    emits: ['accepted']
  }
</script>

(如果没写, 组件上的事件接收函数会被出发两次。一次来自Vue的事件,一次来自原生事件)

10、生命周期更名

destroyed 生命周期选项被重命名为 unmounted
beforeDestroy 生命周期选项被重命名为 beforeUnmount

简要升级指南

  1. 检查component、directive等全局变量,替换成app实例方法。
  2. 检查组件中使用了nextTick、observable等方法。
  3. 检查使用了v-model的组件,value和input事件替换。
  4. 检查是否有同时在一个元素上使用了v-if和v-for。
  5. 检查使用v-bind时是否同时又注入了属性
  6. 检查删除.native修饰符。
  7. 检查函数式组件是否正确。
  8. 检查异步组件的写法是否正确。
  9. 检查每个组件的事件是否已经在emits项中声明。
  10. 检查destroyed、beforeDestroy生命周期名字是否变更。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,406评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,732评论 3 393
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,711评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,380评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,432评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,301评论 1 301
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,145评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,008评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,443评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,649评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,795评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,501评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,119评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,731评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,865评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,899评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,724评论 2 354

推荐阅读更多精彩内容