vue - vue2 升级到 vue3的步骤

访问量: 935

refer to :

原则:

1. 能不动就别动

2. 一定要动的话,改动比较大。

3. 看:npm run dev 看能否能跑起来, 看报的是什么错

重新安排package.json

如果是大项目的话,建议慎重操作 如果是小项目的话,pacakge.json需要重新安排。否则会包莫名其妙的错误。基本都是由于第三方包版本不兼容造成的。

vue-router需要做改动

import Vue from 'vue'
import Router from 'vue-router'

改成:

import { createRouter, createWebHistory } from 'vue-router'
routes = []  // 这里是路由
const router = createRouter({
  history: createWebHistory(process.env.BASE_URL),
  routes
})

export default router

VueResource 不要用了,使用Axios

import VueResource from 'vue-resource'

修改vue的初始化入口和方式

new Vue({
  el: '#app',
  router,
  template: '<App/>',
  components: { App }
})

改成形如这样的形式:

import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import store from './vuex/store'

createApp(App).use(store).use(router).mount('#app')

不再暴露全局的Vue对象。

参考:https://v3.vuejs.org/api/application-config.html#errorhandler

例如,Vue2.x

import vueConfig from './vue-config'
const configs = {
  api: 'http://shopweb.sweetysoft.com/interface/'
}

Vue.use(vueConfig, configs)

Vue3.x

....
const app = createApp({})
app.config.globalProperties.api = 'http://shopweb.sweetysoft.com/interface/'

Vuex的使用发生了变化。不但声明要改(src/vuex/store.js) ,其他代码也要改(使用vuex的地方)

import Vue from 'vue'
import Vuex from 'vuex'
export default new Vuex.Store({  ... }) 

vue3:

import { createStore } from 'vuex'
import { INCREASE } from '@/vuex/mutation_types'

export default createStore({

使用的页面,都要有 store: useStore(),  的声明

修改http的使用方式

vue2.x

this.$http.get 

vue3:

const axios = require('axios');
axios.get('/api/interface/blogs/all').then((response) => {
     response.data ...

检查router, 看是否有重名的内容

vue2中可以重名,vue3中不可以重名,否则报错:

[Vue Router warn]: No match found for location with path "/" 
解决办法: 不要让name 重名
 const routes = [           
     {
       path: '/',           
       name: 'Root',           // 这里不可以重名
       component: Index     
     },

订阅/RSS Feed

Subscribe