微信小程序开发 - 为 tap 事件的处理函数传递数据

为 tap 事件的处理函数传递数据

1、基本介绍
  • 在微信小程序中,为 tap 事件的处理函数传递数据,主要通过在组件上设置 data-* 自定义属性来实现
  1. 传递的数据存储在 event.currentTarget.dataset 对象中,currentTarget 指向事件绑定的当前组件

  2. 在 WXML 中,属性名写作短横线形式(例如,data-item-id),在 JS 中获取时,会自动转换为驼峰形式(例如,itemId)

2、演示
html 复制代码
<view bindtap="handleTap" data-user-id="{{123}}" data-user-role="admin">点击我</view>
js 复制代码
Page({
  handleTap(event) {
    const userId = event.currentTarget.dataset.userId;
    const userRole = event.currentTarget.dataset.userRole;
    console.log("userId:", userId);
    console.log("userRole:", userRole);
  },
});
3、常见错误
  1. 写作 bindtap="handleTap(123)",小程序会将整个 "handleTap(123)" 当作一个函数名去查找,导致报错
html 复制代码
<view bindtap="handleTap(123)">点击我</view>
js 复制代码
Page({
  handleTap(data) {
    console.log("data:", data);
  },
});
复制代码
Component "pages/mytest/index" does not have a method "handleTap(123)" to handle event "tap".
  1. 在 WXML 中使用大写,写作 data-itemId="{``{1}}",大写字母会被转为小写,导致 dataset.itemid 存在,而 dataset.itemId 为 undefined
html 复制代码
<view bindtap="handleTap" data-itemId="{{1}}">点击我</view>
js 复制代码
Page({
  handleTap(event) {
    const itemId = event.currentTarget.dataset.itemId;
    console.log("itemId:", itemId);

    const itemid = event.currentTarget.dataset.itemid;
    console.log("itemid:", itemid);
  },
});
复制代码
itemId: undefined
itemid: 1
相关推荐
傻啦嘿哟13 小时前
Python在Excel中创建与优化数据透视表的完整指南
java·前端·spring
Yeniden13 小时前
Deepeek用大白话讲解 --> 状态模式(企业级场景1,自动售货机2,订单状态3,消除if-else4)
java·开发语言·状态模式
拜晨13 小时前
用流式 JSON 解析让 AI 产品交互提前
前端·javascript
浩男孩13 小时前
🍀vue3 + Typescript +Tdesign + HiPrint 打印下载解决方案
前端
yzp-13 小时前
记录一个死锁异常--循环打印 AB go语言
开发语言·后端·golang
andwhataboutit?13 小时前
LANGGRAPH
java·服务器·前端
无限大613 小时前
为什么"Web3"是下一代互联网?——从中心化到去中心化的转变
前端·后端·程序员
cypking13 小时前
CSS 常用特效汇总
前端·css
风月歌13 小时前
小程序项目之超市售货管理平台小程序源代码(源码+文档)
java·微信小程序·小程序·毕业设计·源码
程序媛小鱼13 小时前
openlayers撤销与恢复
前端·js