欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3.x項目降級到vue2.7的解決方案

 更新時間:2023年03月18日 14:42:01   作者:前端小蝸  
Vue2.7是Vue2.x的最終次要版本,下面這篇文章主要給大家介紹了關于vue3.x項目降級到vue2.7的解決方案,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

把 vue3 項目降級到 vue2 ??

原項目為 vue3 + vite + element-plus + pinia + vue-router + typescript 構建

降級后為 vue2.7 + vite + element-ui + pinia + vue-router + typescript

為什么要降級到 vue2 ?

  • 兼容性問題:公司基于 element-ui 開發(fā)了自己的一套 ui 組件,并且還有基于 vue2 開發(fā)的中臺組件。由于現(xiàn)有的組件庫都是基于 vue2 開發(fā)的,完全不兼容 Vue 3。
  • 學習成本:團隊中的開發(fā)人員可能需要花費大量時間來學習 Vue 3 的新功能。??
  • 項目需求:項目需求中需要 Vue 3 的新功能的部分我們可以使用 vue2.7 來替代。
  • vue3 無法兼容 IE10 瀏覽器(雖然覺得沒必要考慮這個,但是種種原因...??

考慮到上面幾點,我想了幾個方法 ??:

  • 微前端:考慮過 qiankun 和 micro-app,但是由于 ui 組件使用的是 vue2 開發(fā)所以無法兼容
  • ui 組件庫+中臺組件庫 升級到 vue3 版本:工程量太大被拒絕
  • 降級項目到 vue2.7:改動較小,邏輯基本無需改動。成本可控

vue3 和 vue2 的依賴

vue3 所需依賴

    ...  // other
    "vue": "^3.2.31",
    "vue-router": "^4.0.10",
    "pinia": "^2.0.13",
    "vite": "^2.9.1",
    "vue-tsc": "^0.33.9"
    "prettier": "^2.6.2",
    "element-plus": "^2.1.8",

vue2 所需依賴

    ... //other
    "vue": "2.7.5",
    "vue-router": "^3.5.4"
    "pinia": "^2.0.14",
    "vite": "^2.9.9",
    "vue-tsc": "^0.39.5",
    "prettier": "^2.7.1",
    "element-ui": "x.x.x" // 因為公司有自己的ui庫 這里用element-ui代替

想要把 vue3 的項目降級到 vue2,我們先看下上面的依賴,

  • vue 肯定是需要改動的
  • vue-router 也是需要改動:vue-router 默認版本是@4 但是 vue-router@4 只能支持 vue3,以及為了避免更多的問題,所以我們需要改為 vue-router@3 版本。

對比 vue3 和 vu2 的區(qū)別

  • 響應式區(qū)別:vue3 使用 proxy 代理,vue2 使用 Object.defineProperty()
  • 選項式 API 和組合式 API
  • 生命周期不同

這里只簡單說明,不做重點

實踐步驟

  • vue 降級
  • vue-router降級
  • 組件庫降級
  • pinia或者vuex
  • eslint等工程化

vue 降級

npm i vue@2.7.5

將 vue3 的 createApp() 改為 vue.use()

// vue3
import { createApp } from "vue";
const app = createApp(App);
app.use("xxx");
// vue2
import Vue from "vue";
vue.use("xxx");
new Vue({
  //...
}).$mount("#app");

vue-router 降級

npm i vue-router@3.6.5

將vue-router@4.x.x 降級到 @3.x.x

// vue3 + vue-router4
import {
  createWebHashHistory,
  createRouter,
} from 'vue-router'

export const constantRoutes = [
    {
        path: 'xxx',
        component: xxx,
        name: 'xxx',
        meta: {
            hidden: true,
        },
        children: [
            {
                path: '/xxx',
                component: () => import('xxx'),
            },
        ],
    },
    ...
]
const router = createRouter({
  history: createWebHashHistory('/admin'),
  routes: constantRoutes,
})
// vue2.7+ vue-router3

import VueRouter from "vue-router";

export const router = new VueRouter({
  scrollBehavior: () => ({ x: 0, y: 0 }),
  mode: "hash",
  routes: constantRoutes,
});

export const constantRoutes = [
  {
    path: "/xxx",
    name: "xxx",
    component: () => import("xxx"),
    
  },
  ...
];

element-ui

因為 element-plus 是使用vue3重寫的組件,所以無法應用在vue2的項目中,所以需要重寫安裝 element-ui

npm i element-ui

值得慶幸的是,如果你使用的是 element-ui ,那么你的改動會很少,element-pluselement-ui的組件名保持了一致,并且大多數(shù)的方法名和屬性也都保持了一致。

pinia

官方說明

Pinia 最初是在 2019 年 11 月左右重新設計使用 Composition API 。從那時起,最初的原則仍然相同,但 Pinia 對 Vue 2 和 Vue 3 都有效,并且不需要您使用組合 API。 除了安裝和 SSR 之外,兩者的 API 都是相同的,并且這些文檔針對 Vue 3,并在必要時提供有關 Vue 2 的注釋,以便 Vue 2 和 Vue 3 用戶可以閱讀!

同樣 pinia 作為 vuex 的第五代版本,也是完全兼容vue2和vue3的,所以這部分你也基本不用改動。

eslint + husky + prettier + typescript

值得注意的是 elint 在使用vue3的擴展和vue2是不同的,所以不能直接復制粘貼

其他的交驗倒是沒發(fā)現(xiàn)什么問題

問題/缺陷

  • 使用vite 構建的話 federationPluginplugin-legacy 會有沖突,暫時無法解決

總結

總體來說,讓vue3的項目降級到vue2是不需要重寫的,我們可以盡量的控制修改的代價。

我們需要注意以下幾個地方

  • vue-router 的語法和版本
  • vue 的語法和版本
  • ui組件庫的兼容性和標簽,屬性,方法
  • eslint的擴展問題

雖然vue3給我們的開發(fā)提供了高效,便利的一方面,但是我們在實踐中還是要考慮到公司的開發(fā)環(huán)境和原有的公共庫,做好調(diào)查。避免給其他開發(fā)人員帶來不必要的麻煩。

到此這篇關于vue3.x項目降級到vue2.7的文章就介紹到這了,更多相關vue3.x項目降級vue2.內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue中ElementUI分頁組件Pagination的使用方法

    Vue中ElementUI分頁組件Pagination的使用方法

    這篇文章主要為大家詳細介紹了Vue中ElementUI分頁組件Pagination的使用,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • VUE Error: getaddrinfo ENOTFOUND localhost

    VUE Error: getaddrinfo ENOTFOUND localhost

    這篇文章主要介紹了VUE Error: getaddrinfo ENOTFOUND localhost,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • vue使用@include或@mixin報錯的問題及解決

    vue使用@include或@mixin報錯的問題及解決

    這篇文章主要介紹了vue使用@include或@mixin報錯的問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • Vue計算屬性的使用

    Vue計算屬性的使用

    本篇文章主要介紹了Vue計算屬性的使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • Vue3超詳細的ref()用法教程(看這一篇就夠了!)

    Vue3超詳細的ref()用法教程(看這一篇就夠了!)

    這篇文章主要給大家介紹了關于Vue3超詳細的ref()用法的相關資料,在Vue3中ref函數(shù)不僅可以用于在組件中獲取DOM元素或子組件的引用,還可以直接訪問組件元素本身,需要的朋友可以參考下
    2023-07-07
  • Vue高級特性概念原理詳細分析

    Vue高級特性概念原理詳細分析

    這篇文章主要介紹了Vue高級特性概念原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2023-03-03
  • Vue3+echarts繪制世界地圖的示例代碼

    Vue3+echarts繪制世界地圖的示例代碼

    最近做項目需要實現(xiàn)世界地圖,本文主要介紹了Vue3+echarts繪制世界地圖的示例代碼,具有一定的參考價值,感謝的可以了解一下
    2024-03-03
  • Vue項目之ES6裝飾器在項目實戰(zhàn)中的應用

    Vue項目之ES6裝飾器在項目實戰(zhàn)中的應用

    作為一個曾經(jīng)的Java?coder,當?shù)谝淮慰吹絡s里面的裝飾器Decorator,就馬上想到了Java中的注解,當然在實際原理和功能上面,Java的注解和js的裝飾器還是有很大差別的,這篇文章主要給大家介紹了關于Vue項目之ES6裝飾器在項目實戰(zhàn)中應用的相關資料,需要的朋友可以參考下
    2022-06-06
  • 使用vue項目配置多個代理的注意點

    使用vue項目配置多個代理的注意點

    這篇文章主要介紹了使用vue項目配置多個代理的注意點,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • vue如何實現(xiàn)動態(tài)加載腳本

    vue如何實現(xiàn)動態(tài)加載腳本

    這篇文章主要介紹了vue如何實現(xiàn)動態(tài)加載腳本,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-02-02

最新評論