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

vue3 + vite2 vue 打包后router-view空白

vue3 + vite2 vue 打包后router-view空白

  • 1. 路由空白的原因分析
    • 1.1 路由模式设置问题
    • 1.2 base 设置问题
    • 1.3 路由中组件的动态导入方式

第一次使用 vite 打包项目,被这个问题搞了大半天,心态有点崩!不过解决完后还是非常开心!

1. 路由空白的原因分析

1.1 路由模式设置问题

  • Hash模式的工作原理如下:

    • 当用户点击页面上的导航菜单时,使用JavaScript代码来更改URL的hash。

    • 当URL的hash部分发生变化时,浏览器会自动触发hashchange事件。开发者可以通过监听 * hashchange事件来捕获URL变化的通知,并根据新的hash值执行相应的操作,如更新页面内容或进行状态管理。

    • 通过hashchange事件的监听,可以实现单页应用(Single Page Application,SPA)中不同页面视图的切换,而无需重新加载整个页面。这是因为只有URL的hash部分发生变化,浏览器并不会向服务器发送新的请求。

    • 对于hash模式下的URL,浏览器并不会向服务器请求相应的资源。因此,当首次加载网页时,只需请求一个HTML页面,并在该页面中引入JavaScript和CSS等资源。

  • History模式的工作原理如下:

    • 通过History API,可以在不导致页面重新加载的情况下,动态地修改浏览器的URL。这意味着,当用户访问新的路径时,浏览器不会向服务器请求新的页面,而只是通过JavaScript代码来更新页面内容。

    • 当用户在网站中浏览不同页面或执行特定操作时,通过调用History API中的方法(如pushState()或replaceState()),可以修改URL的路径部分,从而反映当前页面状态和导航历史。

    • 使用History模式的应用程序通常会预定义一组路由(routes),将URL的路径与特定的页面或视图关联起来。通过监听浏览器的popstate事件,可以捕获URL的变化,并根据新的路径值执行相应的操作。

    • 当用户通过浏览器的前进或后退按钮导航时,也会触发popstate事件。开发者可以在事件处理程序中获取新的路径值,并根据路径值来更新页面内容,以保持URL和应用程序状态同步。

    • 对于History模式下的URL,当用户直接访问特定路径时,浏览器会向服务器发送请求以获取相应的页面。因此,服务器需要进行相应的配置,以确保在各个路径下都返回正确的页面。

  • vue-router设置问题

const route = new createRouter({
  mode: "hash",
   // history:createWebHashHistory(import.meta.env.VITE_RES_URL),
   history: createWebHashHistory(import.meta.env.VITE_RES_URL),
   routes
})
export default route; 

1.2 base 设置问题

1.3 路由中组件的动态导入方式

参考链接

  • 错误方式
 let routes = [{
      path: '/index',
       component: import('@/components/index'),
       name: 'index'
  },]
  • 正确方式
 let routes = [{
      path: '/index',
       component: () => import('@/components/index'),
       name: 'index'
  },]

ps: import(‘@/components/index’) 与 () => import(‘@/components/index’) 加载方式有很大区别!


http://www.kler.cn/a/308305.html

相关文章:

  • SHA-256哈希函数
  • 硬件工程师之电子元器件—二极管(4)之热量对二极管温度特性的影响
  • Docker compose部署portainer
  • WLAN消失或者已连接但是访问不了互联网
  • c++写一个死锁并且自己解锁
  • apache2配置多站点
  • 用最新方案为数据密集型AI供能:将服务器农场沉入旧金山湾
  • 【YashanDB知识库】数据库获取时间和服务器时间不一致
  • Facebook的虚拟现实功能简介:社交网络的新前沿
  • 腾讯地图SDK Android版开发 11 覆盖物示例 4 线
  • 什么是蜘蛛池?有什么作用
  • 【原创】java+swing+mysql长途客车售票管理系统设计与实现
  • CACTI 0.8.7 迁移并升级到 1.2.7记录
  • 【零散技术】详解Odoo17邮件发送(一)
  • Unity 编辑器设置中文
  • 对称密码中的密钥是如何实现安全配送的?
  • 【数据结构】快速排序详解(递归版本)
  • 初始爬虫7
  • 时间安全精细化管理平台存在未授权访问漏洞
  • 项目管理 | 一文读懂什么是敏捷开发管理
  • Zotero使用(一)PDF文件导入不会自动识别
  • 3C认证---GB 4706.1-2005
  • 【Java EE】冯·诺依曼体系结构及其在 JavaEE 中的应用
  • systemctl控制服务和守护进程
  • Redis——常用数据类型set
  • nginx服务器安装和部署代理