Skip to content
    在 Opshell 的 Blog 中:
  • 目前已分享 70 篇文章
  • 還有 114 個坑正在填補中
  • 已有: Loading 次觀看
  • 已有: Loading 個人來過
✍️ Opshell
📆 Last Updated:8/23/2024Created:2022/09/22
👀 已被閱讀: Loading

[Day22]:Vite 環境最...咦裝好了 part1

Day 22 Banner

Vite 環境最...咦裝好了

每次開始學習新的語言或框架,最麻煩的不是要學習他有哪些語法、規則是安裝...嗯? 好了?!!───────────────────────── By Opshell


目標:

安裝完成使用Vite + TypeScript需要的環境, 然後開始祈禱過程不要出現奇怪的問題。


過程:

安裝Vite

建個專案資料夾,因為是Ops要自己做部落個的筆記, 並且由 cli 遷移到 vite + TypeScript的紀錄, 所以就直接在專案底下動工了:

1. 在目前環境下開始

目前有安裝的套件: 目前環境 雖然沒有裝vite,但npm會自動下載:

shell
 yarn create vite

2. 輸入專案名稱

因為是要當後台用, 直接輸入webadminvite(個人喜好) 專案名稱

3. 選擇框架

Vue不解釋 Vue

4. 選擇語言

TypeScript

5. 結果

結果

對,就這樣,一個vue+typescript 的基本框就好了, vite也有提供創建模板,可以像這樣快速生成:

shell
 yarn create vite webadminvite --template vue-ts

目前可用的模板可以到官網查看。


Vite + Vue3 + TypeScript 配置

  • 1. 進專案資料夾

    shell
     cd webadminvite

  • 2. TypeScript Node types 依賴

    在設定路徑、文件讀寫等操作的時候,為了簡化路徑都會使用別名, 但是直接設定的話,TypeScript看不懂node相關的套件的型別宣告, 所以需要先設定node的types依賴。

    2-1. 安裝指令:

     yarn add @types/node -D

    指令省略一堆結果

    2-2. 別名設定:

    TypeScript設定別名需要改:tsconfig.jsonvite.config.ts兩支檔案。

    • tsconfig.json

    compilerOptions内新增paths設定, key為要增加的别名,value為別名對應的目錄或路徑:

    json
     // tsconfig.json
     "paths": {
       "@/*": ["./src/*"]
     },

    別名設定

    ※ 别名一般都是設定目錄,所以key和value都要加上/*

    • vite.config.ts

    import path from 'path'之後, 在defineConfig裡新增resolve區塊:

    typescript
     // vite.config.ts
     import { defineConfig } from 'vite';
     import vue from '@vitejs/plugin-vue';
     import path from 'path'; // 這個
    
     // https://vitejs.dev/config/
     export default defineConfig({
       plugins: [vue()],
    
       // 這裡
       resolve: {
          alias: {
             '@': path.resolve(__dirname, 'src')
          }
       }
     });

    vite.config.ts設定得別名要和tsconfig.json 裡設定的一樣才可以, 只是key末尾不需要/*,value 需要用path指向對應的目錄。


  • 3. Node Service和proxy(代理)

    在本機開發的時候,都需要啟動 Node Service 來瀏覽畫面, 通過proxy(代理)來串接後端接口, 所以我們需要設定一下vite.config.ts

    javascript
     // vite.config.ts
     export default defineConfig({
       // 以上省略...
    
       // 代理伺服器
       server: {
          port: 8080,
          strictPort: false, // Port被占用時直接退出, false會嘗試連接下一個可用Port
          open: true, // dev時自動打開網頁,也可以給網址指定。
          // 自訂代理規則,配合後端進行Api呼叫等。
          proxy: {
             '/api': {
                target: "http://www.opshell/api/", // 本機串接
                ws: true, // 代理的WebSockets
                changeOrigin: true, // 允許websockets跨域
                rewrite: (path) => path.replace(/^\/api/, '')
             },
          }
       }
     });

    更多的設定可以參考官方 http-proxy更多設定請見官方


  • 4 都設定好了之後,試著跑跑看

    輸入下面的指令:

     yarn run dev

    指令結果

    有沒有出現這個畫面呢~?

    vite 成功畫面


小結:

今天的Vite + TypeScript 的常用設定就處理好啦~ 明天還有更多、更多的東西要來設定呢~ 沒辦法,Vite快是沒錯 但是也是拋下了那些Cli包好的東西, 所以需要什麼,就一個個裝回來, 這是一個漫長的過程。 大家早點睡,晚安~

Released under the MIT License.