广告位联系
返回顶部
分享到

Android开发微信小程序路由跳转方式

Android 来源:互联网 作者:秩名 发布时间:2022-04-12 21:02:01 人浏览
摘要

官方文档 https://developers.weixin.qq.com/miniprogram/dev/api/route/wx.switchTab.html 路由跳转的两种形式 标签形式 1 navigator url=/pages/test/test open-type=switchTab 跳转到新页面/navigator 通过open-type来选择和上

官方文档

https://developers.weixin.qq.com/miniprogram/dev/api/route/wx.switchTab.html

 

路由跳转的两种形式

 

标签形式

1

跳转到新页面

通过open-type来选择和上面一样的跳转方式

 

js形式

1

2

3

4

5

6

7

8

# wxml文件

# js文件

tiao1:function(){

    wx.reLaunch({

      url: '/pages/test/test',

    })

  }, 

 

快速总结

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

# wxml文件

# js文件

tiao1:function(){

    wx.reLaunch({

      url: '/pages/test/test',

    })

  },   

// 只能跳转到tabBar页面,不能跳转到非tabBar页面,并且关闭

    //所有非tabBar页面,url不能携带参数

     wx.switchTab({

      url: '/pages/test/test',

     })

  //关闭所有的页面,打开应用内的某个页面,他的url可以携带参数

  //在跳转页面的onload生命周期函数中去接收

     wx.reLaunch({

        url: '/pages/test1/test1?name=123;age=18',

      })

    //关闭当前页面,跳转到应用内的某个页面,但是不允许跳转到

    //tabbar页面,他的路由也是可以携带参数的

    wx.redirectTo({

        url: '/pages/test1/test1?name='+this.data.name1+';age=17',

     })

    //保留当前页面,跳转到应用内的某个页面,但是不能跳转到

    //tabbar,可以使用wx.navigateBack返回到原来的页面,

    //他的url也可以带参数,小程序中页面最多栈10层

    wx.navigateTo({

      url: '/pages/test1/test1?name=333',

    })

  //delat表示回退多少层

  wx.navigateBack({

     delta:1

   })

 

小程序路由跳转

 

1.1 wx.switchTab(Object object)

这里的tabBar是底下的导航栏指定的页面,

跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面

参数

Object object

属性 类型 默认值 必填 说明
url string   需要跳转的 tabBar 页面的路径(需在 app.json 的tabBar字段定义的页面),路径后不能带参数。
success function   接口调用成功的回调函数
fail function   接口调用失败的回调函数
complete function   接口调用结束的回调函数(调用成功、失败都会执行)

示例代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

{

  "tabBar": {

    "list": [

      {

        "pagePath": "index",

        "text": "首页"

      },

      {

        "pagePath": "other",

        "text": "其他"

      }

    ]

  }

}

wx.switchTab({

  url: '/index'

})

 

1.2 wx.reLaunch(Object object)

基础库 1.1.0 开始支持,低版本需做兼容处理。

关闭所有页面,打开到应用内的某个页面

参数

Object object

属性 类型 默认值 必填 说明
url string   需要跳转的应用内页面路径,路径后可以带参数。参数与路径之间使用?分隔,参数键与参数值用=相连,不同参数用;分隔;如 'path?key=value;key2=value2'
success function   接口调用成功的回调函数
fail function   接口调用失败的回调函数
complete function   接口调用结束的回调函数(调用成功、失败都会执行)

示例代码

1

2

3

4

wx.reLaunch({

  url: 'test?id=1'

})

// test Page({ onLoad (option) { console.log(option.query) } })

 

1.3 wx.redirectTo(Object object)

关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面。

参数

Object object

属性 类型 默认值 必填 说明
url string   需要跳转的应用内非 tabBar 的页面的路径, 路径后可以带参数。参数与路径之间使用?分隔,参数键与参数值用=相连,不同参数用;分隔;如 'path?key=value;key2=value2'
success function   接口调用成功的回调函数
fail function   接口调用失败的回调函数
complete function   接口调用结束的回调函数(调用成功、失败都会执行)

示例代码

1

2

3

wx.redirectTo({

  url: 'test?id=1'

})

 

1.4 wx.navigateTo(Object object)

保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面。使用wx.navigateBack可以返回到原页面。小程序中页面栈最多十层。

参数

Object object

属性 类型 默认值 必填 说明
url string   需要跳转的应用内非 tabBar 的页面的路径, 路径后可以带参数。参数与路径之间使用?分隔,参数键与参数值用=相连,不同参数用;分隔;如 'path?key=value;key2=value2'
success function   接口调用成功的回调函数
fail function   接口调用失败的回调函数
complete function   接口调用结束的回调函数(调用成功、失败都会执行)

示例代码

1

2

3

4

5

6

7

8

9

wx.navigateTo({

  url: 'test?id=1'

})

// test.js

Page({

  onLoad(option) {

    console.log(option.query)

  }

})

 

1.5 wx.redirectTo与wx.navigateTo的区别

1.利用wx.navigateTo跳转到下一个页面的时候(这时候会执行onHide方法),下一个页面头部会有返回按钮

2.如果不想有返回按钮,可以用wx.redirectTo进行页面跳转(这时候关闭此页面,会执行onUnload生命周期,这样下一个页面就不会有返回按钮了,因为上一个页面已经被关闭了,没有页面可以返回)

 

1.6 wx.navigateBack(Object object)

关闭当前页面,返回上一页面或多级页面。可通过getCurrentPages()获取当前的页面栈,决定需要返回几层。

参数

Object object

属性 类型 默认值 必填 说明
delta number   返回的页面数,如果 delta 大于现有页面数,则返回到首页。
success function   接口调用成功的回调函数
fail function   接口调用失败的回调函数
complete function   接口调用结束的回调函数(调用成功、失败都会执行)

示例代码

1

2

3

4

5

6

7

8

9

10

11

12

13

// 注意:调用 navigateTo 跳转时,调用该方法的页面会被加入堆栈,而 redirectTo 方法则不会。见下方示例代码

// 此处是A页面

wx.navigateTo({

  url: 'B?id=1'

})

// 此处是B页面

wx.navigateTo({

  url: 'C?id=1'

})

// 在C页面内 navigateBack,将返回A页面

wx.navigateBack({

  delta: 2

})


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://www.cnblogs.com/guyouyin123/p/12464237.html
相关文章
  • Kotlin的Collection与Sequence操作异同点介绍

    Kotlin的Collection与Sequence操作异同点介绍
    在Android开发中,集合是我们必备的容器,Kotlin的标准库中提供了很多处理集合的方法,而且还提供了两种基于容器的工作方式:Collection 和
  • 实现一个Kotlin函数类型方法

    实现一个Kotlin函数类型方法
    接口与函数类型 业务开发中,经常会有实现一个函数式接口(即接口只有一个方法需要实现)的场景,大家应该都会不假思索的写出如下代
  • Android10 App启动Activity源码分析
    ActivityThread的main方法 让我们把目光聚焦到ActivityThread的main方法上。 ActivityThread的源码路径为/frameworks/base/core/java/android/app/ActivityThread。 1 2
  • Android10客户端事务管理ClientLifecycleManager源码解析

    Android10客户端事务管理ClientLifecycleManager源码解析
    在Android 10 App启动分析之Activity启动篇(二)一文中,简单地介绍了Activity的生命周期管理器是如何调度Activity进入onCreate生命周期的流程。这
  • Kotlin对象的懒加载方式by lazy与lateinit异同介绍

    Kotlin对象的懒加载方式by lazy与lateinit异同介绍
    属性或对象的延时加载是我们相当常用的,一般我们都是使用 lateinit 和 by lazy 来实现。 他们两者都是延时初始化,那么在使用时那么他们两
  • Android类加载流程分析

    Android类加载流程分析
    本文分析的代码基于Android8.1.0源码。 流程分析 从loadClass开始,我们来看下Android中类加载的流程 /libcore/ojluni/src/main/java/java/lang/ClassLoader.ja
  • Android实现读写USB串口数据的代码

    Android实现读写USB串口数据的代码
    最近在研究USB方面的内容;先后做了关于Android读写HID、串口设备的DEMO。本文比较简单,主要介绍的是Android实现读取串口数据的功能 废话不
  • Epoxy - 在RecyclerView中构建复杂界面
    Diffing 对于复杂数据结构支持的多个视图类型展示在屏幕上, Epoxy此时是尤其有用的. 在这些场景中, 数据可能会被网络请求, 异步 Observable, 用
  • Android性能优化的详细介绍

    Android性能优化的详细介绍
    性能优化是一个app很重要的一部分,一个性能优良的app从被下载到启动到使用都能给用户到来很好的体验。自然我们做性能优化也是从被下
  • Android进阶宝典-插件化2(Hook启动插件中四大组件

    Android进阶宝典-插件化2(Hook启动插件中四大组件
    在上一节,我们主要介绍了如果通过反射来加载插件中的类,调用类中的方法;既然插件是一个apk,其实最重要的是启动插件中的Activity、
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计