【vue-router源码】八、router.go、router.back、router.forward源码解析

供稿:hz-xin.com     日期:2025-01-15
【vue-router源码】系列文章带您深入了解vue-router的内部实现。我们关注的是router.go、router.back、router.forward这三个函数的源码解析。阅读本文前,请确保您熟悉vue-router的基本使用,如需了解,可访问vue-router官网。

go函数允许用户在历史记录中前进或后退,参数delta为正则表示前进,为负则表示后退。

go函数内部调用history.go方法,触发popstate事件。在createWebHistory函数中,通过useHistoryListeners注册popstate事件监听器。此监听器在执行history.go后被激活。

popstate监听函数执行时,调用listeners中的listener。listener在setupListeners方法中被添加,用于根据地址栏的url进行首次跳转。该跳转由push方法完成,进而执行pushWithRedirect方法,最后调用finalizeNavigation,最终调用markAsReady方法。

在markAsReady方法内,调用setupListeners中的一个方法,添加一个监听函数。这个监听函数与push过程相似,但若出现导航取消、冗余或位置错误等错误信息,需要将历史记录回退至相应位置。

go执行流程:通过调用history.go方法触发popstate事件,该事件处理与push过程相似,但在错误处理方面,会将历史记录回退。

back函数实现原理等同于go(-1),即后退一步。

forward函数实现原理等同于go(1),即前进一步。

总结,go、back、forward方法通过调用history.go方法,触发popstate事件,事件处理与push过程相似,但在处理错误信息时,会将历史记录回退到正确位置。

【vue-router源码】八、router.go、router.back、router.forward源码...
go函数允许用户在历史记录中前进或后退,参数delta为正则表示前进,为负则表示后退。go函数内部调用history.go方法,触发popstate事件。在createWebHistory函数中,通过useHistoryListeners注册popstate事件监听器。此监听器在执行history.go后被激活。popstate监听函数执行时,调用listeners中的listener。listener在setu...

vuerouter原理(vuerouter源码分析)
上边代码中关键的第1步,利用Vue.js提供的插件机制.use(plugin)来安装VueRouter,而这个插件机制则会调用该plugin对象的install方法(当然如果该plugin没有该方法的话会把plugin自身作为函数来调用);下边来看下vue-router这个插件具体的实现部分。 VueRouter对象是在src\/index.js中暴露出来的,这个对象有一个静态的install...

vue源码解析(18)--VueRouter初始化
对于非根组件,利用this.$parent指向,通过this._routerRoot访问根组件实例。接下来,注册全局RouterView和RouterLink,确保在任何地方都能使用。Vue Router类定义在src\/index.js文件中。类包含app表示根Vue实例,apps保存所有子组件的Vue实例,options保存路由配置,beforeHooks、resolveHooks和afterHooks表示钩...

vue-srr 实现原理( vuex、vue-router、syncData )
在`src`目录下创建`router`和`store`文件夹,分别用于`vue-router`和`vuex`的配置,以便在服务端使用。对`app.js`、`server-entry.js`、`client-entry.js`和`server.js`进行相应改造,以整合`vue-router`和`vuex`支持。Vue-SSR本质上是通过`webpack`打包`client-entry.js`和`server-entry.js`...

vue-router(vuerouter钩子函数)
首先vue-router实现了在无需刷新页面的情况下更新视图 对比:location.href=""实现了跳转但是刷新了页面 在浏览器环境下的两种方式,分别就是在HTML5History,HashHistory两个类中实现的。 两个模式hash和history 原理: 移动端采用WebView加载Vue单页应用时,要采用hash模式 解释: 我们理想的情况是通过index.html进入页面...

vue-router-next 源码解析
router-view和router-link是vue-router提供的两个基本组件,分别用于动态渲染匹配的路由组件和创建可导航的链接。router-view组件通过响应式机制确保了路由状态的即时更新和组件的动态渲染,而router-link组件则提供了与常规链接相似的交互性,但实现在不刷新页面的情况下切换路由。总结,通过深入解析vue-router...

【vue-router源码】六、router.resolve源码解析
vue-router源码系列带你深入了解v4.0.15版本的实现,前提是对基本用法有一定了解,可通过官网学习。本文焦点是router.resolve的解析过程。router.resolve的核心任务是将给定的路由地址标准化。它接受两个参数:rawLocation(可能为对象或字符串)和currentLocation(可选,默认为currentRoute)。解析过程分为两...

vue-router 使用与原理分析
Vue Router是Vue.js的官方路由工具,旨在简化使用Vue.js构建单页应用(SPA)的流程。对于复杂前端项目,如管理后台,正确理解和使用Vue Router变得尤为重要。Vue Router的使用包含基本步骤:1. 安装Vue Router依赖。2. 在`App.vue`中引入`router-view`,作为渲染容器。3. 创建路由配置文件`router\/index....

【vue-router源码】三、理解Vue-router中的Matcher
在深入探究vue-router的内部机制时,我们关注的重点是Matcher的实现。这个系列文章基于vue-router v4.0.15的源码,如果你尚未熟悉vue-router的基本用法,建议先通过官网学习。Matcher在vue-router中的角色至关重要,它是每个定义路由的转换器,负责路由的创建、修改和删除。createRouter函数通过createRouter...

vue2 router路由源码分析(vue-router 3版本history模式) 简单版_百度...
Vue2中的router功能主要依赖于Vue的实例化和Vue Router的安装过程。Vue Router的核心是处理地址栏的导航和内容的渲染,实现页面间的无缝切换。首先,为了实现Router的管理,我们会创建一个名为VueRouter的文件夹,其中包含一个index.js文件。这个文件会导出一个类,并在其中定义一个install方法,这个方法负责...