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…

如何理解Js中闭包

闭包(Closure)是JavaScript中的一个重要概念,它指的是函数能够记住并访问它的词法作用域(lexical scope),即使这个函数在其词法作用域之外执行。简而言之,闭包允许你从内部函数访问外部函数的变…

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…

Android -- 调用系统相册之图片裁剪保存

前言 最近线上反馈,部分vivo手机更换头像时调用系统相册保存图片失败,经本人测试,确实有问题。 经修复后,贴出这块的代码供小伙伴们参考使用。 功能 更换头像选择图片: 调用系统相机拍照,调用系统图片…

【Linux刷题练习】

题目 1 题目:Linux 文件权限 -rwxr-xr-x 是什么意思,怎样变更文件夹以及下面所有文件的拥有者? 正确答案:A 知识点: 文件权限: -rwxr-xr-x 表示文件权限: 第一个 - 表示文件类型,…

Android:ViewPaper动态添加移除第一页

问题: 动态改变itemList之后,调用notifyDataSetChanged();没有作用。 原因: 原因是PagerAdapter内部的getItemPosition方法获取的值是固定POSITION_UNCHANGED,表示未改变,所以不更新。 解决: 要更新则…

嵌入式——STM32外设应用

STM32 微控制器以其高性能、低功耗和丰富的外设资源,在嵌入式系统设计中得到了广泛应用。以下将详细介绍 STM32 的主要外设及其典型应用,帮助开发者更好地理解和应用这些功能。 1. GPIO(通用输入输出端口) 功能:GPIO…

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

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

C++集合运算函数总结-

集合必须是有序的, merge:将两个有序范围合并到一个新的有序范围中。 set_union:将两个有序集合的并集存储到第三个集合中。 set_difference:将第一个有序集合中不在第二个有序集合中的元素存储到第三个集合中。 set_symmetri…

LeetCode20:有效的括号

原题地址:. - 力扣(LeetCode) 题目描述 给定一个只包括 (,),{,},[,] 的字符串 s ,判断字符串是否有效。 有效字符串需满足: 左括号必须用相同类型的右括号闭合…

架构师之路-学渣到学霸历程-33

Nginx的常用命令 nginx的重点在于配置文件,但是我们也得懂得这些命令怎么使用的; 先了解一下nginx的命令;如下面笔记~! 1、Nginx命令 Nginx的命令: 如果用yum安装的话,默认会添加到PATH路径如果用源码安…

银河麒麟v10 xrdp安装

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

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

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

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

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

uniapp 实现本地二维码 二维码中间增加图片不显示(显示白块)

使用 uni.getImageInfo({ }) 转化 将 图片地址转化成本地预览地址 initUrqCode(){// let logo http://mujiachaoshi.kiss55.com/78aca7812fd801f8e6d4d4482af70d38uni.getImageInfo({src: this.user.photo,success: (res) > {// 获取uQRCode实例var qr new UQRCode();// …