【vue3|第21期】Vue3中Vue Router的push和replace方法详解

embedded/2024/10/17 20:45:00/

日期:2024年8月9日
作者:Commas
签名:(ง •_•)ง 积跬步以致千里,积小流以成江海……
注释:如果您觉得有所帮助,帮忙点个赞,也可以关注我,我们一起成长;如果有不对的地方,还望各位大佬不吝赐教,谢谢^ - ^
1.01365 = 37.7834;0.99365 = 0.0255
1.02365 = 1377.4083;0.98365 = 0.0006

说在最前面:本文 vue3 的示例代码,在没有另外声名的情况下,均采用 <script setup> 组合式代码风格,风格统一,避免混乱,请各位新老食客放心食用哈 ^ _ ^


文章目录

  • 一、前言
  • 二、基本概念
  • 三、区别与联系
    • 1、联系
    • 2、区别
  • 四、完整示例
    • 1、设置路由
    • 2、使用 push 方法
    • 3、使用 replace 方法
  • 五、结语


在这里插入图片描述


一、前言


Vue.js 的世界里,Vue Router 扮演着至关重要的角色,特别是在单页面应用(SPA)的开发中。Vue Router 不仅负责页面之间的跳转,还管理着页面的生命周期和状态。在 Vue3 中,Vue Router 提供了多种导航方式,其中最基本也最重要的是 pushreplace 方法。这两种方法虽然目的相同,即进行页面跳转,但它们对浏览器历史栈的处理却大相径庭。

二、基本概念


push__26">1、push 方法

push 方法,从字面上理解,就是“推”一个新的记录到历史栈。在 Vue Router 中,当你使用router.push() 进行页面跳转时,这个新页面的 URL 会被添加到浏览器的历史记录中。这意味着用户可以点击浏览器的后退按钮,回到之前的页面。

形式语法示例
声明式<RouterLink :to="xxx"><RouterLink to="/home">首页</RouterLink>
编程式router.push(xxx)router.push({ name: "home" });

replace__35">2、replace 方法

push 不同,replace 方法虽然也会进行页面跳转,但是不会向历史记录中添加新记录,而是替换当前的记录。在使用 router.replace() 进行导航时,新的 URL 会替代当前页面的URL 记录。这意味着用户无法通过后退按钮回到之前的页面。

形式语法示例
声明式<RouterLink :to="xxx" replace><RouterLink to="/home" replace>首页</RouterLink>
编程式router.replace(xxx)router.replace({ name: "home" });

三、区别与联系


1、联系

  • 两者都是 Vue Router 提供的编程式导航方法,可以在 JavaScript 代码中直接调用。
  • 两者都可以用于改变当前路由,并导航到新的路由地址。

2、区别

内容pushreplace
添加历史记录
后退按钮行为可以回到上一页不能回到上一页
适用场景常规页面跳转无后退需求的跳转

四、完整示例


下面,我们将通过一些简单的示例来展示 pushreplace 方法在实际应用中的使用。

1、设置路由

首先,我们需要定义一些路由。假设我们有以下两个组件:Home.vueAbout.vue

  • src/router/index.js
javascript">import { createRouter, createWebHistory } from 'vue-router';
import Home from './components/Home.vue';
import About from './components/About.vue';
const routes = [{ path: '/', component: Home },{ path: '/about', component: About }
];
const router = createRouter({history: createWebHistory(import.meta.env.BASE_URL),routes,
});export default router;
  • src/main.js
javascript">import { createApp } from 'vue'
import App from './App.vue'// import router from '@/router/index'
import router from '@/router'const app = createApp(App)
app.use(router)
app.mount('#app')

push__95">2、使用 push 方法

在组件中,我们可以通过 this.$router.push 来导航到不同的路由。

javascript"><template><button @click="goToHome">首页</button>
</template><script setup lang="ts">
import { useRouter } from 'vue-router';
const router = useRouter();function goToHome() {router.push({ path: '/' });// 也可以名字跳转// router.push({ name: 'Home' });
}
</script>

在上面的例子中,点击按钮会导航到主页,并在历史记录中添加一条新记录。

replace__114">3、使用 replace 方法

同样地,我们可以使用 router.replace 来替换当前的历史记录。

javascript"><template><button @click="goToAbout">关于(Replace)</button>
</template><script setup lang="ts">
import { useRouter } from 'vue-router';
const router = useRouter();function goToAbout() {router.replace({ path: '/about' });// 也可以名字跳转// router.replace({ name: 'About' });
}
}
</script>

在这个例子中,点击按钮会导航到关于页,但不会在历史记录中添加新记录。如果用户尝试点击后退按钮,他们将不会返回到前一个页面。

五、结语


通过上述讲解,我们可以看到 pushreplace 方法在 Vue Router 中的不同用途。push 方法适用于大多数导航情况,而 replace 方法则适用于那些不需要用户返回的情况,如登录后的重定向。了解这两个方法的使用场景,可以帮助我们更好地控制应用的路由行为。


参考文章:s

  • 《Vue Router》

版权声明:本文为博主原创文章,如需转载,请给出:
原文链接:https://blog.csdn.net/qq_35844043/article/details/141059537


http://www.ppmy.cn/embedded/93497.html

相关文章

LVS--DR模式

目录 1 DR模式原理 2 DR模式请求回复过程 3 实验环境 4 开始实验 4.1 配置实验环境 4.2 Router 配置路由转发 4.3 LVS 设置转发规则 4.4 解决vip响应问题 4.5 Web1配置 4.6 Web2配置 5 测试效果 1 DR模式原理 当用户向负载均衡调度器&#xff08;Director Server&#xff09;发…

vue3父组件向子组件传参的具体写法

在Vue 3中&#xff0c;父组件向子组件传参&#xff08;也称作传递props&#xff09;是一种非常基本的通信方式。下面我将详细解释如何在Vue 3中实现这一功能。 1. 定义子组件并接收props 首先&#xff0c;你需要在子组件中定义你想要接收的props。这通过在组件的props选项中完…

模型部署 - docker

docker简介 Docker 是一种开源的容器化平台&#xff0c;允许开发者将应用程序及其依赖项打包到一个标准化的单元中&#xff0c;称为“容器”。这些容器可以在任何支持 Docker 的系统上运行&#xff0c;无需担心环境差异。 为什么需要 Docker&#xff1f; 在传统的开发中&…

Flask 处理响应

Flask 处理响应 直接返回字符串返回重定向返回 JSON 数据返回字典并自动转换为 JSON返回元组基本元组返回包含响应头的元组返回使用 make_response 返回文件自定义响应返回模板 在 Flask 中&#xff0c;处理响应&#xff08;Response&#xff09;是 Web 应用开发中的一个核心环…

嵌入式初学-C语言-十五

函数的概述 函数&#xff1a;实现一定功能的&#xff0c;独立的代码模块&#xff0c;我们的函数一定是先定义后使用使用函数的优势 可以通过函数提供功能给别人使用&#xff0c;当然我们也可以使用别人提供的函数&#xff0c;减少代码量借助函数可以减少重复性代码。实现结构…

如何选择最适合您需求的数据恢复工具?适用于 Windows 的 7 大数据恢复工具

数据丢失可能是一种令人沮丧的经历&#xff0c;无论是由于意外删除、磁盘格式化还是系统崩溃造成的。幸运的是&#xff0c;Windows 用户可以使用几种可靠的数据恢复工具来有效地恢复丢失的文件。以下是七大数据恢复工具的汇总&#xff0c;包括奇客数据恢复的产品&#xff1a; 适…

【Material-UI】按钮与第三方路由库的集成详解

文章目录 一、ButtonBase 组件简介二、与第三方路由库的集成1. React Router示例代码 2. Next.js示例代码 三、客户端导航的优势四、其他自定义集成1. 使用自定义组件示例代码 五、总结 在现代前端开发中&#xff0c;单页应用&#xff08;SPA&#xff09;变得越来越普遍。这种应…

quark-design 原生引入使用说明

说明:旧项目前后不分离 使用原生html开发的情况下 以动作面板举例: esm全局引入的方式 <script type"module"> import quarkd from "https://cdn.jsdelivr.net/npm/quarkd2.0.4/esm" //直接使用 quarkd.ActionSheet({actions: [{ name: "Opti…