1、dataset
在標簽中利用 data-xxx 來定義你要傳入的參數,,
然后事件中傳入 event 用 event.currentTarget.dataset.xxx 來取你傳入的值
在 WXML 中,這些自定義數據以 data- 開頭,多個單詞由連字符 - 連接。這種寫法中,連字符寫法會轉換成駝峰寫法,而大寫字符會自動轉成小寫字符。如:
data-element-type,最終會呈現為event.currentTarget.dataset.elementType;data-elementType,最終會呈現為event.currentTarget.dataset.elementtype。
<view data-alpha-beta="1" data-alphaBeta="2" bindtap="bindViewTap"> DataSet Test </view>
Page({ bindViewTap:function(event){ event.currentTarget.dataset.alphaBeta === 1 // - 會轉為駝峰寫法 event.currentTarget.dataset.alphabeta === 2 // 大寫會轉為小寫 } })
2、mark
2.7.1 以上,可以使用 mark 來識別具體觸發事件的 target 節點。此外, mark 還可以用於承載一些自定義數據(類似於 dataset )。
當事件觸發時,事件冒泡路徑上所有的 mark 會被合並,並返回給事件回調函數。(即使事件不是冒泡事件,也會 mark 。)
<view mark:myMark="last" bindtap="bindViewTap"> <button mark:anotherMark="leaf" bindtap="bindButtonTap">按鈕</button> </view>
如果按鈕被點擊,將觸發 bindViewTap 和 bindButtonTap 兩個事件,事件攜帶的 event.mark 將包含 myMark 和 anotherMark 兩項。
Page({ bindViewTap: function(e) { e.mark.myMark === "last" // true e.mark.anotherMark === "leaf" // true } })
細節注意事項:
- 如果存在同名的
mark,父節點的mark會被子節點覆蓋。 - 在自定義組件中接收事件時,
mark不包含自定義組件外的節點的mark。 - 不同於
dataset,節點的mark不會做連字符和大小寫轉換。
