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

本文主要是介绍若依ruoyi-vue部署在子域名下(做为子应用),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

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

文章目录

  • 若依ruoyi-vue部署在子域名下(做为子应用)
  • 一、vue.config.js
  • 二、router/index.js
  • 三、Navbar.vue
  • 四、request.js
  • 五、修改nginx配置
  • 六、测试
  • 七、静态资源(图片等)
    • ①:修改静态资源路径
    • ②:背景图片路径
    • ③:动态图片路径
    • ④:获取静态资源的请求


一、vue.config.js

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

publicPath: process.env.NODE_ENV === "production" ? "/health-care" : "/",

在这里插入图片描述

二、router/index.js

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

base: process.env.NODE_ENV === 'production' ? '/health-care' : '/',

在这里插入图片描述

三、Navbar.vue

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

location.href = process.env.NODE_ENV === "production" ? "/health-care" : "" + '/index';

在这里插入图片描述

四、request.js

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

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;
  • 片段
location /health-care {# 配置前端资源的路径,将 /health-care 请求路径映射到实际的项目打包输出目录alias /usr/local/project/item_ruoyi/dist;# 指定默认访问的文件,index.html 或 index.htmindex index.html index.htm;# 尝试访问 URI(即请求路径),如果文件或目录不存在,则将请求重定向到 /health-care/index.html# 这是为了支持 Vue Router 等前端路由方式(history 模式)try_files $uri $uri/ /health-care/index.html;}
  • 完整配置
 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下

在这里插入图片描述

②:背景图片路径

  • 使用相对路径
 background-image: url('../../../assets/img/slices/title@2x.png');
 .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; /* 背景图片居中 */}

③:动态图片路径

  • 有时需要动态获取图片路径
<div class="top-card" v-for="item in button_list" :key="item.id" ><img alt="" :src="item.currentUrl || item.url"/></div>
  • 使用 require 来加载静态资源
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 来加载静态资源
        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);}},

这篇关于若依ruoyi-vue部署在子域名下(做为子应用)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1120560

相关文章

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

SpringShell命令行之交互式Shell应用开发方式

《SpringShell命令行之交互式Shell应用开发方式》本文将深入探讨SpringShell的核心特性、实现方式及应用场景,帮助开发者掌握这一强大工具,具有很好的参考价值,希望对大家有所帮助,如... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F