微信小程序常用的传值

1.通过 URL 传参

在页面跳转时,可以在 URL 中携带参数进行传递,然后在目标页面的 onLoad 生命周期中获取参数。

复制代码
// 在页面 A 中跳转到页面 B 并传递参数
wx.navigateTo({
  url: '/pages/detail/index?id=123'
});

// 在页面 B 的 onLoad 生命周期中获取参数
onLoad: function (options) {
  console.log(options.id); // 输出 123
}

通过 navigateTo 方法传递数据的方式比较常见,可以通过 wx.setStorageSync 方法在当前页面设置数据,然后在目标页面的 onLoad 生命周期中使用 wx.getStorageSync 方法获取数据。以下是一个示例代码来演示这种传递数据的方式:

在页面 A 中设置数据并跳转到页面 B:

复制代码
// 在页面 A 中设置数据
wx.setStorageSync('key', 'value');

// 使用 navigateTo 方法跳转到页面 B
wx.navigateTo({
  url: '/pages/pageB/pageB'
});

在页面 B 的 onLoad 生命周期中获取数据:

复制代码
Page({
  onLoad: function(options) {
    // 在页面 B 的 onLoad 生命周期中获取数据
    var data = wx.getStorageSync('key');
    console.log(data); // 输出 'value'
  }
});

3.通过全局变量传值

可以在 app.js 文件中定义全局变量,然后在任何页面中都可以访问和修改这些全局变量。

app.js 文件中定义全局变量:

复制代码
// app.js
App({
  globalData: {
    userInfo: null
  }
});

在任意页面中访问和修改全局变量:

复制代码
// 在任意页面中访问和修改全局变量
// 设置全局变量
getApp().globalData.userInfo = { name: 'Alice', age: 30 };
// 获取全局变量
console.log(getApp().globalData.userInfo); // 输出 { name: 'Alice', age: 30 }

4.通过事件总线传值

可以使用事件总线进行页面间通信,创建一个事件总线实例,然后在需要传递数据的页面发送事件,在需要接收数据的页面监听事件。

1.创建一个事件总线实例:

复制代码
// eventBus.js
const EventBus = {
  events: {},
  on: function(event, callback) {
    if (!this.events[event]) {
      this.events[event] = [];
    }
    this.events[event].push(callback);
  },
  emit: function(event, data) {
    if (this.events[event]) {
      this.events[event].forEach(callback => {
        callback(data);
      });
    }
  }
};

module.exports = EventBus;

2.在发送数据的页面发送事件

复制代码
// pageA.js
const eventBus = require('../../utils/eventBus');

// 发送事件
eventBus.emit('dataUpdated', { name: 'Bob', age: 25 });

3.在接收数据的页面监听事件:

复制代码
// pageB.js
const eventBus = require('../../utils/eventBus');

Page({
  onLoad: function() {
    // 监听事件
    eventBus.on('dataUpdated', (data) => {
      console.log(data); // 输出 { name: 'Bob', age: 25 }
    });
  }
});

这些都是微信小程序中常用的页面间传值方式

相关推荐
星光一影2 小时前
美容/心理咨询/问诊/法律咨询/牙医预约/线上线下预约/牙医行业通用医疗预约咨询小程序
mysql·小程序·vue·php·uniapp
游戏开发爱好者83 小时前
H5 混合应用加密 Web 资源暴露到 IPA 层防护的完整技术方案
android·前端·ios·小程序·uni-app·iphone·webview
wangpq3 小时前
记录曾经打开半屏小程序遇到的事
前端·微信小程序
2501_915106324 小时前
最新版本iOS系统设备管理功能全面指南
android·macos·ios·小程序·uni-app·cocoa·iphone
游戏开发爱好者84 小时前
HTTPS DDoS 排查 异常流量到抓包分析
网络协议·ios·小程序·https·uni-app·iphone·ddos
jay神4 小时前
【原创】基于小程序的图书馆座位预约系统
微信小程序·小程序·毕业设计·图书馆自习室座位预约系统·座位预约系统
计算机徐师兄4 小时前
Java基于微信小程序的物流管理系统【附源码、文档说明】
java·微信小程序·物流管理系统·java物流管理系统小程序·物流管理系统小程序·物流管理系统微信小程序·java物流管理系统微信小程序
一点晖光5 小时前
小程序中web-view加载uni-app H5如何使用postMessage方法的解决方案
前端·小程序·uni-app
2501_915918415 小时前
iOS 性能监控 运行时指标与系统行为的多工具协同方案
android·macos·ios·小程序·uni-app·cocoa·iphone
00后程序员张5 小时前
IPA 混淆技术全解,从成品包结构出发的 iOS 应用安全实践与工具组合
android·安全·ios·小程序·uni-app·cocoa·iphone