微信小程序事件綁定基本語法示例詳解
更新時間:2025年04月11日 09:06:10 作者:@程序員ALMJ
這篇文章主要介紹了微信小程序事件綁定基本語法示例詳解,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友一起看看吧
微信小程序使用 bind 或 catch 前綴綁定事件,語法如下:
<組件 bind事件名="處理函數" catch事件名="處理函數"></組件>
bind:事件綁定,允許事件冒泡(向父組件傳遞)。catch:事件綁定,阻止事件冒泡(不會向父組件傳遞)。
一、常見事件類型
| 事件名 | 說明 | 適用組件 |
|---|---|---|
tap | 點擊事件 | view, button |
input | 輸入框內容變化 | input, textarea |
submit | 表單提交 | form |
scroll | 滾動事件 | scroll-view |
longpress | 長按事件(350ms) | view, button |
二、事件綁定示例
1. 點擊事件(bindtap / catchtap)
<!-- 點擊事件(允許冒泡) --> <view bindtap="handleTap">點擊我</view> <!-- 阻止冒泡 --> <view catchtap="handleNoBubbleTap">點擊我(不冒泡)</view>
Page({
handleTap() {
console.log("點擊事件觸發(fā)");
},
handleNoBubbleTap() {
console.log("點擊事件觸發(fā),但不會冒泡");
}
});2. 輸入事件(bindinput)
<input bindinput="handleInput" placeholder="輸入內容" />
Page({
handleInput(e) {
console.log("輸入內容:", e.detail.value);
}
});3. 表單提交(bindsubmit)
<form bindsubmit="handleSubmit"> <input name="username" placeholder="用戶名" /> <button form-type="submit">提交</button> </form>
Page({
handleSubmit(e) {
console.log("表單數據:", e.detail.value);
}
});三、事件對象(event)
事件處理函數的參數 event 包含以下關鍵屬性:
| 屬性 | 說明 |
|---|---|
type | 事件類型(如 tap, input) |
target | 觸發(fā)事件的組件(原始事件源) |
currentTarget | 當前綁定事件的組件 |
detail | 額外信息(如輸入框的值) |
timeStamp | 事件觸發(fā)時間戳 |
touches | 觸摸點信息(多指觸控) |
獲取 data-* 自定義數據
<view data-id="123" bindtap="handleDataTap">點擊獲取 data-id</view>
Page({
handleDataTap(e) {
const id = e.currentTarget.dataset.id; // 123
console.log("data-id:", id);
}
});四、阻止事件冒泡(catch vs bind)
bind:允許事件向上冒泡(父組件也會觸發(fā)相同事件)。catch:阻止事件冒泡(僅當前組件觸發(fā))。
示例
<view bindtap="parentTap"> <view catchtap="childTap">點擊我(不會觸發(fā)父組件的 tap)</view> </view>
Page({
parentTap() {
console.log("父組件點擊"); // 不會執(zhí)行(因為子組件用了 catchtap)
},
childTap() {
console.log("子組件點擊");
}
});五、自定義組件事件(triggerEvent)
如果使用自定義組件,可以通過 triggerEvent 觸發(fā)父組件的事件:
子組件
Component({
methods: {
handleTap() {
this.triggerEvent("customevent", { data: "Hello" });
}
}
});父組件
<child bindcustomevent="handleCustomEvent" />
Page({
handleCustomEvent(e) {
console.log("自定義事件數據:", e.detail.data); // "Hello"
}
});六、總結
| 場景 | 推薦寫法 |
|---|---|
| 普通點擊事件 | bindtap="handleTap" |
| 阻止冒泡 | catchtap="handleTap" |
| 表單輸入 | bindinput="handleInput" |
| 表單提交 | bindsubmit="handleSubmit" |
| 自定義組件通信 | triggerEvent + bind事件名 |
到此這篇關于微信小程序事件綁定基本語法的文章就介紹到這了,更多相關微信小程序事件綁定基本語法內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
JavaScript遍歷數組的三種方法map、forEach與filter實例詳解
這篇文章主要介紹了JavaScript遍歷數組的三種方法map、forEach與filter,結合實例形式詳細分析了javascript針對數組遍歷的map、forEach與filter三種方法相關操作技巧與注意事項,需要的朋友可以參考下2019-02-02
詳解TypeScript中的箭頭函數如何實現(xiàn)重載
這篇文章主要為大家詳細介紹了TypeScript中的箭頭函數是如何實現(xiàn)重載的,文中的示例代碼講解詳細,具有一定的參考價值,需要的可以參考一下2023-05-05
JavaScript設計模式之觀察者模式(發(fā)布訂閱模式)原理與實現(xiàn)方法示例
這篇文章主要介紹了JavaScript設計模式之觀察者模式(發(fā)布訂閱模式)原理與實現(xiàn)方法,結合實例形式分析了JavaScript觀察者模式概念、原理、使用方法及相關操作注意事項,需要的朋友可以參考下2018-07-07
利用原生JavaScript實現(xiàn)造日歷輪子實例代碼
這篇文章主要給大家介紹了關于如何利用原生JavaScript實現(xiàn)造日歷輪子的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用JavaScript具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-05-05

