• uniapp 页面间传参方法


    页面之间传参大概可分为以下几种情况:

    1. 上级页面 → 下级页面(单向)
    2. 上级页面 ← 下级页面(单向)
    3. 上级页面 ↔ 下级页面(双向)

    一、上级页面 → 下级页面(单向)

    uni.navigateTo:URL编程式传参

    作为最常用也是最简单的跳转携带参数的API,这里不多赘述,想详细了解的朋友可以前往官方文档学习,这里只做传参分享。

    官方文档:uni.navigateTo(OBJECT)

    1、携带静态参数
    1. //在起始页面跳转到test.vue页面并传递参数
    2. //作用场景,需要提供固定传参状态的页面,一般和动态参数一起使用
    3. uni.navigateTo({
    4. url: 'test?id=1&name=uniapp'
    5. });
    2、携带动态参数
    1. //在起始页面跳转到test.vue页面并传递参数
    2. let uniapp = {
    3. uniappItem: 0,
    4. };
    5. //当传递的参数是对象时,必须先转化为JSON格式
    6. uni.navigateTo({
    7. url: 'test?id=1&name=' + JSON.stringify(uniapp),
    8. });
    3、页面接收 。注意是在onload方法中接收。
    1. onLoad: function (option) { //option为object类型,会序列化上个页面传递的参数
    2. console.log(option.id); //打印出上个页面传递的参数。
    3. console.log(option.name); //打印出上个页面传递的参数。
    4. }
    4、标签传参

    URL有长度限制,太长的字符串会传递失败,可改用窗体通信全局变量,另外参数中出现空格等特殊字符时需要对参数进行编码,如下为使用encodeURIComponent对参数进行编码的示例。

    1. //此处的 :URL 是动态载入,参数是变量;
    2. //当使用了 :URl 却使用了静态地址,有可能不生效,同样如果使用了变量却没有用 :URL 也会有问题
    3. "'/pages/test/test?item='+ encodeURIComponent(JSON.stringify(item))">

    页面接收

    1. // 在test.vue页面接受参数
    2. onLoad: function (option) {
    3. const item = JSON.parse(decodeURIComponent(option.item));
    4. }

    二、上级页面 ← 下级页面(单向)

    一般来说 uni.navigateTo 的参数传递可以满足页面的传递,但遇到需要更新上级页面的需求时,就需要使用uni.e m i t ( ) 和 u n i . emit()和uni.emit()和uni.on() 进行页面间通讯。

    该方法一般运用在当你从下级页面(或组件)改变数据后,通知上级页面进行刷新或其他操作,实在不清楚也没关系,当你需要时自然明白。

    1、uni.$on(eventName,callback):监听事件

    在上级页面设置 uni.$emit() 来监听下级页面的调用,其中的eventName就是事件名称,第二个参数是接受到函数后触发的回调函数。在监听事件结束后一定要移除监听事件,不然会有重复监听的问题。

    1. // 我的页面
    2. onLoad(){
    3. // 监听事件
    4. uni.$on('login',(usnerinfo)=>{
    5. this.usnerinfo = usnerinfo;
    6. })
    7. },
    8. onUnload() {
    9. // 移除监听事件
    10. uni.$off('login');
    11. },
    2、触发事件

    传递的参数一定是要在对象中的属性

    1. uni.$emit('login', {
    2. avatarUrl: 'https://img-cdn-qiniu.dcloud.net.cn/uploads/nav_menu/10.jpg',
    3. token: 'user123456',
    4. userName: 'unier',
    5. login: true
    6. });

    三、上级页面 ↔ 下级页面(双向) 

    在一般情况下,单向传递已经可以满足我们的业务需求,如向下级页面传递需要显示的参数、变动的状态,向上级页面传递的需要更新的数据或是需要再次调用的函数。

    但遇到两个联系十分紧密的页面时,单向传递就无法满足我们的业务需求,向下级页面传递参数和监听事件就会显得特别繁琐。在uniapp中,它将上面两种传递方式加以结合,提供了这样一个方法去实现双向传递:uni.navigateTo({ event:{} })

    1、上级页面内代码
    1. // 在起始页面跳转到test.vue页面,并监听test.vue发送过来的事件数据
    2. uni.navigateTo({
    3. url: 'pages/test?id=1',
    4. // 调用通信事件对象
    5. events: {
    6. // 获取下级页面参数:
    7. // 为指定事件添加一个监听器,获取被打开页面传送到当前页面的数据
    8. // 注意看下级页面中所对应的函数名,你可以定义多个方法去管理传递的参数
    9. acceptDataFromOpenedPage: function(data) {
    10. // 对数据做处理
    11. console.log(data)
    12. },
    13. someEvent: function(data) {
    14. // 对数据做处理
    15. console.log(data)
    16. }
    17. },
    18. // 发送通信方法
    19. success: function(res) {
    20. // 通过eventChannel向被打开页面传送数据
    21. // 其中含有两个参数,第一个是接收的函数名,第二个则是需要携带的参数
    22. res.eventChannel.emit('acceptDataFromOpenerPage', { data: 'data from starter page' })
    23. }
    24. })
    2、下级页面内代码
    1. // 在test.vue页面,向起始页通过事件传递数据
    2. // 此方法不是一定要在 onLoad 内调用,哪里需要哪里调
    3. onLoad: function(option) {
    4. // 此处声明只是为了显示看起来简洁一点
    5. const eventChannel = this.getOpenerEventChannel();
    6. // emit 代表的就是向上一个页面传递需要更新的数据
    7. eventChannel.emit('acceptDataFromOpenedPage', {data: 'data from test page'});
    8. eventChannel.emit('someEvent', {data: 'data from test page for someEvent'});
    9. // 接收上个页面传递的数据
    10. // 监听acceptDataFromOpenerPage事件,获取上一页面通过eventChannel传送到当前页面的数据
    11. eventChannel.on('acceptDataFromOpenerPage', function(data) {
    12. // 对数据做处理
    13. console.log(data)
    14. })
    15. }

  • 相关阅读:
    Django-图书管理系统(含源码)
    Spring总结
    一份CPP的面试题,这是要招聘大师吗?
    Dubbo Invoker
    wordpress的手工迁移
    【AUTOSAR-CAN-1】DataBase for Can——深入理解 DBC 通信矩阵
    hooks 的定义
    解决nexus3登录x509: certificate has expired or is not yet valid
    Linux常用命令
    常用接口测试及接口抓包常用的测试工具
  • 原文地址:https://blog.csdn.net/yunhuaikong/article/details/134058677