Vue项目打包部署与路由配置深度解析

在Vue.js项目的开发和部署过程中,配置打包路径和路由模式是两个至关重要的环节。下面,我们将详细探讨如何根据需求将Vue项目打包部署到域名的根路径或二级路径,并深入解析hash路由与history路由的配置方法。

一、Vue项目打包部署
1. 配置vue.config.js

vue.config.js是Vue CLI项目的配置文件,用于定制项目构建过程中的各种选项。其中,publicPath属性决定了打包后静态资源的路径前缀。

  • 部署到根路径

    如果希望将Vue项目部署到域名的根路径(如https://yourdomain.com/),则应将publicPath设置为'/'(这是默认值,通常无需显式设置)。

    module.exports = {
      publicPath'/' // 默认值,无需显式设置
    };
  • 部署到二级路径

    如果希望将Vue项目部署到域名的二级路径(如https://yourdomain.com/cms/),则应将publicPath设置为对应的路径(如'/cms/')。

    module.exports = {
      publicPath'/cms/'
    };
2. 打包与部署

在配置好vue.config.js后,使用npm run build命令进行打包。打包完成后,会在项目根目录下生成一个dist文件夹,里面包含了所有静态资源文件。将这些文件上传至服务器上的指定目录,并根据服务器类型(如Nginx、Apache等)进行相应的配置。

3. 服务器配置示例(Nginx)

以Nginx为例,下面展示了如何为Vue项目配置Nginx以支持根路径和二级路径的部署。

  • 根路径部署

    server {listen 80;server_name yourdomain.com;location / {root /path/to/your/vue/dist;try_files $uri $uri/ /index.html; # 捕获所有路由,并返回index.html}
    }
    
  • 二级路径部署

    server {listen 80;server_name yourdomain.com;location /cms {alias /path/to/your/vue/dist; # 注意是alias,不是roottry_files $uri $uri/ /cms/index.html; # 捕获所有/cms/开头的路由,并返回/cms/index.html}
    }
    
二、Vue路由配置
1. hash路由

hash路由是Vue Router的默认模式,它通过URL中的#符号来表示路由路径。这种模式下,页面刷新时不会导致404错误,因为服务器会将所有请求都重定向到index.html(前提是服务器已正确配置)。

  • 配置方法

    在Vue Router的配置中,无需显式设置mode属性(或将其设置为'hash'),即可使用hash路由。

    import Vue from 'vue';
    import Router from 'vue-router';
    import Home from '@/components/Home.vue';

    Vue.use(Router);

    export default new Router({
      // mode: 'hash', // 可选,因为'hash'是默认值
      routes: [
        {
          path'/',
          name'Home',
          component: Home
        },
        // 其他路由配置...
      ]
    });
2. history路由

history路由使用浏览器的History API来修改URL,而不带#符号。这种模式下,页面刷新时需要服务器能够正确处理前端路由,否则会导致404错误。

  • 配置方法

    在Vue Router的配置中,将mode属性设置为'history',并根据项目部署路径设置base属性(如果部署在根路径,则无需设置base)。

    export default new Router({
      mode'history',
      // base: '/cms', // 如果部署在二级路径,则设置该属性为对应的路径
      routes: [
        {
          path'/',
          name'Home',
          component: Home
        },
        // 其他路由配置...
      ]
    });
  • 服务器配置

    使用history路由时,必须确保服务器能够捕获所有前端路由请求,并将它们重定向到index.html(或对应的入口文件)。这通常通过服务器的重写规则或代理配置来实现。

总结

通过合理配置vue.config.js和Vue Router,以及正确设置服务器端的代理规则,你可以轻松地将Vue应用部署到域名的根路径或二级路径,并自由选择使用hash路由或history路由。

在配置过程中,务必注意服务器端的支持情况,以确保前端路由能够正常工作。希望这篇深度解析能够帮助你更好地理解和配置Vue项目的部署和路由。

本文由 mdnice 多平台发布

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/884104.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

无人机之自动控制原理篇

一、飞控系统 无人机飞控是指无人机的飞行控制系统,是无人机的大脑。飞控系统通过传感器、控制器和执行机构三部分实现对无人机的自动控制。 传感器:传感器负责收集无人机的姿态、速度、高度等信息。常见的传感器包括陀螺仪、加速度计、磁力计、气压计、…

得物App获评新奖项,正品保障夯实供应链创新水平

近日,得物App再度获评新奖项——“2024上海市供应链创新与应用优秀案例”。 本次奖项为上海市供应链领域最高奖项,旨在评选出在供应链创新成效上处于领先地位、拥有成功模式和经验的企业。今年以来,得物App已接连获得“上海市质量金奖”、“科…

STM32F103C8T6学习笔记3--按键控制LED灯

1、实验内容 S4、S5分别接PB12和PB13,实验要求,按下S4,D1亮,D2灭;按下S5,D2亮,D1灭。 由于按键学习的是GPIO口的输入功能,和输出功能的配置略有区别。本次通过按键触发相应功能没有…

10.27复习day —— 药销系统分页前(上)

登陆界面 1.auto 水平方向 —— 占据尽量多的空间 margin:auto —— 水平居中 2.块状:block main、div、p 特点: 独占一行 水平方向占满父元素可用空间(所以得设置宽度) 垂直方向占据空间由其内容大小决定 行内:inlin…

clickhouse运维篇(三):生产环境一键生成配置并快速部署ck集群

前提条件:先了解集群搭建流程是什么样,需要改哪些配置,有哪些环境,这个文章目的是简化部署。 clickhouse运维篇(一):docker-compose 快速部署clickhouse集群 clickhouse运维篇(二&am…

快速入门kotlin编程(精简但全面版)

注:本文章为个人学习记录,如有错误,欢迎留言指正。 目录 1. 变量 1.1 变量声明 1.2 数据类型 2. 函数 3. 判断语句 3.1 if 3.2 when语句 4. 循环语句 4.1 while 4.2 for-in 5. 类和对象 5.1 类的创建和对象的初始化 5.2 继承 5…

云原生Istio基础

一.Service Mesh 架构 Service Mesh(服务网格)是一种用于处理服务到服务通信的专用基础设施层。它的主要目的是将微服务之间复杂的通信和治理逻辑从微服务代码中分离出来,放到一个独立的层中进行管理。传统的微服务架构中&#x…

【网页布局技术】项目五 使用CSS设置导航栏

《CSSDIV网页样式与布局案例教程》 徐琴 目录 任务一 制作简单纵向导航栏支撑知识点1.合理利用display:block属性2.利用margin-bottom设置间隔效果3.利用border设置特殊边框 任务二 制作简单横向导航栏任务三 制作带图片效果的横向导航栏任务…

银河麒麟v10 xrdp安装

为了解决科技被卡脖子的问题,国家正在大力推进软硬件系统的信创替代,对于一些平时对Linux操作系统不太熟练的用户来讲提出了更高的挑战和要求。本文以银河麒麟v10 24.03为例带领大家配置kylin v10的远程桌面。 最近公司为了配置信创开发新购了几台银河麒…

什么是x86架构,什么是arm架构

什么是 x86 架构? x86 架构是一种经典的指令集架构(ISA),最早由英特尔在 1978 年推出,主要用于 PC、服务器等领域。 它是一种复杂指令集计算(CISC)架构,支持大量的复杂指令和操作&…

客户的奇葩要求—在CAN网络的基础上加入了CAN_FD的节点

1:客户的奇葩要求 最近的工作中,遇到了一个有点奇葩的事,客户需要开发一个系统,我们负责其中的一个ECU,这个系统采取的是经典11bit ID的CAN网络。 今天突然提了一个要求,说要在网络中,加入支持…

4G 模组的 FTP 应用:技术科普

众所周知FTP协议包括两个组成部分,其一为FTP服务器,其二为FTP客户端,今天我将为大家带来一场4G 模组的 FTP 应用技术科普: 以低功耗模组Air780E核心板为例。 1、FTP 概述 FTP(File Transfer Protocol,文件…

PAT甲级-1074 Reversing Linked List

题目 题目大意 给一个链表的头结点和总节点个数,以及k。每k个节点的链表都要翻转。 思路 链表可以用一个结构体数组来存储,先遍历一遍,过滤掉不在链表中的节点。然后将过滤好的节点放入res数组中,每k个元素用一次reverse()&…

44-RK3588s调试 camera-engine-rkaiq(rkaiq_3A_server)

在RK3588s平台上调试imx415 camera sensor 过程中,已经识别到了camera sensor ID,并且可以拿到raw图和isp处理后的图像,但是isp处理后的图像偏绿,来看查看后台服务发现rkaiq_3A_server没有运行,然后单独运行rkaiq_3A_s…

Python 变量在函数中的作用域

什么是局部变量? 作用范围在函数内部,在函数外部无法使用 什么是全局变量? 在函数内部和外部均可使用 如何将函数内定义的变量声明为全局变量? 使用global关键字, global变量 练习: 演示局部变量 #…

百数功能更新——表单提交支持跳转到外部链接并支持传参

百数的表单外链功能允许用户将表单以链接的形式分享给外部用户,外部用户无需登录或加入团队即可访问并填写表单。 本次更新的表单提交后跳转指定链接的功能,在支持跳转内部链接的基础上,支持用户在完成表单填写并提交后,自动跳转…

BSV区块链为供应链管理带来效率革命

​​发表时间:2024年10月10日 供应链管理是众多行业的重中之重,它确保了商品能够从制造商处顺畅地传递到消费者手中。然而,传统的供应链管理面临着许多挑战,包括缺乏透明度、延误、欺诈和协调上的低效率等等。 BSV区块链技术的出…

Linux基础(七):Linux文件与目录管理

Linux文件与目录管理 1.目录与路径1.1 cd1.2 pwd1.3 mkdir1.4 rmdir1.5 ls1.6 cp1.7 rm1.8 mv 2.可执行文件路径的变量:$PATH3.从字符串中获取目录名称和文件名称4.文件内容读取4.1 cat与tac4.2 nl4.3 more和less4.4 head与tail4.5 od 5 使用touch来改变文件的时间6…

C语言初阶:十一.代码调试技巧

❤欢迎各位大佬访问:折枝寄北-CSDN博客折枝寄北擅长C语言初阶,等方面的知识,折枝寄北关注python,c,java,qt,c语言领域.https://blog.csdn.net/2303_80170533?typeblog❤文章所属专栏https://blog.csdn.net/2303_80170533/category_12794764.html?spm1001.2014.300…

什么是aps排产管理软件?aps排产管理软件有什么用?最详细解释!

近几年,APS排产管理软件特别火,很多制造业企业都在谈论和使用它。不过,因为信息太多太杂,我们平时接收到的往往都是零零碎碎的介绍,很难全面了解它。所以,今天这篇文章就来给大家做个整合,把APS…