前端 JS 经典:vue 开发中的 base 和 publicPath

前言:不知各位小伙伴有没有遇到过这样的问题,就是本地开发的好好的,结果打包后自信满满的交给运维部署,一上线,就是页面资源找不到了,跳转页面白屏了。等各种问题,这大概率就是配置问题。有这么两个配置 base 和 publicPath,在 vue2 和 vue3 的表现形式不同,下面会详细介绍。这两个配置一般影响的是生成环境,对本地开发没啥影响。

1. publicPath

publicPath 影响的是打包后外部资源的获取。

比如:如果配置是 publicPath: "./" 或者 publicPath: "",那么打包后 index.html 里的资源就是引入的相对路径,访问 www.a.com 那它的资源就是在 www.a.com/assets/xxx.js 下,这没问题,但是如果访问的路由 www.a.com/a/b/c,因为是单页项目只有一个 index.html,所以这时资源路径是 www.a.com/a/b/assets/xxx.js,这就不对了,拿不到资源,就报错了。所以我们需要将这个值设置为绝对路径 publicPath: "/"。那么不管路由跳转到哪,资源都是在 www.a.com/assets/xxx.js 下的。

vue2 中配置 vue.config.js,其实是 webpack 的配置。

javascript 复制代码
module.exports = {
  publicPath: "/",
};

vue3 中配置 vite.config.js,其实是 vite 的配置。

javascript 复制代码
import { defineConfig } from "vite";

export default defineConfig(() => {
  return {
    base: "/",
  };
});

2. base

base 影响的是组件匹配。

假如运维将我们的站点部署到一个子目录下。比如 admin 文件夹下。路由匹配组件,线上可能就会有问题。比如我们路由写的 /user,转化成完整路径就是 www.a.com/user 去匹配 User.vue 组件,但是生产上是 www.a.com/admin/user 去匹配 User.vue 组件,那肯定就匹配不上,所以我们需要在 router 配置里面,统一配置下 base: "/admin"。

vue2 中配置 base

javascript 复制代码
import VueRouter from "vue-router";

const router = new VueRouter({
  base: "/admin",
});

vue3 中配置 base 就是配置 createWebHistory() 的第一个参数

javascript 复制代码
import { createRouter, createWebHistory } from "vue-router";

const router = createRouter({
  history: createWebHistory("/admin"),
});

总结:一般这两个值,我们会写在环境变量里,到时候可以直接修改,不更改内部代码。

相关推荐
随风一样自由2 分钟前
【前端领域】2026最新前端领域全梳理(框架/工具/AI/跨端/底层标准/就业趋势)
前端·人工智能·前端框架
这是个栗子3 分钟前
【前端性能优化】优化数据加载:用 Promise.all 从串行到并行
前端·javascript·性能优化·异步编程·前端优化·promise.all
fei_sun42 分钟前
黑洞路由(Null Route/空接口路由)
服务器·前端·javascript
大爱一家盟1 小时前
告别卡点BGM同质化 2026原创卡点音乐素材下载网站 TOP5 推荐
大数据·前端·人工智能
彦为君1 小时前
算法思维与经典智力题
java·前端·redis·算法
aa小小2 小时前
localhost 访问异常排查笔记
前端
格子软件2 小时前
2026年GEO优化系统源码的分布式状态机深度拆解
java·前端·vue.js·vue·geo
陈随易2 小时前
Rust、Golang、MoonBit 编译成 WASM,体积和速度差距有多大?
前端·后端·程序员
IT_陈寒2 小时前
Python多线程的坑,我居然现在才踩到
前端·人工智能·后端
摇滚侠2 小时前
方法 A 等方法 B 执行完再执行 叫同步调用还是异步调用 JS 默认是同步调用还是异步调用
开发语言·javascript·ecmascript