若依ruoyi-vue部署在子域名下(做为子应用)

若依ruoyi-vue部署在子域名下(做为子应用)

特殊情况需要部署到子路径下(做为子应用)

文章目录


一、vue.config.js

1. 修改vue.config.js中的 publicPath

js 复制代码
publicPath: process.env.NODE_ENV === "production" ? "/health-care" : "/",

二、router/index.js

1. 修改router/index.js 添加一行base属性

js 复制代码
base: process.env.NODE_ENV === 'production' ? '/health-care' : '/',

三、Navbar.vue

1. 修改src/layout/components/Navbar.vue 中的 location.href

js 复制代码
location.href = process.env.NODE_ENV === "production" ? "/health-care" : "" + '/index';

四、request.js

1. 修改request.js 中的 location.href

js 复制代码
location.href = process.env.NODE_ENV === "production" ? "/health-care" : "" + '/index';

五、修改nginx配置

注意:修改三处

  • nginx配置中是alias而不是root
  • location /health-care
  • try_files uri uri/ /health-care/index.html;
  • 片段
yaml 复制代码
location /health-care {
         # 配置前端资源的路径,将 /health-care 请求路径映射到实际的项目打包输出目录
         alias /usr/local/project/item_ruoyi/dist;

         # 指定默认访问的文件,index.html 或 index.htm
         index index.html index.htm;

         # 尝试访问 URI(即请求路径),如果文件或目录不存在,则将请求重定向到 /health-care/index.html
         # 这是为了支持 Vue Router 等前端路由方式(history 模式)
         try_files $uri $uri/ /health-care/index.html;
     }
  • 完整配置
java 复制代码
 server {
     listen 18080;                #监听端口
     server_name  _;

     location /stage-api/ {
         # 这里配置代理到后端服务的地址
         proxy_pass http://127.0.0.1:8080/;
     }

     location /health-care {
         # 这里配置前端资源的路径
         alias /usr/local/project/item_ruoyi/dist;
         index index.html index.htm;
         try_files $uri $uri/ /health-care/index.html;
     }

 }

六、测试

访问路径后面应该带上子路径/health-care

  • 原访问路径:http://60.20.1.12:18080
  • 现访问路径:http://60.201.12:18080/health-care

七、静态资源(图片等)

①:修改静态资源路径

  • 将public 下的静态资源放在src下

②:背景图片路径

  • 使用相对路径
css 复制代码
 background-image: url('../../../assets/img/slices/title@2x.png');
css 复制代码
 .my-header {
     height: 6%;
     box-sizing: border-box;
     background-image: url('../../../assets/img/slices/title@2x.png');
     background-size: 100% 100%; /* 背景图片覆盖整个元素 */
     background-repeat: no-repeat; /* 防止背景图片重复 */
     background-position: center center; /* 背景图片居中 */
 }

③:动态图片路径

  • 有时需要动态获取图片路径
html 复制代码
<div class="top-card" v-for="item in button_list" :key="item.id" >
     <img alt="" :src="item.currentUrl || item.url"/>
 </div>
  • 使用 require 来加载静态资源
yaml 复制代码
button_list: [
                {
                    id: 1,
                    url:  require('../../../assets/img/slices/center_elder2@2x.png'),
                    hover_url:  require('../../../assets/img/slices/center_elder1@2x.png'),
                    currentUrl: ''
                },
                {
                    id: 2,
                    url:  require('../../../assets/img/slices/center_social2@2x.png'),
                    hover_url:  require('../../../assets/img/slices/center_social1@2x.png'),
                    currentUrl: ''
                }
                ]

④:获取静态资源的请求

  • 使用 require 来加载静态资源
js 复制代码
        async set_register_map() {
            // let response = await axios.get('/json/songJiang.json');
            // let geoJson = response.data;
            // echarts.registerMap('songJiang', geoJson);
            try {
                // 使用 require 来加载 JSON 文件
                let geoJson = require('@/assets/json/songJiang.json');
                echarts.registerMap('songJiang', geoJson);
            } catch (error) {
                console.error('Error loading songJiang.json:', error);
            }
        },
相关推荐
东东5161 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino1 小时前
图片、文件的预览
前端·javascript
2501_920931702 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
AI老李3 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
方也_arkling3 小时前
Element Plus主题色定制
javascript·sass
晓晓莺歌3 小时前
vue3某一个路由切换,导致所有路由页面均变成空白页
前端·vue.js
2601_949809594 小时前
flutter_for_openharmony家庭相册app实战+我的Tab实现
java·javascript·flutter
Up九五小庞4 小时前
开源埋点分析平台 ClkLog 本地部署 + Web JS 埋点测试实战--九五小庞
前端·javascript·开源
摘星编程4 小时前
React Native + OpenHarmony:UniversalLink通用链接
javascript·react native·react.js
qq_177767374 小时前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos