国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Vite4+Typescript+Vue3+Pinia 從零搭建(3) - vite配置

這篇具有很好參考價(jià)值的文章主要介紹了Vite4+Typescript+Vue3+Pinia 從零搭建(3) - vite配置。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

項(xiàng)目代碼同步至碼云 weiz-vue3-template
關(guān)于vite的詳細(xì)配置可查看 vite官方文檔,本文簡單介紹vite的常用配置。

初始內(nèi)容

項(xiàng)目初建后,vite.config.ts 的默認(rèn)內(nèi)容如下:

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue()],
})

配置別名

1. 安裝 @types/node

npm i @types/node -D

Vite4+Typescript+Vue3+Pinia 從零搭建(3) - vite配置

2. 修改 vite.config.ts

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import { resolve } from 'path'

// 路徑查找
const pathResolve = (dir: string): string => {
  return resolve(__dirname, ".", dir);
};

// 設(shè)置別名,還可以添加其他路徑
const alias: Record<string, string> = {
  "@": pathResolve("src"),
  "@views": pathResolve("src/views"),
  "@store": pathResolve("src/store/modules")
};

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue()],
  resolve: {
    alias
  },
})

3. 使用

比如,修改 App.vue:

import HelloWorld from '@/components/HelloWorld.vue'

Vite4+Typescript+Vue3+Pinia 從零搭建(3) - vite配置

配置環(huán)境變量

1. 新建env文件

根目錄下新建 .env.env.development、.env.production 三個(gè)文件。
.env 文件內(nèi)新增內(nèi)容:

# 本地運(yùn)行端口號(hào)
VITE_PORT = 8686

.env.development 文件內(nèi)新增內(nèi)容:

# 本地環(huán)境
VITE_USER_NODE_ENV = development

# 公共基礎(chǔ)路徑
VITE_PUBLIC_PATH = /

.env.production 文件內(nèi)新增內(nèi)容:

# 線上環(huán)境
VITE_USER_NODE_ENV = production

# 公共基礎(chǔ)路徑
VITE_PUBLIC_PATH = /

2. 環(huán)境變量統(tǒng)一處理

根目錄下新建 build 文件夾,其目錄下新建 index.ts,內(nèi)容如下:

// 環(huán)境變量處理方法
export function wrapperEnv(envConf: Recordable): ViteEnv {
  const ret: any = {};

  for (const envName of Object.keys(envConf)) {
    let realName = envConf[envName].replace(/\\n/g, "\n");
    realName = realName === "true" ? true : realName === "false" ? false : realName;
    if (envName === "VITE_PORT") realName = Number(realName);
    ret[envName] = realName;
    if (typeof realName === "string") {
      process.env[envName] = realName;
    } else if (typeof realName === "object") {
      process.env[envName] = JSON.stringify(realName);
    }
  }
  return ret;
}

3. 環(huán)境類型定義

types\index.d.ts 文件里新增對(duì) RecordableViteEnv 的類型定義:

type Recordable<T = any> = Record<string, T>;

interface ViteEnv {
  VITE_USER_NODE_ENV: "development" | "production";
  VITE_PUBLIC_PATH: string;
  VITE_PORT: number;
}

修改 tsconfig.json 文件,將 build 文件夾內(nèi)的文件包含進(jìn)去:

"include": [ // 需要檢測的文件
  "src/**/*.ts",
  "build/*.ts",
  "src/**/*.d.ts",
  "src/**/*.tsx",
  "src/**/*.vue",
  "mock/*.ts",
  "types/*.d.ts",
  "vite.config.ts"
],

同理,修改 tsconfig.node.json 文件:

"include": [
  "build/*.ts",
  "types/*.d.ts",
  "vite.config.ts"
]

4. 使用

修改 vite.config.ts

import { defineConfig, loadEnv, ConfigEnv, UserConfig } from "vite"
import vue from '@vitejs/plugin-vue'
import { resolve } from 'path'
import { wrapperEnv } from './build'

// 路徑查找
const pathResolve = (dir: string): string => {
  return resolve(__dirname, ".", dir);
};

// 設(shè)置別名,還可以添加其他路徑
const alias: Record<string, string> = {
  "@": pathResolve("src"),
  "@views": pathResolve("src/views"),
  "@store": pathResolve("src/store")
};

// https://vitejs.dev/config/
export default defineConfig(({ mode }: ConfigEnv): UserConfig => {
  const root = process.cwd()
  const env = loadEnv(mode, root)
  const viteEnv = wrapperEnv(env)

  return {
    base: viteEnv.VITE_PUBLIC_PATH,
    plugins: [vue()],
    resolve: {
      alias
    },
    server: {
      host: "0.0.0.0",
      port: viteEnv.VITE_PORT,
      https: false,
      open: true,
      // 本地跨域代理 https://cn.vitejs.dev/config/server-options.html#server-proxy
      proxy: {
        "^/api": {
          target: "http://192.168.1.4:8688",
          changeOrigin: true,
          rewrite: path => path.replace(/^\/api/, "")
        }
      }
    },
  }
})

目錄更新

當(dāng)前項(xiàng)目目錄如下:文章來源地址http://www.zghlxwxcb.cn/news/detail-746131.html

|   .env
|   .env.development
|   .env.production
|   .gitignore
|   index.html
|   package-lock.json
|   package.json
|   README.md
|   tree.txt
|   tsconfig.json
|   tsconfig.node.json
|   vite.config.ts
|   
+---.vscode
|       extensions.json
|       
+---build
|       index.ts
|              
+---node_modules 
+---public
|       vite.svg
|       
+---src
|   |   App.vue
|   |   main.ts
|   |   style.css
|   |   vite-env.d.ts
|   |   
|   +---assets
|   |       vue.svg
|   |       
|   \---components
|           HelloWorld.vue
|           
\---types
        index.d.ts

到了這里,關(guān)于Vite4+Typescript+Vue3+Pinia 從零搭建(3) - vite配置的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包