title: 使用 navigateTo 实现灵活的路由导航

date: 2024/8/13

updated: 2024/8/13

author: cmdragon

excerpt:

摘要:本文详细介绍 Nuxt.js 中的 navigateTo 函数,包括基本用法、在路由中间件中使用、导航到外部 URL 和新标签页打开链接的方法,以及参数详解和注意事项,展示了该函数在程序化导航中的灵活性和强大功能。

categories:

  • 前端开发

tags:

  • Nuxtjs
  • 路由
  • 导航
  • 编程
  • Web
  • 中间件
  • URL



扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

使用 navigateTo 函数的详细指南

navigateTo 是 Nuxt.js 中一个非常强大的导航辅助函数,允许开发者以编程的方式导航用户,支持服务端与客户端的环境。

什么是 navigateTo

navigateTo 允许我们在自己的代码中灵活地重定向到不同的路由。它可以以字符串或者路由对象的形式接收目标路径,并支持多种选项来定制导航行为。

基本用法

在 Vue 组件中使用 navigateTo 非常简单。以下是一些常见用法的示例:

导航到简单路径


<script setup lang="ts"> // 导航到 '/search'
await navigateTo('/search')
</script>

导航到路由对象

你也可以将路由对象作为参数传递:


<script setup lang="ts"> // 使用路由对象导航
await navigateTo({path: '/search'})
</script>

带查询参数的路由对象

如果需要添加查询参数,可以这样做:


<script setup lang="ts"> // 导航到带有查询参数的路径
await navigateTo({
path: '/search',
query: {
page: 1,
sort: 'asc'
}
})
</script>

在路由中间件中使用

navigateTo 还可以在路由中间件中使用来实现重定向:

// middleware/redirect.js
export default defineNuxtRouteMiddleware((to, from) => {
if (to.path !== '/search') {
// 永久重定向到 '/search'
return navigateTo('/search', {redirectCode: 301})
}
})

导航到外部 URL

默认情况下,navigateTo 不允许导航到外部 URL。如果需要,可以设置 external 参数为 true


<script setup lang="ts"> // 导航到外部URL
await navigateTo('https://nuxt.com', {external: true})
</script>

在新标签页中打开链接

如果想在新标签页中打开链接,可以使用 open 选项:


<script setup lang="ts"> // 在新标签页中打开链接
await navigateTo('https://nuxt.com', {
open: {
target: '_blank',
windowFeatures: {
width: 500,
height: 500
}
}
})
</script>

参数详解

  • to:

    • 类型: RouteLocationRaw | undefined | null
    • 默认值: '/'
    • 解释: 这是目标路由,可以是字符串或路由对象。当其值为 undefinednull 时,默认导航到根路由 '/'

可选参数 (options)

  • replace:

    • 类型: boolean
    • 默认值: false
    • 解释: 如果设置为 true,则会用新路由替换当前路由,而不是将其推入历史记录。
  • redirectCode:

    • 类型: number
    • 默认值: 302
    • 解释: 在服务器端重定向时,使用的状态码。可以使用 301 表示永久重定向。
  • external:

    • 类型: boolean
    • 默认值: false
    • 解释: 如果设置为 true,则可以导航到外部 URL。默认为不允许外部链接。
  • open:

    • 类型: OpenOptions
    • 解释: 用于在客户端上通过 window.open() 方法导航到 URL。服务器端将忽略该选项。

    OpenOptions 的属性:

    • target:

      • 类型: string
      • 默认值: '_blank'
      • 解释: 定义加载资源的上下文名称。
    • windowFeatures:

      • 类型: OpenWindowFeatures
      • 解释: 这组属性控制新窗口的一些特性,如尺寸和位置。

      OpenWindowFeatures 的属性:

      • popup: boolean
      • width / innerWidth: number
      • height / innerHeight: number
      • left / screenX: number
      • top / screenY: number
      • noopener: boolean
      • noreferrer: boolean

示例:使用全部选项

下面是一个复杂的示例,展示如何使用所有选项进行导航:


<script setup lang="ts"> // 复杂的导航示例
await navigateTo('https://example.com', {
external: true,
open: {
target: '_blank',
windowFeatures: {
width: 800,
height: 600,
popup: true
}
}
})
</script>

注意事项

  • 在调用 navigateTo 时,请确保使用 awaitreturn 处理其结果,因为它返回一个 Promise。
  • 使用中间件时请注意重定向代码的选择,根据信息的更新状态选择合适的状态码。

总结

navigateTo 是一个非常强大的工具,能够以灵活和高效的方式进行导航。无论是简单的路由跳转还是复杂的外部 URL

打开,navigateTo 都可以轻松实现

余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长,阅读完整的文章:使用 navigateTo 实现灵活的路由导航 | cmdragon's Blog

往期文章归档:

使用 navigateTo 实现灵活的路由导航的更多相关文章

  1. Vue2学习小记-给Vue2路由导航钩子和axios拦截器做个封装

    1.写在前面 最近在学习Vue2,遇到有些页面请求数据需要用户登录权限.服务器响应不符预期的问题,但是总不能每个页面都做单独处理吧,于是想到axios提供了拦截器这个好东西,再于是就出现了本文. 2. ...

  2. Vue的钩子函数[路由导航守卫、keep-alive、生命周期钩子]

    前言 说到Vue的钩子函数,可能很多人只停留在一些很简单常用的钩子(created,mounted),而且对于里面的区别,什么时候该用什么钩子,并没有仔细的去研究过,且Vue的生命周期在面试中也算是比 ...

  3. vue_VueRouter 路由_路由器管理n个路由_并向路由组件传递数据_新标签路由_编程式路由导航

    路由:就是一个 key 与 value 的映射关系.key 就是 pathh 前台路由的 value 是 Component 组件对象 后台路由的 value 是一个 回调函数 普通链接: 会发送请求 ...

  4. Vue-初步了解vue-router的三要素:路由map 、路由视图、路由导航

    安装vue-router模块 使用vue-router前要先安装vue-router库 cnpm install vue-router –save 使用vue-router vue-router有三个 ...

  5. vue.js编程式路由导航 --- 由浅入深

    编程式路由导航 实例中定义一个方法,这个方法绑定在标签上 然后就设置路由跳转 语法 this.$router.history.push('要跳转路由的地址') <!DOCTYPE html> ...

  6. vue之路由导航守卫-全局前置守卫

    一.使用方式 全局前置守卫用于在路由配置生效之前进行一些动作,可以使用 router.beforeEach 注册一个全局前置守卫: const router = new VueRouter({ ... ...

  7. 【VUE】5.路由导航守卫

    1. 功能需求 1. 当用户登陆成功后,把得到的token存到Session Storage 2. components -> Form.vue , 对预验证进行校验,如果验证不正确就跳出,如果 ...

  8. Vue Router路由导航及传参方式

    路由导航及传参方式 一.两种导航方式 ①:声明式导航 <router-link :to="..."> ②:编程式导航 router.push(...) 二.编程式导航参 ...

  9. 在React中使用 react-router-dom 编程式路由导航的正确姿势【含V5.x、V6.x】

    ## react-router-dom 编程式路由导航 (v5) ###### 1.push跳转+携带params参数 ```jsx props.history.push(`/b/child1/${i ...

  10. vue - 解决页面跳转到外部链接后,ios回退到本页面,生命周期,路由导航守卫钩子都无法触发的问题

    虽然加班,最近心情还是可以的,没多少bug找上门. 乐级生悲,遇到了个奇葩的坑,花了点时间百度才解决...但我离不开的'板砖'是安卓的,对此坑是抗拒的,完全没问题... #此坑描述 ...订单详情某按 ...

随机推荐

  1. UniTask入门指南:简化Unity中的异步编程

    UniTask入门指南:简化Unity中的异步编程 介绍: UniTask是一个轻量级.高性能的异步编程库,专门针对Unity开发进行了优化.与Unity标准的Task系统相比,UniTask提供了更 ...

  2. python + pytest多进程、多线程执行用例生成报告总结

    背景: 使用多进程.多线程执行测试用例,生成测试报告:不使用多进程.多线程,以下两种方式都可生成报告 两种生成报告的形式 1. pytestreport(pytest_session_finish时生 ...

  3. Caffe样例中mnist的文件之间逻辑分析

    约定一下,Caffe运行样例时在终端中使用的所有命令,同时终端中的目录已经cd到Caffe之中(别告诉我一个Github项目你还没有make all就直接拿过来用了) sudo sh data/mni ...

  4. 【读论文】CM-Gen: A Neural Framework for Chinese Metaphor Generation with Explicit Context Modelling

    为了更好的阅读体验,请点击这里 由于发不出论文,所以找点冷门方向做一做.从汉语比喻开始. 读完这篇论文之后我觉得 COLING 这方向我上我也行(ε=ε=ε=┏(゜ロ゜;)┛ 题目:CM-Gen: A ...

  5. CLR via C# 笔记 -- 特性(18)

    1. 特性继承自System.Attribute,能作用于TypeDef(类.结构.枚举.接口和委托),MethodDef(含构造器),ParamDef,FieldDef,PropertyDef,Ev ...

  6. Linux中的IDR机制

    # Linux中的IDR机制 背景 最近在学习 Linux的i2c子系统,看到代码中有关于IDR的调用.了解了一下有关的文档,发现是用来管理指针(对象实例). //based on linux V3. ...

  7. selenium无头浏览器

    from selenium.webdriver import Edge # 在这里导入浏览器设置相关的类 from selenium.webdriver.edge.options import Opt ...

  8. typora markdown笔记

    前言 此为个人markdown笔记,不定时更新. 正文 1. mermaid 使用 横向流程图 源码 graph LR a(起始)-->b(中间) b-->c1<-->d b- ...

  9. MySql常用日期时间查询

    -- 某一天所在周的第一天: -- 我们知道国外的星期的第一天是从星期天开始的,所以DAYOFWEEK('2017-3-10')函数的第一天是星期天: SELECT CASE WHEN DAYNAME ...

  10. Spring5.X常见的注入方式

    使用set方法注入 Video.java package net.cybclass.sp.domain; public class Video { private int id; private St ...