当前位置: 首页 > news >正文

Vue 3 和 Vue Router 使用 createWebHistory 配置

在 Vue 3 项目中,如果使用 Vue Router 并希望启用 HTML5 History 模式,需要在创建路由器实例时传入 createWebHistory 作为历史模式的配置。此外,还需要确保在生产环境中设置正确的基本路径(base),这样才能正确处理前端路由。

路由配置

首先,在 router/index.js 文件中,这样配置路由器:

import { createRouter, createWebHistory } from 'vue-router';const router = createRouter({history: createWebHistory(import.meta.env.BASE_URL || '/'),routes: [...], // 定义路由数组
});export default router;

在这里,import.meta.env.BASE_URL 是从 Vite 环境变量读取的,它允许指定应用程序的基本路径。如果没有设置环境变量,它将默认为 '/'。这个配置项一般对应的就是vite.config.ts文件中的base项的配置。

在这里插入图片描述
打印输出看到环境变量中的值:在这里插入图片描述
这一项配置了之后再打包后index.html会是这样:
在这里插入图片描述

打包部署到nginx

Nginx 配置
对于 Nginx 的配置,需要确保所有前端路由都能够正确地映射到Vue 应用程序的入口文件(通常是 index.html)。这是因为在 HTML5 History 模式下,URL 看起来像普通的路径,但实际上并不对应于服务器上的物理文件。因此,需要告诉 Nginx 如何处理这些虚拟路径。

以下是一个 Nginx 配置示例,假设应用程序部署在服务器的根目录下:

server {listen 80;server_name example.com;location / {root /path/to/your/dist; # 替换为实际 dist 目录路径try_files $uri $uri/ /index.html;}
}

如果应用程序部署在子路径下,例如 /myapp,需要相应地调整 location 块和 root 指令:

server {listen 80;server_name example.com;location /myapp {alias /path/to/your/dist; # 替换为实际 dist 目录路径try_files $uri $uri/ /myapp/index.html;}
}

请确保将 /path/to/your/dist 替换为实际构建输出目录的路径,并且根据实际部署情况调整 server_name 和子路径。

以上配置将确保即使用户直接访问一个特定的路由(例如 http://example.com/myapp/some-route),Nginx 也会正确地提供 index.html,然后由 Vue Router 接管并渲染正确的组件。

http://www.lryc.cn/news/462315.html

相关文章:

  • Nginx:rewrite指令之flag标志
  • C#从零开始学习(如何构建应用)
  • FCoE简介
  • 论文笔记:Template-Based Named Entity Recognition Using BART
  • 【Nestjs】从入门到精通(依赖注入)
  • C语言函数
  • FLINK SQLTable API 的基本概念及常用API
  • Docker daemon.json配置参数及格式帮助信息
  • 十月编程语言排行榜~
  • 十三、行为型(策略模式)
  • Vue环境安装以及配置
  • Redis 数据类型hash(哈希)
  • 单一执行和循环执行的例行性工作
  • 单细胞分析 | Cicero+Signac 寻找顺式共可及网络
  • 人工智能创造出大量新型蛋白质
  • Palo Alto Networks Expedition 未授权SQL注入漏洞复现(CVE-2024-9465)
  • c 语言 sprintf
  • stm32单片机个人学习笔记10(TIM编码器接口)
  • 如何在Android中存储数据?
  • 13.3寸工业三防平板数字化工厂产线数采手持终端
  • ssh连接慢的问题或zookeeper远程连接服务超时
  • perf工具使用指导
  • WordPress 禁用上传媒体图片自动生成缩略图及多尺寸图片教程
  • 锥线性规划【分布鲁棒、两阶段鲁棒方向知识点】
  • linux环境下的程序设计与git操作
  • Matlab中HybridFcn参数的用法
  • Leetcode 3316. Find Maximum Removals From Source String
  • jeecg3版本的vue,离线启动
  • C++的内存管理
  • YZ系列工具之YZ09:VBA_Excel之读心术