微信小程序几种数据通信方式记录

news2025/1/4 0:21:04

在微信小程序开发中,组件间的数据传递是一个常见的需求。以下是不同组件间数据传递的方式,根据传递的方向(父子、兄弟、跨层级等)提供了多种方法。


1. 父组件向子组件传递数据

通过 properties(组件属性),父组件可以将数据传递给子组件。

父组件(Page 或父组件的 WXML 和 JS):
<child-component custom-data="{{parentData}}" />
Page({
  data: {
    parentData: 'Hello from parent!'
  }
});
子组件(child-component 的 JS 文件):
Component({
  properties: {
    customData: {
      type: String,
      value: '' // 默认值
    }
  },
  observers: {
    customData(newVal) {
      console.log('Received from parent:', newVal);
    }
  }
});

2. 子组件向父组件传递数据

通过 事件机制,子组件可以向父组件传递数据。

子组件(child-component 的 JS 文件):
Component({
  methods: {
    sendDataToParent() {
      this.triggerEvent('customEvent', { data: 'Hello from child!' });
    }
  }
});
父组件(Page 或父组件的 WXML 和 JS):
<child-component bind:customEvent="handleCustomEvent" />
Page({
  handleCustomEvent(e) {
    console.log('Received from child:', e.detail.data);
  }
});

3. 兄弟组件间的数据传递

兄弟组件无法直接通信,通常通过 父组件中转 或使用 全局状态管理

方法 1:通过父组件中转

父组件充当兄弟组件的通信桥梁。

  • 兄弟组件 A 向父组件触发事件,父组件监听并将数据传递给兄弟组件 B。
方法 2:使用全局状态(见方法 4)

4. 全局状态管理

通过小程序的 全局对象状态管理工具 实现组件间的数据共享。

方法 1:使用全局对象(App 对象)
// app.js
App({
  globalData: {
    sharedData: 'Shared data'
  }
});

在组件中访问:

// 任意组件的 JS 文件
const app = getApp();
console.log(app.globalData.sharedData);
方法 2:使用状态管理工具

如 wx-miniprogram/store 等开源库,提供响应式的状态管理功能。


5. 使用 PageComponent 事件系统

如果多个组件在同一个页面,可以利用 页面方法 实现数据共享。

示例:
  1. 组件 A 向页面发送事件:

    Component({
      methods: {
        sendData() {
          this.triggerEvent('sendToPage', { data: 'Data from A' });
        }
      }
    });
    
  2. 页面接收事件并将数据传递给组件 B:

    Page({
      data: {
        dataForB: ''
      },
      handleSendToPage(e) {
        this.setData({ dataForB: e.detail.data });
      }
    });
    
  3. 页面将数据传递给组件 B:

    <component-b custom-data="{{dataForB}}" />
    

6. 自定义 Behavior 实现共享逻辑

Behavior 是一种组件间逻辑复用的方式,多个组件可以通过共享 Behavior 来实现数据共享。

定义 Behavior
// behaviors/shared-data.js
module.exports = Behavior({
  data: {
    sharedValue: 'Shared value'
  },
  methods: {
    updateSharedValue(newValue) {
      this.setData({ sharedValue: newValue });
    }
  }
});
使用 Behavior
// 组件 A
const sharedData = require('behaviors/shared-data.js');
Component({
  behaviors: [sharedData],
  methods: {
    modifySharedValue() {
      this.updateSharedValue('New value from A');
    }
  }
});

// 组件 B
const sharedData = require('behaviors/shared-data.js');
Component({
  behaviors: [sharedData],
  lifetimes: {
    attached() {
      console.log('Shared value:', this.data.sharedValue);
    }
  }
});

7. 微信小程序插件(WeChat Plugin)

如果需要在多个项目间传递数据,可以封装为插件并使用官方提供的 plugin:// 机制。


总结与适用场景

方式场景特点
Properties父传子数据简单直接,单向数据流
事件机制(triggerEvent)子传父数据通过事件触发,适合单层级通信
父组件中转兄弟组件通信父组件作为中转站,数据共享灵活
全局状态管理跨页面、跨组件数据共享适合复杂场景,但引入工具增加复杂度
Behavior共享逻辑、共享数据组件间逻辑复用,减少代码冗余
插件不同小程序间的共享适合大规模复用场景

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2269313.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Android 旋转盘导航栏

1.直接上源码&#xff1a; package com.you.arc;import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.Point; import android.graphics.RectF; import android.support…

手搓一个ChatUI需要分几步

只关注项目代码的同学可以直接跳转目录中的正文部分&#xff0c;查看项目仓库和功能介绍。 引言 Chatbot的UI界面设计&#xff0c;是和传统软件不同的&#xff1a;都是当面一个简洁的对话框&#xff0c;框里预备着热乎的工具&#xff0c;可以随时更新。 像我这样做工的牛马&a…

低代码开发深度剖析:JNPF 如何引领变革

在当今数字化转型加速的时代&#xff0c;低代码开发已成为众多企业提升效率、降低成本的关键利器。它打破了传统开发模式的高门槛和冗长流程&#xff0c;让应用开发变得更加高效、灵活与普惠。 低代码开发的核心优势 低代码开发平台通过可视化的操作界面&#xff0c;减少了对…

uniapp实现APP、小程序与webview页面间通讯

需求&#xff1a; 1、需要在Uniapp开发的APP或小程序页面嵌入一个H5网页&#xff0c;需要拿到H5给APP传递的数据。 2、并且这个H5是使用vuevant开发的。&#xff08;其实跟使用uniapp开发H5一样&#xff09; 实现步骤&#xff1a; 1、首先需要兼容多端和App端&#xff0c;因…

网络游戏之害

网络游戏之害&#xff1a; 网络游戏于今之世风靡四方&#xff0c;其娱人耳目、畅人心怀之效&#xff0c;固为人知&#xff0c;然所藏之害&#xff0c;若隐伏之暗潮&#xff0c;汹涌而至时&#xff0c;足以覆舟&#xff0c;尤以青年为甚&#xff0c;今且缕析其害&#xff0c;以…

数据库的创建与删除:理论与实践

title: 数据库的创建与删除:理论与实践 date: 2024/12/31 updated: 2024/12/31 author: cmdragon excerpt: 在当今的数字时代,数据的管理和存储变得尤为重要。数据库作为数据存储的结构化方案,为数据的增删改查提供了系统化的方法。在一个典型的数据库管理系统中,创建和…

【电机控制】基于STC8H1K28的六步换向——方波驱动(软件篇)

【电机控制】基于STC8H1K28的六步换向——方波驱动&#xff08;软件篇&#xff09; 文章目录 [TOC](文章目录) 前言一、main.c二、GPIO.c三、PWMA.c四、ADC.c五、CMP.c六、Timer.c七、PMSM.c八、参考资料总结 前言 【电机控制】STC8H无感方波驱动—反电动势过零检测六步换向法 …

优化租赁小程序提升服务效率与用户体验的策略与实践

内容概要 在这个快速发展的商业环境中&#xff0c;租赁小程序成为了提升服务效率和用户体验的重要工具。通过对用户需求的深入挖掘&#xff0c;我们发现他们对于功能的便捷性、响应速度和界面的友好性有着极高的期待。因此&#xff0c;针对这些需求&#xff0c;完善租赁小程序…

电子电器架构 --- 智能座舱与AI结合

我是穿拖鞋的汉子&#xff0c;魔都中坚持长期主义的汽车电子工程师。 老规矩&#xff0c;分享一段喜欢的文字&#xff0c;避免自己成为高知识低文化的工程师&#xff1a; 所谓鸡汤&#xff0c;要么蛊惑你认命&#xff0c;要么怂恿你拼命&#xff0c;但都是回避问题的根源&…

C语言 斐波那契数列(递归算法)

C语言 斐波那契数列&#xff08;递归算法&#xff09; 什么是斐波那契数列&#xff1f; 是指这样一个数列&#xff1a;0&#xff0c;1&#xff0c;1&#xff0c;2&#xff0c;3&#xff0c;5&#xff0c;8&#xff0c;13……这个数列从第3项开始 &#xff0c;每一项都等于前两…

互联网直播点播平台EasyDSS无人机视频推拉流技术实现工地远程监控巡检直播

在建筑行业&#xff0c;施工现场的安全管理和实时监控一直是项目管理中的重点。随着技术的进步&#xff0c;无人机工地直播技术成为了一种新兴的解决方案&#xff0c;它不仅能够提高施工透明度&#xff0c;还能够加强现场安全管理。EasyDSS作为一种先进的流媒体技术平台&#x…

【每日学点鸿蒙知识】模拟器开启网络、长时任务、兼容性测试支持、丢帧定位、SO中访问rawfile等

1、模拟器如何开启网络&#xff1f; 模拟器使用的是电脑本身的网络&#xff0c;不通过代理即可访问网络。 2、创建子window后&#xff0c;锁屏很短时间内&#xff0c;应用会被杀死&#xff1f; 没开长时任务&#xff0c;锁屏和退后台保活要开长时任务。 应用退至后台后&…

计算机网络 (18)使用广播信道的数据链路层

一、广播信道的基本概念 广播信道是一种允许一个发送者向多个接收者发送数据的通信信道。在计算机网络中&#xff0c;广播信道通常用于局域网&#xff08;LAN&#xff09;内部的主机之间的通信。这种通信方式的主要优点是可以节省线路&#xff0c;实现资源共享。 二、广播信道数…

深度学习——损失函数汇总

1. 连续值损失函数 总结:主要使用胡贝儿损失函数,应用于连续数值的预测之间的误差损失,参考地址 import torch import torch.nn as nna = torch.tensor([[1, 2], [3, 4]], dtype=torch.float) b = torch.tensor([[3, 5], [8, 6]], dtype=torch.float)loss_fn1 = torch.nn.M…

github 项目分享

今天和大家分享一些github上面搜到关于卫星遥感和水环境相关的项目。 一、WaterDetect 使用端到端算法去识别水体范围的算法&#xff0c;针对哨兵2卫星遥感数据可用。 项目地址&#xff1a; https://github.com/cordmaur/WaterDetect 二、DeepWaterMap 深度卷积神经网络去…

音视频入门基础:MPEG2-PS专题(2)——使用FFmpeg命令生成ps文件

一、错误的命令 通过FFmpeg命令可以将mp4文件转换为ps文件&#xff0c;PS文件中包含PS流数据。 由于PS流/PS文件对应的FFInputFormat结构为&#xff1a; const FFInputFormat ff_mpegps_demuxer {.p.name "mpeg",.p.long_name NULL_IF_CONFIG_SMALL…

活动预告 | Microsoft Azure 在线技术公开课:使用 Azure OpenAI 服务构建生成式应用

课程介绍 通过 Microsoft Learn 免费参加 Microsoft Azure 在线技术公开课&#xff0c;掌握创造新机遇所需的技能&#xff0c;加快对 Microsoft Cloud 技术的了解。参加我们举办的“使用 Azure OpenAI 服务构建生成式应用”活动&#xff0c;了解如何使用包括 GPT 在内的强大的…

springboot523基于Spring Boot的大学校园生活信息平台的设计与实现(论文+源码)_kaic

摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本大学校园生活信息平台就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短时间内处理完毕庞大的数据…

机器学习详解(11):分类任务的模型评估标准

模型评估是利用不同的评估指标来了解机器学习模型的性能&#xff0c;以及其优势和劣势的过程。评估对于确保机器学习模型的可靠性、泛化能力以及在新数据上的准确预测能力至关重要。 文章目录 1 介绍2 评估准则3 分类指标3.1 准确率 (Accuracy)3.2 精确率 (Precision)3.3 召回率…

天天跳绳(???)

广东省人民政府门户网站 https://www.gd.gov.cn/zwgk/zdlyxxgkzl/whjg/content/post... 二沙岛变身智能“运动岛” - 广东省人民政府门户网站 2020年10月20日  广州二沙岛&#xff0c;犹如一颗璀璨明珠点缀在珠江之心&#xff0c;自然风光旖旎&#xff0c;功能分区清 … 公共…