webpack項目 遷移到 vite

1. 處理依賴

yarn add vite vite-plugin-html @vitejs/plugin-vue -D
# 如果使用了jsx語法還需要
yarn add @vitejs/plugin-vue-jsx
# 如果需要生成d.ts文件
yarn add vite-plugin-dts -D
# 如果需要 analyzer
yarn add rollup-plugin-bundle-analyzer -D

刪除 webpack 依賴,常見的有

{
  "@vue/cli-plugin-babel": "~5.0.0",
  "@vue/cli-plugin-eslint": "~5.0.0",
  "@vue/cli-plugin-router": "~5.0.0",
  "@vue/cli-plugin-typescript": "~5.0.0",
  "@vue/cli-service": "~5.0.0",
  "@vue/eslint-config-typescript": "^9.1.0",
  "vue-cli-plugin-style-resources-loader": "^0.1.5",
  "webpack-cli": "^5.0.1"
}

2. 修改配置

// package.json
  "type": "module",
  "scripts": {
    "serve": "vite --host 0.0.0.0 --port 8080",
    "build": "vite build"
  },
<!-- index.html -->
<script type="module" src="/src/main.ts"></script>
  • 添加或修改 tsconfig.jsontsconfig.node.json先改,兩個文件參考 vite 項目

  • .prettierrc.js等配置文件后綴名改為 cjs

  • 刪除vue.config.js疚察,添加vite.config.ts

    // vite.config.ts
    import { resolve } from 'path';
    import { defineConfig } from 'vite';
    import { createHtmlPlugin } from 'vite-plugin-html';
    import vue from '@vitejs/plugin-vue';
    
    // https://vitejs.dev/config/
    export default defineConfig({
      plugins: [
        vue(),
        createHtmlPlugin({
          inject: {
            // 可以向html中注入變量,原來的 htmlWebpackPlugin.options.. 不能再用
          },
        }),
        // bundleAnalyzer(),
        // dts()
      ],
      resolve: {
        alias: {
          '@': resolve(__dirname, 'src'),
        },
        // extensions: ['.mjs', '.js', '.mts', '.ts', '.jsx', '.tsx', '.cjs', '.vue']
      },
      css: {
        // css全局變量仇奶,如果需要的話
        preprocessorOptions: {
          scss: {
            sourceMap: true,
            additionalData: `@import './src/styles/variables.scss';`,
          },
        },
      },
    });
    

3. 代碼變更

  • process.env換為import.meta.env

  • 處理html中插入的變量

  • 靜態(tài)資源引用@/assets/xx.png=>require('@/assets/xx.png')

  • 添加vite-env.d.ts

    /// <reference types="vite/client" />
    
    declare module '*.vue' {
      import type { DefineComponent } from 'vue'
      const component: DefineComponent<{}, {}, any>
      export default component
    }
    
    interface ImportMetaEnv {
      readonly VITE_APP_TITLE: string
      // 更多環(huán)境變量...
    }
    
    interface ImportMeta {
      readonly env: ImportMetaEnv
    }
    

其它根據(jù)錯誤提示修改岛抄,比如有 jsx 語法的 vue 文件,要在 script 標簽上添加lang="jsx"

3.1 生成dts

vite-plugin-dts 與 jsx 一起使用時會報錯

tsc命令也可以生成dts

3.2 webpackChunkName

import(/* webpackChunkName: "xxx" */ ...

可以使用vite-plugin-webpackchunkname來識別

3.3 workbox-webpack-plugin

使用插件vite-plugin-pwa代替

3.4 worker-loader

vite自帶worker識別

3.5 CDN

Uncaught TypeError: Failed to resolve module specifier "vue". Relative references must start with either "/", "./", or "../".

借助vite-plugin-cdn-importrollup-plugin-external-globals解決狈茉,詳見
https://juejin.cn/post/7115215444671201310

https://juejin.cn/post/7197222701220053047夫椭、https://juejin.cn/post/7233220422241108023

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市氯庆,隨后出現(xiàn)的幾起案子益楼,更是在濱河造成了極大的恐慌,老刑警劉巖点晴,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異悯周,居然都是意外死亡粒督,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進店門禽翼,熙熙樓的掌柜王于貴愁眉苦臉地迎上來屠橄,“玉大人族跛,你說我怎么就攤上這事∪袂剑” “怎么了礁哄?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長溪北。 經(jīng)常有香客問我桐绒,道長,這世上最難降的妖魔是什么之拨? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任茉继,我火速辦了婚禮,結(jié)果婚禮上蚀乔,老公的妹妹穿的比我還像新娘烁竭。我一直安慰自己,他們只是感情好吉挣,可當我...
    茶點故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布派撕。 她就那樣靜靜地躺著,像睡著了一般睬魂。 火紅的嫁衣襯著肌膚如雪终吼。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天汉买,我揣著相機與錄音衔峰,去河邊找鬼。 笑死蛙粘,一個胖子當著我的面吹牛垫卤,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播出牧,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼穴肘,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了舔痕?” 一聲冷哼從身側(cè)響起评抚,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎伯复,沒想到半個月后慨代,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡啸如,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年侍匙,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片叮雳。...
    茶點故事閱讀 39,977評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡想暗,死狀恐怖妇汗,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情说莫,我是刑警寧澤杨箭,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站储狭,受9級特大地震影響互婿,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜晶密,卻給世界環(huán)境...
    茶點故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一擒悬、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧稻艰,春花似錦懂牧、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽稠茂。三九已至沫浆,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間贩猎,已是汗流浹背澎语。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工途事, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人擅羞。 一個月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓尸变,卻偏偏與公主長得像,于是被迫代替她去往敵國和親减俏。 傳聞我的和親對象是個殘疾皇子召烂,可洞房花燭夜當晚...
    茶點故事閱讀 44,927評論 2 355

推薦閱讀更多精彩內(nèi)容