微信小程序中常见的 跳转方式 及其特点的表格总结(wx.navigateTo 适合必要 ...

打印 上一主题 下一主题

主题 883|帖子 883|积分 2649

以下是微信小程序中常见的跳转方式及其特点的表格总结:
跳转方式API 方法特点适用场景wx.navigateTowx.navigateTo({ url: '路径' })保留当前页面,跳转到新页面(非 tabBar 页面)。最多支持 10 层页面栈。用于跳转到非 tabBar 页面,且必要返回上一页的场景。wx.redirectTowx.redirectTo({ url: '路径' })关闭当前页面,跳转到新页面(非 tabBar 页面)。用于不必要返回当前页面的场景,如登录后跳转到主页。wx.switchTabwx.switchTab({ url: '路径' })跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面。用于切换到 tabBar 页面的场景。wx.reLaunchwx.reLaunch({ url: '路径' })关闭所有页面,跳转到新页面(可以是 tabBar 或非 tabBar 页面)。用于重置应用状态并跳转到新页面的场景,如退出登录后跳转到登录页。wx.navigateBackwx.navigateBack({ delta: 1 })返回上一页面或多层页面,delta 参数指定返回的层数。用于返回上一页或多层页面的场景。wx.navigateToMiniProgramwx.navigateToMiniProgram({ appId: '目的小程序appId' })跳转到其他小程序。用于跳转到其他小程序的场景。wx.navigateBackMiniProgramwx.navigateBackMiniProgram()从其他小程序返回到当前小程序。用于从其他小程序返回当前小程序的场景。
详细阐明


  • wx.navigateTo

    • 特点:保留当前页面,跳转到新页面。
    • 限制:最多只能打开 10 层页面栈。
    • 示例
      1. wx.navigateTo({
      2.   url: '/pages/detail/detail?id=123'
      3. });
      复制代码

  • wx.redirectTo

    • 特点:关闭当前页面,跳转到新页面。
    • 限制:不能跳转到 tabBar 页面。
    • 示例
      1. wx.redirectTo({
      2.   url: '/pages/index/index'
      3. });
      复制代码

  • wx.switchTab

    • 特点:跳转到 tabBar 页面,并关闭其他非 tabBar 页面。
    • 限制:只能跳转到 tabBar 页面。
    • 示例
      1. wx.switchTab({
      2.   url: '/pages/home/home'
      3. });
      复制代码

  • wx.reLaunch

    • 特点:关闭所有页面,跳转到新页面。
    • 限制:无。
    • 示例
      1. wx.reLaunch({
      2.   url: '/pages/login/login'
      3. });
      复制代码

  • wx.navigateBack

    • 特点:返回上一页面或多层页面。
    • 参数:delta 指定返回的层数,默认为 1。
    • 示例
      1. wx.navigateBack({
      2.   delta: 1 // 返回上一页
      3. });
      复制代码

  • wx.navigateToMiniProgram

    • 特点:跳转到其他小程序。
    • 限制:必要目的小程序的 appId,且必要用户授权。
    • 示例
      1. wx.navigateToMiniProgram({
      2.   appId: '目标小程序的appId',
      3.   path: '目标小程序的路径'
      4. });
      复制代码

  • wx.navigateBackMiniProgram

    • 特点:从其他小程序返回到当前小程序。
    • 示例
      1. wx.navigateBackMiniProgram();
      复制代码


总结

微信小程序提供了多种跳转方式,适用于不同的场景:


  • 页面内跳转:wx.navigateTo、wx.redirectTo、wx.reLaunch。
  • tabBar 跳转:wx.switchTab。
  • 返回上一页:wx.navigateBack。
  • 跳转到其他小程序:wx.navigateToMiniProgram、wx.navigateBackMiniProgram。
根据具体需求选择合适的跳转方式,可以提拔用户体验和开发效率。

在微信小程序开发中,wx.navigateTo 是使用最频仍的跳转方式。以下是它的特点和使用场景,以及为什么它是最常用的:

wx.navigateTo 的特点


  • 保留当前页面

    • 跳转到新页面时,当前页面会被保留在页面栈中,用户可以通过返回按钮回到上一页。
    • 适合必要返回上一页的场景。

  • 支持传递参数

    • 可以通过 URL 传递参数到目的页面,例如:
      1. wx.navigateTo({
      2.   url: '/pages/detail/detail?id=123&name=foo'
      3. });
      复制代码
    • 目的页面可以通过 onLoad 生命周期函数接收参数:
      1. Page({
      2.   onLoad(query) {
      3.     console.log(query.id); // 输出 123
      4.     console.log(query.name); // 输出 foo
      5.   }
      6. });
      复制代码

  • 适用于非 tabBar 页面

    • wx.navigateTo 只能跳转到非 tabBar 页面,而 tabBar 页面通常使用 wx.switchTab。

  • 页面栈限制

    • 最多只能打开 10 层页面栈。假如凌驾 10 层,必要先关闭一些页面。


为什么 wx.navigateTo 最常用?


  • 符合用户习惯

    • 用户通常期望通过返回按钮回到上一页,而 wx.navigateTo 正好满意这一需求。

  • 灵活性高

    • 支持传递参数,适合大多数页面跳转场景。
    • 可以跳转到恣意非 tabBar 页面。

  • 开发便捷

    • 代码简朴易用,适合快速开发。

  • 适用场景广泛

    • 例如:

      • 从列表页跳转到详情页。
      • 从表单页跳转到确认页。
      • 从主页跳转到设置页。



其他跳转方式的使用频率


  • wx.redirectTo

    • 使用频率较低,通常用于不必要返回当前页面的场景,例如登录后跳转到主页。

  • wx.switchTab

    • 用于跳转到 tabBar 页面,使用频率中等。

  • wx.reLaunch

    • 使用频率较低,通常用于重置应用状态,例如退出登录后跳转到登录页。

  • wx.navigateBack

    • 使用频率较高,通常用于返回上一页或多层页面。

  • wx.navigateToMiniProgram

    • 使用频率较低,通常用于跳转到其他小程序。


总结



  • wx.navigateTo 是最常用的跳转方式,因为它符合用户习惯、灵活性高且开发便捷。
  • 其他跳转方式(如 wx.switchTab、wx.redirectTo 等)则根据具体场景选择使用。


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

民工心事

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表