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 分钟前
零基础入门前端 第十三届蓝桥杯省赛 :水果拼盘 Flex一篇过(可用于备赛蓝桥杯Web应用开发)
前端·css·职场和发展·蓝桥杯·css3
weixin199701080167 分钟前
《苏宁商品详情页前端性能优化实战》
前端·性能优化
天若有情6737 分钟前
前端HTML精讲02:表单高阶用法+原生校验,告别冗余JS,提升开发效率
前端·javascript·html
蜡台8 分钟前
Vue 组件通信的 12 种解决方案
前端·javascript·vue.js·props
问道飞鱼13 分钟前
【前端知识】React Flow : 一个基于 React 的可视化节点编辑器框架
前端·ai工作流·react flow
qq_4061761416 分钟前
从零到一掌握 React 核心语法与规则:前端开发者必备指南
前端·react.js·前端框架
wefly20171 小时前
jsontop.cn:一站式 JSON 全能工具集,开发全流程效率神器
前端·javascript·python·django·json·json在线转换
XDHCOM2 小时前
Redis远程连接命令详解,分享高效配置与安全实践技巧
前端·redis·安全
YAY_tyy4 小时前
Vue3 + Three.js 实战:自定义 3D 模型加载与交互全流程
前端·javascript·vue.js·threejs