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,确保和部署路径一致

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

相关推荐
楼田莉子5 分钟前
Qt开发学习——QtCreator深度介绍/程序运行/开发规范/对象树
开发语言·前端·c++·qt·学习
暮之沧蓝7 分钟前
Vue总结
前端·javascript·vue.js
木易 士心44 分钟前
Promise深度解析:前端异步编程的核心
前端·javascript
im_AMBER1 小时前
Web 开发 21
前端·学习
又是忙碌的一天1 小时前
前端学习day01
前端·学习·html
Joker Zxc1 小时前
【前端基础】20、CSS属性——transform、translate、transition
前端·css
excel1 小时前
深入解析 Vue 3 源码:computed 的底层实现原理
前端·javascript·vue.js
大前端helloworld1 小时前
前端梳理体系从常问问题去完善-框架篇(react生态)
前端
不会算法的小灰1 小时前
HTML简单入门—— 基础标签与路径解析
前端·算法·html
zero13_小葵司2 小时前
在Vue项目中构建后端配置的动态路由及权限控制体系
前端·javascript·vue.js