原生微信小程序事件传参 - bindtap + data-*(包含多参数传参)- 附完整示例

微信小程序:是一种全新的连接用户与服务的方式,它可以在微信内被便捷地获取和传播,同时具有出色的使用体验。

目录

效果

一、介绍

1、官方文档:微信开放文档

二、UI - Vant

1、官方文档:Vant Weapp - 轻量、可靠的小程序 UI 组件库

三、使用步骤

1、创建按钮

2、设置按钮父节点样式

3、创建变量

4、显示参数

5、设置参数文本样式

6、按钮绑定事件并传参

7、动态显示事件参数

8、区分currentTarget 与 target

四、完整示例

example.wxml

example.css

example.ts

 欢迎扫描下方二维码关注VX公众号


效果

一、介绍

1、官方文档:微信开放文档

微信开放文档微信开发者平台文档icon-default.png?t=N7T8https://developers.weixin.qq.com/miniprogram/dev/framework/

二、UI - Vant

1、官方文档:Vant Weapp - 轻量、可靠的小程序 UI 组件库

Vant Weapp - 轻量、可靠的小程序 UI 组件库轻量、可靠的小程序 UI 组件库icon-default.png?t=N7T8https://vant-ui.github.io/vant-weapp/#/home

注:安装 + 使用等配置的链接 - Vant Weapp - 轻量、可靠的小程序 UI 组件库

三、使用步骤

1、创建按钮

<view class="button-wrap">
  <van-button type="primary" size="large">类型A</van-button>
</view>
<view class="button-wrap">
  <van-button type="info" size="large">类型B</van-button>
</view>

2、设置按钮父节点样式

.button-wrap {
  margin: 30rpx 0;
}

3、创建变量

data: {
  id: '',
  type: '',
},

4、显示参数

<view>
  id: <text class="text-color" >{{id}}</text>
</view>
<view>
  type: <text class="text-color">{{type}}</text>
</view>

5、设置参数文本样式

.text-color {
  color: #FF976A;
}

6、按钮绑定事件并传参

<view class="button-wrap">
  <van-button data-id="A01" data-type="A" bindtap="chooseType" type="primary" size="large">类型A</van-button>
</view>
<view class="button-wrap">
  <van-button data-id="B01" data-type="B" bindtap="chooseType" type="info" size="large">类型B</van-button>
</view>

注:官方文档

事件 | 微信开放文档

事件 | 微信开放文档微信开发者平台文档icon-default.png?t=N7T8https://developers.weixin.qq.com/miniprogram/dev/framework/view/wxml/event.html

7、动态显示事件参数

chooseType(e: { currentTarget: { dataset: { id: any; type: any; }; }; }) {
  console.log('e',e);
  const { id, type } = e.currentTarget.dataset;
  this.setData({
    id,
    type
  })
},

8、区分currentTarget 与 target

currentTarget:事件绑定者,也就是,哪个组件绑定了当前事件处理函数。

target:事件触发者,也就是,哪个组件触发了当前事件处理函数。

根据场景选择是使用currentTarget,还是target

四、完整示例

example.wxml

<view class="button-wrap">
  <van-button data-id="A01" data-type="A" bindtap="chooseType" type="primary" size="large">类型A</van-button>
</view>
<view class="button-wrap">
  <van-button data-id="B01" data-type="B" bindtap="chooseType" type="info" size="large">类型B</van-button>
</view>

<view>
  id: <text class="text-color" >{{id}}</text>
</view>
<view>
  type: <text class="text-color">{{type}}</text>
</view>

example.css

.button-wrap {
  margin: 30rpx 0;
}

.text-color {
  color: #FF976A;
}

example.ts

Page({

  /**
   * 页面的初始数据
   */
  data: {
    id: '',
    type: '',
  },

  /**
   * bindtap事件
   */
  chooseType(e: { currentTarget: { dataset: { id: any; type: any; }; }; }) {
    console.log('e',e);
    const { id, type } = e.currentTarget.dataset;
    this.setData({
      id,
      type
    })
  },
})

注:chooseType方法与onLoad生命周期函数同级

 欢迎扫描下方二维码关注VX公众号

  • 21
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,下面是一个简单的封装示例: 1. 在 `components` 目录下新建一个 `select` 目录,然后在 `select` 目录下新建两个文件 `select.wxml` 和 `select.js`。 2. 在 `select.wxml` 文件中编写下拉选择器的模板代码,示例如下: ``` <view class="el-select" bindtap="onSelectTap"> <view class="el-select__input"> <input type="text" class="el-select__inner" placeholder="{{placeholder}}" disabled="{{disabled}}" value="{{selectedText}}"> <i class="el-select__caret el-icon-arrow-down"></i> </view> <view class="el-select-dropdown" hidden="{{!showDropdown}}" catchtouchmove="catchTouchMove"> <scroll-view scroll-y="{{true}}" class="el-select-dropdown__list"> <view class="el-select-dropdown__item" wx:for="{{options}}" wx:key="{{item.value}}" bindtap="onOptionTap" data-value="{{item.value}}"> {{item.label}} </view> </scroll-view> </view> </view> ``` 其中,`placeholder` 表示选择器的占位符,`disabled` 表示选择器是否禁用,`selectedText` 表示当前选中的文本,`showDropdown` 表示下拉框是否显示,`options` 表示下拉框的选项列表。 3. 在 `select.js` 文件中编写组件的逻辑代码,示例如下: ``` Component({ properties: { options: { type: Array, value: [] }, placeholder: { type: String, value: '' }, disabled: { type: Boolean, value: false }, value: { type: [String, Number], value: '', observer: 'onValueChange' } }, data: { selectedValue: '', selectedText: '', showDropdown: false }, methods: { onValueChange: function(newVal) { var options = this.data.options; var selectedItem = options.find(function(item) { return item.value == newVal; }); if (selectedItem) { this.setData({ selectedValue: selectedItem.value, selectedText: selectedItem.label }); } }, onSelectTap: function() { if (this.data.disabled) { return; } this.setData({ showDropdown: !this.data.showDropdown }); }, onOptionTap: function(event) { var value = event.currentTarget.dataset.value; this.setData({ selectedValue: value, selectedText: this.data.options.find(function(item) { return item.value == value; }).label, showDropdown: false }); this.triggerEvent('change', { value: value }); }, catchTouchMove: function() { // 阻止滚动穿透 } } }); ``` 其中,`options` 表示下拉框的选项列表,`placeholder` 表示选择器的占位符,`disabled` 表示选择器是否禁用,`value` 表示当前选中的值,`selectedValue` 表示当前选中的值,`selectedText` 表示当前选中的文本,`showDropdown` 表示下拉框是否显示。 4. 在需要使用下拉选择器的页面中,引入 `select` 组件并传入相关参数示例如下: ``` <import src="../../components/select/select.wxml" /> <template is="select" data="{{ options: options, placeholder: '请选择', value: value }}" /> ``` 其中,`options` 表示下拉框的选项列表,`placeholder` 表示选择器的占位符,`value` 表示当前选中的值。 5. 在需要监听选择器值改变的页面中,使用 `bind:change` 绑定事件即可,示例如下: ``` <import src="../../components/select/select.wxml" /> <view class="page"> <template is="select" data="{{ options: options, placeholder: '请选择', value: value }}" bind:change="onSelectChange" /> </view> ``` 其中,`onSelectChange` 表示选择器值改变时触发的事件处理函数。 这只是一个简单的示例,如果需要更多功能可以根据实际需求进行扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值