vue3.x+vite2.x項目搭建

vite中文文檔:https://cn.vitejs.dev

創建項目(node版本12以上)

npm init @vitejs/app 項目名 (注意:npm init vite-app xxx是vite1.0)

選擇vue

image.png

如果使用typescript,選擇vue-ts

image

創建完成

image

目錄如下:

image

增加別名

修改vite.config.js文件

import { resolve } from "path";

export default defineConfig({
  resolve: {
    alias: {
      "@": resolve(__dirname, "src")
    }
  }
})

使用:import HelloWorld from "@/components/HelloWorld .vue";

區分開發環境和生產環境(如接口調用時不同url)

默認:執行vite 時是 development 開發模式,vite build時是 production 生產模式

  1. 在項目根目錄下新建文件:(不同模式下獲取變量對應的不同的值)

.env.development

VITE_APP_TITLE='開發環境'
VITE_APP_BASE_URL='/'

.env.production

VITE_APP_TITLE='生產環境'
VITE_APP_BASE_URL='/api'

自定義環境變量命名規范:必須以VITE_為前綴

  1. 可以為自定義變量增加TypeScript類型定義,src目錄下env.d.ts文件中增加:
interface ImportMetaEnv {
  VITE_APP_TITLE: string,
  VITE_APP_BASE_URL: string
}
  1. 通常還會有測試環境test等其他自定義模式,例如

修改package.json文件中scripts,指定模式:

 "scripts": {
    "dev": "vite",
    "test": "rimraf ./test && vue-tsc --noEmit && vite build --mode test",
    "build": "rimraf ./dist && vue-tsc --noEmit && vite build  --mode production",
    "serve": "vite preview"
  }

修改vite.config.js:

export default defineConfig(({ command, mode }) => {
  return {
    build: {
      outDir: mode === "production" ? "dist" : "test"
    }
  }
})

(npm install rimraf --save-dev,刪除指定文件夾)

按需引入element-plus組件及其樣式

安裝依賴:
npm install element-plus --save
npm install vite-plugin-components vite-plugin-style-import --save-dev
1.修改vite.config.js:

import ViteComponents, { ElementPlusResolver } from 'vite-plugin-components'
import styleImport from 'vite-plugin-style-import';

export default defineConfig(({ command, mode }) => {
  return {
    plugins: [
      vue(),
      //按需引入element-plus組件
      ViteComponents({
        customComponentResolvers: [ElementPlusResolver()],
      }),
      //按需引入element-plus組件樣式
      styleImport({
        libs: [{
          libraryName: 'element-plus',
          esModule: true,
          resolveStyle: (name) => {
            return `element-plus/theme-chalk/${name}.css`;
          }
        }]
      })]
  }
})
  1. 直接使用element-plus的組件,無需其他修改
 <el-button type="warning" icon="el-icon-close" circle></el-button>
  1. build時tslint報錯:
    Cannot find module 'element-plus/es/popper' or its corresponding type declarations...

解決:忽略node_modules檢查
package.json -> scripts -> build,添加--skipLibCheck

"build": "rimraf ./dist && vue-tsc --noEmit --skipLibCheck && vite build"

或者,tsconfig.json -> compilerOptions -> 添加 skipLibCheck: true

"compilerOptions": {
    "skipLibCheck": true
}

使用scss

安裝依賴:

npm install sass --save-dev

  1. vite.config.js文件里增加css: {...},可配置公共樣式和全局變量:
export default defineConfig({
  css: {
    preprocessorOptions: {
      scss: {
        additionalData: '@import "./src/assets/index.scss";' // 此處為字符串加分號;,多個文件分號分割
      }
    }
  }
})
  1. index.scss,變量$color,和css類選擇器樣式color
$color: green;
.color {
  color: red;
}
  1. 使用變量和樣式,文字為綠色
<template>
  <div>
    ...
    <h4 class="color">2.方法</h4>
    ...
  </div>
</template>
<style lang="scss" scoped>
.color {
 color: $color;
}
</style>

路由vue-router

安裝vue-router 4.x版本:
npm install vue-router@next --save

  1. src目錄下新建文件夾router,router文件夾下新建文件index.ts
import { RouteRecordRaw, createRouter, createWebHashHistory } from "vue-router";

const routes: RouteRecordRaw[] = [
    {path: "/", redirect: "/home"},
    {
        path: "/home",
        name: "Home",
        component: () => import("@/views/index.vue"),
    },
    {
        path: "/logo",
        name: "Logo",
        component: () => import("@/views/Logo.vue"),
    },
];

const router = createRouter({
    history: createWebHashHistory(),
    routes,
});

export default router;
  1. 修改main.ts
import router from "./router/index"
createApp(App).use(router).mount('#app')

vuex 4.x

安裝依賴:
npm install vuex@next --save

  1. src目錄下新建store文件夾,store文件夾下新建modules文件夾和index.ts文件


    image.png

舉個栗子:title.ts,寫法和vue2無差別

import {getAxios} from "@/utils/request";

const title = {
    namespaced: true,
    state: {
        titles: []
    },
    mutations: {
        showTitle(state, action){
            state.titles = action.payload
        }
    },
    actions: {
        showTitle({commit}){
            return new Promise((resolve, reject) => {
                getAxios('/json/article-list.json').then(resp => {
                    let action = {
                        type: 'showTitle',
                        payload: resp
                    }
                    commit(action)
                    resolve()
                }).catch(err => {
                    console.log(err)
                    reject()
                })
            })
        }
    },
    getters: {
        getTitle(state){
            return state.titles.map((item: {title: string}) => item.title).join(",")
        }
    }
}
export default title

modules/index.ts

import user from "@/store/modules/user";
import title from "@/store/modules/title";

export default {
    user,
    title
}
  1. 創建store

index.ts:

import { createStore } from "vuex";
import modules from "./modules";

const store = createStore({
    modules
})
export default store

main.ts:

import {createApp} from 'vue'
import App from './App.vue'
import router from "@/router"
import store from "@/store";

const app = createApp(App)
app.use(router).use(store).mount('#app')
  1. 使用
import {ref} from 'vue'
import {useStore} from "vuex";

export default {
  name: 'demo',
  setup() {
    const store = useStore();
    const title = ref("");
    const showTitle = () => {
      store.dispatch('title/showTitle').then(() => {
        title.value = store.getters["title/getTitle"];
      });
    }

    return {
      title,
      showTitle
    }
  }

axios及vite配置代碼解決開發環境跨域問題

安裝依賴:
npm install axios --save

封裝axios get、post請求方法,不同環境不同baseURL:

import axios from "axios";

//顯示、隱藏loading加載中
let httpRequestCount: number = 0;
let loading: any = null;
export const showLoading = () => {
  if (httpRequestCount === 0) {
   // 顯示loading
  }
  httpRequestCount++;
}
const hideLoading = () => {
  httpRequestCount--;
  if (httpRequestCount === 0) {
    loading.close();
  }
}
//axios攔截器數據處理
const service = axios.create({
  baseURL: import.meta.env.VITE_APP_BASE_URL,
  timeout: 15000
});
service.interceptors.request.use(
  config => {
    showLoading();
    config.headers.token = "123";
    return config
  },
  error => {
    hideLoading();
    return Promise.reject(error);
  }
);
service.interceptors.response.use(
  response => {
    hideLoading();
    const {code, data, msg} = response.data;
    if(code === 200) {
      return Promise.resolve(data);
    }else {
      // 提示錯誤信息
      return Promise.reject(data);
    }
  },
  error => {
    hideLoading();
     // 提示錯誤信息
    return Promise.reject(error);
  }
);
export const getAxios = (url: string, params: object | null = {}, option: object | null = {}) => {
  return service({
    url,
    params,
    method: "get",
    ...option
  })
}
export const postAxios = (url: string, params: object | null = {}, option: object | null = {}) => {
  return service({
    url,
    params,
    method: "post",
    ...option
  })
}

修改vite.config.js

export default defineConfig(({ command, mode }) => {
  return {
    server: {
      proxy: {
        '/api': {
          target: 'http://xxx.com',
          changeOrigin: true,
          rewrite: (path) => path.replace(/^\/api/, '')
        },
      }
    }
  }
})
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,606評論 6 533
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,582評論 3 418
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,540評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,028評論 1 314
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,801評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,223評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,294評論 3 442
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,442評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,976評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,800評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,996評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,543評論 5 360
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,233評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,662評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,926評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,702評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,991評論 2 374

推薦閱讀更多精彩內容