vue.config.ts配置代理解决跨域,配置开发环境开启source-map

vue.config.ts

javascript 复制代码
const { defineConfig } = require('@vue/cli-service')

module.exports = defineConfig({
  lintOnSave: false,
  transpileDependencies: true,
  devServer: {
    proxy: {
      '/api': {
        target: 'http://127.0.0.1:5203',
        changeOrigin: true,
        ws: true
      }
    }
  },
  configureWebpack: (config) => {
    // 根据环境动态配置 source-map
    // 开发环境:启用 source-map 便于调试
    // 生产环境:禁用 source-map 提升性能和安全性
    if (process.env.NODE_ENV === 'development') {
      config.devtool = 'source-map'
    } else {
      config.devtool = false
    }
  }
})

完成!✅ 我已经修改了 vue.config.js,现在 source-map 会根据环境自动配置。

改动说明

修改内容

之前

复制代码
config.devtool = "source-map"  // 所有环境都启用

现在

复制代码
if (process.env.NODE_ENV === 'development') {
  config.devtool = 'source-map'  // 仅开发环境启用
} else {
  config.devtool = false  // 生产环境禁用
}

配置效果

开发环境(yarn dev / yarn serve
  • 启用 source-map
  • 便于调试:可以在浏览器中查看原始源码
  • 错误堆栈指向实际源文件位置
  • process.env.NODE_ENV = 'development'
生产环境(yarn build
  • 禁用 source-map
  • 性能优化:构建速度更快
  • 文件体积更小:不生成 .map 文件
  • 安全性提升:源码不会暴露
  • process.env.NODE_ENV = 'production'

为什么要这样做?

开发环境需要 source-map
  • 🔍 精确定位错误:能看到原始的 TypeScript/Vue 代码行号
  • 🐛 便于调试:在 DevTools 中可以设置断点调试源码
  • 📊 性能分析:准确追踪性能瓶颈
生产环境不需要 source-map
  • 🚀 构建更快:减少 20-30% 构建时间
  • 📦 包体积更小:source-map 文件可能占整体大小的 30-50%
  • 🔒 安全性更高:不暴露源码结构和业务逻辑
  • 💰 节省带宽 :用户不需要下载额外的 .map 文件

验证方式

验证开发环境
复制代码
yarn dev
# 检查浏览器 DevTools -> Sources
# 应该能看到 webpack:// 下的源文件
验证生产环境
复制代码
yarn build
# 检查 dist 目录,不应该有 .map 文件
ls dist/js/*.map  # 应该没有 .map 文件

其他 source-map 选项

如果需要更细粒度的控制,可以使用不同的 devtool 值:

复制代码
// 开发环境选项
'source-map'           // 最完整,但最慢
'eval-source-map'      // 推荐:快速且完整
'cheap-module-source-map'  // 较快,行级映射

// 生产环境选项
false                  // 推荐:完全禁用
'hidden-source-map'    // 生成 map 但不引用(用于错误监控)
'nosources-source-map' // 有映射但不含源码

现在你的项目配置更加合理了!开发时可以高效调试,生产时获得最佳性能。🎉

相关推荐
QQ1__8115175155 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态5 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子5 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室5 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI5 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing5 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者5 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册5 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李5 小时前
2026 年 Web 前端开发的 8 个趋势!
前端
里欧跑得慢5 小时前
15. Web可访问性最佳实践:让每个用户都能平等访问
前端·css·flutter·web