CSS/JS/图片全挂了,部署后页面白屏/资源加载失败?这两个配置项坑了多少人!

很多同学在本地开发时一切正常,但一把项目部署到服务器上就各种崩溃:页面打不开、图片不显示、甚至连JS文件都404了。其实这些问题大概率都跟两个配置有关,而且都和路径相关!

今天就用大白话讲清楚这两个配置到底管啥用,以及怎么设置才能避免部署翻车。


问题一:为什么页面能打开,但CSS/JS/图片全挂了?

这通常是因为资源路径错了

想象一下:

你写完代码打包后,生成一个dist文件夹。里面虽然有很多资源,但最终只有一个index.html(因为是单页面应用)。

部署到服务器后,你访问首页(比如 www.example.com)能正常打开,但一点其他路由(比如 www.example.com/about)就白屏,或者资源加载失败。

为什么?

因为你打包时资源用的是相对路径 (比如 ./static/js/main.js)。当你访问首页时,浏览器拼接出来的路径是:
www.example.com/static/js/main.js ✅ 能访问到。

但如果你访问的是/about页面,浏览器会尝试拼接:
www.example.com/about/static/js/main.js ❌ 这个路径根本不存在!

怎么解决?

在打包工具的配置中(比如Vue的vue.config.js或React的webpack.config.js)设置**公共路径(publicPath)**为绝对路径:

js 复制代码
// vue.config.js
module.exports = {
  publicPath: '/'
  // 或者如果你的项目部署在子路径(如/www/demo/),则设为 '/demo/'
};

这样打包后所有资源都会从根路径开始查找(比如 /static/js/main.js),不管在哪个页面访问,资源路径都是对的。


问题二:为什么页面能打开,资源也加载了,但路由跳转失效?

这是因为路由配置少了基础路径

比如你的项目部署在服务器子目录(如 www.example.com/demo/),但你的路由配置还是本地开发时的根路径:

js 复制代码
const router = new VueRouter({
  routes: [...],
  mode: 'history'
});

结果你访问 www.example.com/demo/about 时,路由拿着/about去匹配,但实际部署的路径是/demo/about,当然匹配不上!

怎么解决?

在路由配置中加上base选项:

js 复制代码
const router = new VueRouter({
  routes: [...],
  mode: 'history',
  base: '/demo/' // 这里填你的部署子路径
});

更聪明的做法是通过环境变量动态设置

js 复制代码
base: process.env.BASE_URL

然后在开发环境设为空,生产环境设为你的子路径(比如/demo/),这样本地和部署都能正常工作。


总结一下:

  1. 资源加载失败 → 检查打包配置的 publicPath,改成绝对路径(一般是 '/'
  2. 路由跳转失败 → 检查路由配置的 base,确保和部署路径一致

这两个配置项改起来就一行代码,但如果不理解背后的原理,出了问题根本不知道从哪下手。希望这篇能帮你少走弯路!

相关推荐
小小小小宇12 分钟前
LLM 长期记忆构建
前端
lichenyang45324 分钟前
从 Express 老项目到 NestJS + Docker:一次车辆管理系统的渐进式重构
前端
Momo__2 小时前
VueUse createReusableTemplate —— 单文件组件内的模板复用神器
前端·vue.js
程序员小富2 小时前
我开源了一个开发者专属的智能 JSON 工具,得到了媳妇高度认可
前端·vue.js·后端
小小小小宇2 小时前
程序员如何给 LLM 装工具以及看懂推理过程
前端
写代码的皮筏艇2 小时前
React中的forwardRef
前端·react.js·面试
槑有老呆2 小时前
花三个月工资请了个 AI 程序员,结果它连青岛啤酒股价都查不了
前端
风骏时光牛马2 小时前
Verilog开发常见问题汇总解析
前端
子兮曰2 小时前
AI Coding Method Map:一张图看懂 AI 编程的完整链路
前端·人工智能·后端