day02 | 事件绑定

本文介绍了小程序中事件的基本概念,如事件作为渲染层到逻辑层的通信方式,以及常用事件如tap。事件对象的属性如target和currentTarget在处理事件时的作用被详细阐述,特别是bindtap事件用于响应用户触摸。同时,文章讨论了如何在事件处理函数中更新data数据,事件传参的特殊性,以及通过bindinput实现文本框输入与data同步的方法。
摘要由CSDN通过智能技术生成
  1. 什么是事件

事件是渲染层到逻辑层的通讯方式。通过事件可以将用户在渲染层产生的行为,反馈到逻辑层进行业务的处理

2.小程序中常用的事件

3.事件对象的属性列表

当事件回调触发的时候,会收到一个事件对象event,它的详细属性如下表所示:

4.target 和 currentTarget

target 是触发该事件的源头组件,而 currentTarget 则是当前事件所绑定的组件。举例如下:

点击内部的按钮时,点击事件以冒泡的方式向外扩散,也会触发外层view的tap事件处理函数。

此时,对于外层的view来说:

  • e.target 指向的是触发事件的源头组件,因此,e.target 是内部的 按钮 组件

  • e.currentTarget 指向的是当前正在触发事件的那个组件,因此,e.currentTarget 是当前的 view组件

5.bindtap

在小程序中,不存在HTML中的onclick鼠标点击事件,而是通过tap事件来响应用户的触摸行为

  1. 通过 bindtap,可以为组件绑定tap触摸事件,语法如下:

<!-- index.wxml -->
<button type="primary" bindtap="btnTapHandler">按钮</button>
  1. 在页面的 .js 文件中定义对应的事件处理函数,事件参数通过形参event(一般简写成e)来接收:

// 定义按钮的时间处理函数
    btnTapHandler(e) {
        console.log(e)
    }

6.在事件处理函数中为 data 中的数据赋值

通过调用 this.setData(dataObject) 方法,可以给页面data 中的数据重新赋值,示例如下:

<button type="primary" bindtap="CountChange">+1</button>
// index.js

Page({

    /**
     * 页面初始数据
     */
    data: {
        count: 0,
    },

    // +1 按钮的点击事件处理函数
    CountChange() {
        this.setData({
            count: this.data.count + 1
        })
    }
})

7.事件传参

小程序中的事件传参比较特殊,不能在绑定事件的同时为事件处理函数传递参数。

(info 会被解析为参数的名字;数值 2 会被解析为参数的值)

例如,下面的代码将不能正常工作:

<button type="primary" bindtap="btnTap2" data-info="2">+2</button

这会被认为是字符串

<button type="primary" bindtap="btnTap2" data-info="{{2}}">+2</button>
 btnTap2(e) {
        console.log(e)
    }

event.target.dataset.参数名

在事件处理函数中,通过event.target.dataset.参数名即可获取到具体参数的值,示例代码如下:

<!-- index.wxml -->
<button type="primary" bindtap="btnTap2" data-info="{{2}}">+2</button>
// +2 按钮的点击事件处理函数
    btnTap2(e) {
        this.setData({
            count: this.data.count + e.target.dataset.info
        })
    }

8.实现文本框和 data 之间的数据同步

<!-- index.wxml -->
<input value="{{msg}}" bindinput="inputHandler" />
input {
    border: 1px solid #eee;
    margin: 5px;
    padding: 5px;
    border-radius: 4px;
}
// index.js

Page({
    /**
     * 页面初始数据
     */
    data: {
        msg: '你好,'
    }
})

9.bindinput

在小程序中,通过input事件来响应文本框的输入事件,语法格式如下:

  1. 通过 bindinput,可以为文本框绑定输入事件:

<!-- index.wxml -->
<input value="{{msg}}" bindinput="inputHandler" />
  1. 在页面的 .js 文件中定义事件处理函数:

 // input 输入框的事件处理函数
    inputHandler(e) {
        console.log(e.detail.value)
        // this.setData({
        //     msg: e.detail.value
        // })
    }
 // input 输入框的事件处理函数
    inputHandler(e) {
        // console.log(e.detail.value)
        this.setData({
            msg: e.detail.value
        })
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值