• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > 浅谈小程序跨页面之间通信的几种方式

浅谈小程序跨页面之间通信的几种方式

作者:站长图库 字体:[增加 减小] 来源:互联网 时间:2022-04-29

站长图库向大家介绍了小程序跨页面通信,页面之间通信等相关知识,希望对您有所帮助

本篇文章给大家分享几种常见的小程序跨页面之间通信的方式,有需要的可以参考。


浅谈小程序跨页面之间通信的几种方式


小程序是由一个个page构成的,如果存在路由栈为[A,B],A->B传值自然可以一层层传递,但是B->A传递数据就需要额外的辅助方式,以下讨论几种常见的方式。


1、localStorage + onShow

应用场景:A->B/B->A 都可

优点:简单操作,易理解

缺点:调用到storage,有可能设置失败;且设置后是持久缓存,可能污染原逻辑,应及时删除

应用示例:

// 以A->B示例 // A 页面Page({    onShow(){        if(wx.getStorageSync('$datas')){            console.log(wx.getStorageSync('$datas'))  // 11111        }    },}) // B 页面Page({    someActions(){        wx.setStorageSync('$datas','11111')    },})


2、globalData + onShow

应用场景:A->B/B->A 都可

优点:简单操作,易理解;直接操作globalData对象,相比于storage执行效率更高

缺点:设置后是小程序生命周期内都可访问,可能污染原逻辑,应及时删除

应用示例:

// 以A->B示例 // A 页面const app = getApp();Page({    onShow(){        if(app.globalData.$datas){            console.log(app.globalData.$datas)  // 11111        }    },}) // B 页面const app = getApp();Page({    someActions(){        app.globalData.$datas = '11111';    },})


3、小程序本身提供的 EventChannel

应用场景:主要是 B->A

优点:小程序原生提供,可随时销毁

缺点:仅限制在navigateTo中,且要求基础库版本不低于2.7.3

应用示例:

// A页面wx.navigateTo({  url: 'B?id=1',  events: {    // 为指定事件添加一个监听器,获取被打开页面传送到当前页面的数据    acceptDataFromOpenedPage: function(data) {      console.log(data)    },    someEvent: function(data) {      console.log(data)    }    ...  },  success: function(res) {    // 通过eventChannel向被打开页面传送数据    res.eventChannel.emit('acceptDataFromOpenerPage', { data: 'test' })  }})  // B页面Page({  onLoad: function(option){    console.log(option.query)    const eventChannel = this.getOpenerEventChannel()    eventChannel.emit('acceptDataFromOpenedPage', {data: 'test'});    eventChannel.emit('someEvent', {data: 'test'});    // 监听acceptDataFromOpenerPage事件,获取上一页面通过eventChannel传送到当前页面的数据    eventChannel.on('acceptDataFromOpenerPage', function(data) {      console.log(data)    })  }})


4、自定义EventBus

应用场景:A->B/B->A 都可

优点:自定义实现,可扩展

缺点:对wx进行扩展自定义变量,相同eventName可能会重复绑定监听事件

EventBus: 参考这篇EventBus实现

应用示例:

// app.jsconst EventBus = require('./utils/eventBus.js');App({    onLaunch(){        // 将eventBus初始到wx上        wx['$uhomesBus'] = (function () {            if (wx['$uhomesBus']) return wx['$uhomesBus'];            return new EventBus();        })();    }}) // A页面Page({    someActions(){        wx.$uhomesBus.$on('$datas',(data)=>{            console.log(data); // 11111        })    },}) // B页面Page({    emitActions(){        wx.$uhomesBus.$emit('$datas', '11111');    },})


5、获取页面栈实例 getCurrentPages

应用场景:主要是 B->A

优点:小程序原生提供,处理逻辑基本都在B页面

缺点:需要增加匹配页面的相应规则,且路由栈至少有两个页面存在

应用示例:

// A页面Page({    someActions(datas){        console.log(datas); // 11111    },})  // B页面Page({    someActions(){        const pages = getCurrentPages();        if (pages.length < 2) return;                 // 如果页面层级较多,可用循环去匹配到A页面;        // 此处仅做2个页面的示例        const prevPage = pages[pages.length - 1];                 // 路由匹配到A        if (prevPage.route === 'A') {            prevPage.someActions('11111');        }    },})


6、globalData proxy

暂时未试验这种方式,原理上可行;

相应的原理可参考Vue3的数据劫持和订阅通知相结合。


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 浅谈小程序跨页面之间通信的几种方式

相关文章

  • 2022-04-29WordPress程序打开速度慢的三种解决方法
  • 2022-04-29宝塔面板数据库占用磁盘过大怎么办?
  • 2022-04-29Coreldraw简单制作质感的图标
  • 2022-04-29关于蓝奏网盘部分地区无法下载解决方案
  • 2022-04-29MacOS安装VirtualBox的问题小结
  • 2022-04-293大技巧秒杀百度的首页排名
  • 2022-04-29Photoshop制作光滑的金色发光字
  • 2022-04-29禾匠4.4.8微信授权接口修复教程
  • 2022-04-29html5的drag和drop的用法示例
  • 2022-04-29PhotoShop打造石头材质金属文字特效制作教程

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • PhotoShop制作蓝色梦幻动漫签名溶图教程
    • 详解WordPress文章阅读量如何统计和显示(非插件)
    • PHP怎么删除最后一个字符
    • Thinkphp5.0框架的Db操作实例分析【连接、增删改查、链式操作等】
    • uniapp实现微信小程序全局分享的示例代码
    • PHP实现搜索联想功能(基于字典树算法)
    • WordPress获取各类页面链接的函数总结
    • Photoshop合成抽象风格的人物插画教程
    • dedecms文章审核后给会员增加积分或者金币的办法
    • Flex中对表格中某列的值进行数字格式化保留两位小数

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有