vue3 history模式的nginx以及环境变量配置

环境变量配置

.env.prod

JavaScript 复制代码
BASE_URL='/user'

.env.sit

JavaScript 复制代码
BASE_URL='/user'

代码里配置

vue.config.js

JavaScript 复制代码
const { defineConfig } = require('@vue/cli-service');
module.exports = defineConfig({
  transpileDependencies: true,
  publicPath: process.env.BASE_URL,
  })

router/index.js

JavaScript 复制代码
import { createRouter, createWebHistory } from 'vue-router';
import routes from './router.config';
const router = createRouter({
 history: createWebHistory(process.env.BASE_URL),
 routes,
});
export default router;

nginx上配置

比如服务器上项目统一放在app目录下

打开app文件夹,一台服务器可能部署多个项目,就需要给每个项目单独命名一个文件夹,每个项目又有前后端代码。

到这里,如果我们使用的是hash路由,项目已经可以进行访问了,只是有#号,比较丑,路径为: XXXX.XXX.XX/user/#/inde...

想要去掉这个就要使用history模式,并且在nginx中进行配置,如果不配置也能访问,但是刷新后404,nginx的配置如下:

JavaScript 复制代码
   location /user{
      alias   /app/user/front/dist;
      try_files $uri $uri/ /user/index.html;
                autoindex on;
    }

访问的方式变为: XXXX.XXX.XX/user/index (无论怎么刷新都不会有错误,这里最好还要在nginx统一配置错误页面4xx、5XX或者在前端项目里进行路由匹配,不然访问的页面找不到或者崩溃 提示不友好,用户看不明白)。

end

相关推荐
燐妤4 分钟前
前端HTML编程1:初识html
前端·html5
xiaoye37085 分钟前
java接口文档工具 swagger2和swagger3对比
java·服务器·前端
tongyiixiaohuang8 分钟前
基于轻易云的数据集成,实现企业系统间灵活对接
java·前端·数据库
哥本哈士奇13 分钟前
Power BI学习笔记第17篇:Power BI Dashboard 常用布局方案推荐
前端·powerbi
军军君0119 分钟前
数字孪生监控大屏实战模板:固体颗粒物监管平台
前端·javascript·vue.js·typescript·前端框架·echarts·less
菜鸟小码29 分钟前
MapReduce 核心思想:分而治之,大数据处理的智慧之源
前端·javascript·mapreduce
前端那点事33 分钟前
Cookie和Token的核心区别(附使用场景,易懂好记)
前端·vue.js
前端那点事36 分钟前
Vue设计模式实战解析:6种高频模式+源码拆解,面试/开发双适用
前端·vue.js
墩墩大魔王丶37 分钟前
VS Code 如何使用 DeepSeek
前端
木斯佳39 分钟前
前端八股文面经大全:TME QQ音乐前端二面(2026-04-22)·面经深度解析
前端