微信小程序开发系列(十七)·事件传参·mark-自定义数据

目录

步骤一:按钮的创建

步骤二:按钮属性配置

步骤三:添加点击事件

步骤四:参数传递

步骤五:打印数据

步骤六:获取数据

步骤七:父进程验证

总结:data-*自定义数据和mark-自定义数据的区别


        事件传参:在触发事件时,将一些数据作为参数传递给事件处理函数的过程,就是事件传参。

        在小程序>微信小程序中,我们经常会在组件上添加一些自定义数据,然后在事件处理函数中获取这些自定义数据,从而完成业务逻辑的开发。

        上一章我们了解到,在组件上通过data-"的方式定义需要传递的数据,其中*是自定义的属性,例如: <view data-id="100" bindtap="handier"/>然后通过事件对象进行获取自定义数据。

零基础手把手教你创建小程序>微信小程序(十六)·事件传参·data-*自定义数据-CSDN博客

        本章我们讲解另一种方法,小程序进行事件传参的时候,除了使用 data-* 属性传递参数外,还可以使用 mark 标记传递参数mark是一种自定义属性,可以在组件上添加,用于来识别具体触发事件的target节点。

        同时mark还可以用于承载一些自定义数据在组件上使用 mark:自定义属性 的方式将数据传递给事件处理函数。

        例如: <view mark:id="100" bindtap="handler"/>然后通过事件对象进行获取自定义数据

步骤一:按钮的创建

        找到购物车页面,找到其文件路径,快速找到cart.wxml文件,编写代码,创建一个按钮:


<view>
  <button>按钮</button>
</view>

步骤二:按钮属性配置

        找打上一配置的cate.scss文件将其中的内容复制粘贴到cart.scss文件中,配置按钮相关属性:

view{
  display: flex;
  height: 300rpx;
  background-color: skyblue;
  align-items: center;
}

步骤三:添加点击事件

        在cart.wxml文件中创建一个名为“bluHandler”的点击事件:


<view>
  <button bind:tap="btuHandler">按钮</button>
</view>

步骤四:参数传递

        如果需要使用 mark 进行事件传参,如果需要使用 mark:自定义属性的方式进行参数传递:


<view>
  <!-- 如果需要使用 mark 进行事件传参,如果需要使用 mark:自定义属性的方式进行参数传递 -->
  <button bind:tap="btuHandler" mark:id="1" mark:name="tom">按钮</button>
</view>

步骤五:打印数据

        找到cart.js文件,对按钮绑定事件进行处理:


Page({
  
  // 按钮绑定的事件处理函数
  btuHandler(event){
    console.log(event)
  }
})

步骤六:获取数据


Page({

  // 按钮绑定的事件处理函数
  btuHandler(event){
    console.log(event.mark.id)
    console.log(event.mark.name)
  }
})

步骤七:父进程验证

        找到cart.wxml对view添加事件:


<view bind:tap="parentHandler" mark:parentid="1" mark:parentname="tom">
  <!-- 如果需要使用 mark 进行事件传参,如果需要使用 mark:自定义属性的方式进行参数传递 -->
  <!-- <button bind:tap="btuHandler" mark:id="1" mark:name="tom">按钮</button> -->

  <button mark:id="1" mark:name="tom">按钮</button>
</view>

        在找到cart.js文件,对view创建的事件,读取:

        首先点击蓝色区域(不点击按钮):


Page({

  // 按钮绑定的事件处理函数
  btuHandler(event){
    console.log(event.mark.id)
    console.log(event.mark.name)
  },

  //view 绑定的事件处理函数
  parentHandler(event){
    //先点击蓝色区域
    // 通过事件对象获取的是 view 身上绑定的数据
    console.log(event)
  }
})

        点击按钮(不点击蓝色区域):


Page({

  // 按钮绑定的事件处理函数
  btuHandler(event){
    console.log(event.mark.id)
    console.log(event.mark.name)
  },

  //view 绑定的事件处理函数
  parentHandler(event){
    //先点击蓝色区域
    // 通过事件对象获取的是 view 身上绑定的数据

    // 先点击按钮(不点击蓝色区域)
    console.log(event)
  }
})

总结:data-*自定义数据和mark-自定义数据的区别

对于 data-*自定义数据:

点击蓝色区域(不点击按钮)

        currentTarget 事件绑定者:view

        target 事件触发者:view

不点击蓝色区域(点击按钮)     

        currentTarget 事件绑定者:view

        target 事件触发者:按钮


如果想获取 view 身上的数据,就必须使用 currentTarget 才可以。

如果想获取的是时间触发者本身数据,就需要使用 target。

对于 mark-自定义数据:

点击蓝色区域(不点击按钮)

        通过事件对象获取的是 view 身上绑定的数据

不点击蓝色区域(点击按钮)

通过事件对象获取到的是 触发事件的节点 以及父节点身上的所有 mark 数据

小程序>微信小程序开发_时光の尘的博客-CSDN博客


http://www.niftyadmin.cn/n/5409052.html

相关文章

WPF依赖属性概述

文章目录 一、前言二、依赖属性2.1 前置知识2.2 依赖属性与CLR属性2.3 依赖属性支持CLR属性2.4 设置属性值2.4.1 在XAML中设置属性值2.4.2 在代码中设置属性 2.5 依赖属性提供的属性功能2.5.1 资源2.5.2 数据绑定2.5.3 样式2.5.4 动画2.5.5 元数据覆盖2.5.6 属性值继承2.5.7 WP…

MyBatis三个经典问题

1. Mybatis的执行流程 MyBatis 是一个流行的 Java 持久化框架&#xff0c;提供了对象关系映射 (ORM) 和 SQL 映射的功能&#xff0c;使开发者能够更加方便地与数据库交互。MyBatis 的执行流程大致如下&#xff1a; 配置阶段: 加载配置文件: MyBatis 通过读取配置文件&#xff…

[清爽快捷]一条命令解决国内访问github超时For Linux、MAC 、Windows

国内访问github经常超时&#xff0c;通常使用梯子是比较常见的做法&#xff0c;但是梯子收费不太符合互联网的精神。本文给出一条命令解决Ubuntu上git访问github超时的解决办法 方法 在下面选择对应平台的命令复制&#xff0c;打开自己平台的shell&#xff0c;粘贴并执行&…

鸿蒙Harmony应用开发—ArkTS声明式开发(模态转场设置:全屏模态转场)

通过bindContentCover属性为组件绑定全屏模态页面&#xff0c;在组件插入和删除时可通过设置转场参数ModalTransition显示过渡动效。 说明&#xff1a; 从API Version 10开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 不支持横竖屏切换。…

去中心化钱包应用:数字货币时代的自由与安全之选

​小编介绍&#xff1a;10年专注商业模式设计及软件开发&#xff0c;擅长企业生态商业模式&#xff0c;商业零售会员增长裂变模式策划、商业闭环模式设计及方案落地&#xff1b;扶持10余个电商平台做到营收过千万&#xff0c;数百个平台达到百万会员&#xff0c;欢迎咨询。 随…

Vue3只渲染一次 v-once

v-once 指令&#xff1a;用于只渲染一次&#xff0c;首次渲染后&#xff0c;就不会再重新渲染了。 v-once 指令&#xff1a;也可以用在组件上&#xff0c;使组件只加载一次。 语法格式&#xff1a; // 在标签中使用 <div v-once> {{ 数据 }} </div>// 在组件中使…

Ubuntu 22.04 server 安装GNOME/XFCE/KDE桌面环境

在Ubuntu Server上安装桌面环境可以通过以下步骤完成&#xff1a; 安装前请确保您已经在/etc/apt/sources.list 文件中启用了Universe和Multiverse软件库。 首先&#xff0c;通过SSH或物理访问方式登录到Ubuntu Server。 确保系统处于最新状态&#xff0c;运行以下命令进行更…

iOS 中的 UITextField 如何设置才能只输入数字和小数点?

刚接触 iOS不久&#xff0c;接到一个iOS项目&#xff0c;其中有一个需求就是在一个 UITextField中只能输入数字和小数点&#xff0c;这个需求在Android中非常容易&#xff0c;只需要设置 <EditTextandroid:id"id/id_et_price"android:layout_width"match_par…