vite配置

127 阅读4分钟
{  
  root: process.cwd(), // 项目根目录(index.html 文件所在的位置),  
  base'/'// 开发或生产环境服务的公共基础路径 配置引入相对路径  
  mode'development'// 模式  
  plugins: [vue()], // 需要用到的插件数组  
  publicDir'public'// 静态资源服务的文件夹  
  cacheDir'node_modules/.vite'// 存储缓存文件的目录  
  resolve: {  
    alias: [ // 文件系统路径别名  
      {  
        find/\/@\//,  
        replacementpathResolve('src') + '/'  
      }  
    ],  
    dedupe: [], // 强制 Vite 始终将列出的依赖项解析为同一副本  
    conditions: [], // 解决程序包中 情景导出 时的其他允许条件  
    mainFields: [], // 解析包入口点尝试的字段列表  
    extensions: ['.mjs''.js''.ts''.jsx''.tsx''.json'], // 导入时想要忽略的扩展名列表  
    preserveSymlinksfalse// 启用此选项会使 Vite 通过原始文件路径确定文件身份  
  },  
  css: {  
    modules: {  
      scopeBehaviour'global' | 'local',  
      // ...  
    },  
    postcss''// 内联的 PostCSS 配置 如果提供了该内联配置,Vite 将不会搜索其他 PostCSS 配置源  
    preprocessorOptions: { // css的预处理器选项  
      scss: {  
        additionalData`$injectedColor: orange;`  
      }  
    }  
  },  
  json: {  
    namedExportstrue// 是否支持从.json文件中进行按名导入  
    stringifyfalse//  开启此项,导入的 JSON 会被转换为 export default JSON.parse("...") 会禁用按名导入  
  },  
  esbuild: { // 最常见的用例是自定义 JSX  
    jsxFactory'h',  
    jsxFragment'Fragment'  
  },  
  assetsInclude: ['**/*.gltf'], // 指定额外的 picomatch 模式 作为静态资源处理  
  logLevel'info'// 调整控制台输出的级别 'info' | 'warn' | 'error' | 'silent'  
  clearScreentrue// 设为 false 可以避免 Vite 清屏而错过在终端中打印某些关键信息  
  envDir'/'// 用于加载 .env 文件的目录  
  envPrefix: [], // 以 envPrefix 开头的环境变量会通过 import.meta.env 暴露在你的客户端源码中  
  server: {  
    host'127.0.0.1'// 指定服务器应该监听哪个 IP 地址  
    port5000// 指定开发服务器端口  
    strictPorttrue// 若端口已被占用则会直接退出  
    httpsfalse// 启用 TLS + HTTP/2  
    opentrue// 启动时自动在浏览器中打开应用程序  
    proxy: { // 配置自定义代理规则  
      '/api': {  
        target'http://jsonplaceholder.typicode.com',  
        changeOrigintrue,  
        rewrite(path) => path.replace(/^\/api/'')  
      }  
    },  
    corstrue// 配置 CORS  
    forcetrue// 强制使依赖预构建  
    hmr: { // 禁用或配置 HMR 连接  
      // ...  
    },  
    watch: { // 传递给 chokidar 的文件系统监听器选项  
      // ...  
    },  
    middlewareMode''// 以中间件模式创建 Vite 服务器  
    fs: {  
      stricttrue// 限制为工作区 root 路径以外的文件的访问  
      allow: [], // 限制哪些文件可以通过 /@fs/ 路径提供服务  
      deny: ['.env''.env.*''*.{pem,crt}'], // 用于限制 Vite 开发服务器提供敏感文件的黑名单  
    },  
    origin'http://127.0.0.1:8080/'// 用于定义开发调试阶段生成资产的 origin  
  },  
  build: {  
    target: ['modules'], // 设置最终构建的浏览器兼容目标  
    polyfillModulePreloadtrue// 是否自动注入 module preload 的 polyfill  
    outDir'dist'// 指定输出路径  
    assetsDir'assets'// 指定生成静态文件目录  
    assetsInlineLimit'4096'// 小于此阈值的导入或引用资源将内联为 base64 编码  
    cssCodeSplittrue// 启用 CSS 代码拆分  
    cssTarget''// 允许用户为 CSS 的压缩设置一个不同的浏览器 target 与 build.target 一致  
    sourcemapfalse// 构建后是否生成 source map 文件  
    rollupOptions: {}, // 自定义底层的 Rollup 打包配置  
    lib: {}, // 构建为库  
    manifestfalse// 当设置为 true,构建后将会生成 manifest.json 文件  
    ssrManifestfalse// 构建不生成 SSR 的 manifest 文件  
    ssrundefined// 生成面向 SSR 的构建  
    minify'esbuild'// 指定使用哪种混淆器  
    terserOptions: {}, // 传递给 Terser 的更多 minify 选项  
    writetrue// 启用将构建后的文件写入磁盘  
    emptyOutDirtrue// 构建时清空该目录  
    brotliSizetrue// 启用 brotli 压缩大小报告  
    chunkSizeWarningLimit500// chunk 大小警告的限制  
    watchnull// 设置为 {} 则会启用 rollup 的监听器  
  },  
  preview: {  
    port5000// 指定开发服务器端口  
    strictPorttrue// 若端口已被占用则会直接退出  
    httpsfalse// 启用 TLS + HTTP/2  
    opentrue// 启动时自动在浏览器中打开应用程序  
    proxy: { // 配置自定义代理规则  
      '/api': {  
        target'http://jsonplaceholder.typicode.com',  
        changeOrigintrue,  
        rewrite(path) => path.replace(/^\/api/'')  
      }  
    },  
    corstrue// 配置 CORS  
  },  
  optimizeDeps: {  
    entries: [], // 指定自定义条目——该值需要遵循 fast-glob 模式  
    exclude: [], // 在预构建中强制排除的依赖项  
    include: [], // 可强制预构建链接的包  
    keepNamesfalse// true 可以在函数和类上保留 name 属性  
  },  
  ssr: {  
    external: [], // 列出的是要为 SSR 强制外部化的依赖,  
    noExternal''// 列出的是防止被 SSR 外部化依赖项  
    target'node'// SSR 服务器的构建目标  
  }  
}