小程序事件系統 —— 33 事件傳參 - data-*自定義數據

事件傳參:在觸發事件時,將一些數據作為參數傳遞給事件處理函數的過程,就是事件傳參;

在微信小程序中,我們經常會在組件上添加一些自定義數據,然后在事件處理函數中獲取這些自定義數據,從而完成業務邏輯的開發,這個過程稱為小程序的事件傳參;

在組件上通過 data-* 定義需要傳遞的數據,其中 * 是自定義的屬性,例如:<view data-id="100" bindtap="handler" />,代碼中的 id 就是自定義的屬性,屬性值 100 是需要傳遞的數據,然后通過事件對象獲取自定義的數據;

下面打開微信開發者工具演示一下事件傳參的使用步驟,在演示完后講解一下相關的注意事項:

  • 在 pges/cate/cate.wxml 文件中添加下面代碼:

    <view><button bind:tap="btnHandler" data-id="1" data-name="tom">按鈕</button>
    </view>
    

    綁定事件 btnHandler,自定義 id 和 name 數據;

  • 在 pages/cate/cate.js 文件中定義 btnHandle 事件處理函數:

      btnHandler(event){console.log(event)}
    
  • 在 pages/cate/cate.scss 文件中定義一下 view 的樣式:

    view {display: flex;height: 300rpx;background-color: skyblue;align-items: center;
    }
    

在頁面中點擊按鈕,在 console 中可以看到打印的事件對象信息,如下:

在這里插入圖片描述
打開事件對象,可以看到在 currentTarget 和 target 中都能看到傳遞的數據信息,如下:

在這里插入圖片描述在這里插入圖片描述
這時候我們需要了解一下 currentTarget 和 target 的區別是什么:

  • currentTarget:事件綁定者,也就是指哪個組件綁定了當前事件處理函數;
  • target:事件觸發者,也就是指哪個組件出發了當前事件處理函數;

在這個例子中,currentTarget 的事件綁定者是 btn 按鈕,target 的事件觸發者也是 btn 按鈕;

接下來看一下 currentTarget 和 target 不是指向同一個組件的情況:

  • 在 pages/cate/cate.wxml 中添加下面代碼:
<view bind:tap="parentHandler" data-parentid="1" data-parentname="tom"><button data-id="1" data-name="tom">按鈕</button>
</view>
  • 在 pages/cate/cate.js 中添加下面代碼:
 parentHandler (event) {console.log(event)}

刷新重新運行,清空 console 區域,點擊按鈕周圍的藍色區域(注意不要點擊按鈕),觀察 console 打印的事件對象信息,如下:

在這里插入圖片描述
可以看到,在打印的事件對象中,currentTarget 獲得的數據是 parentid 和 parentname,可以知道當前的事件綁定者是 view,如下:

在這里插入圖片描述
同樣,target 獲取的數據也是 parentid 和 parentname,可以知道當前事件的觸發者也是 view,如下:

在這里插入圖片描述
下面點擊按鈕(注意不要點擊按鈕外的藍色區域),觀察 console 打印的事件數據,可以發現,currentTarget 綁定的數據是 view 對應的自定義數據,如下:

在這里插入圖片描述
再看一下 target 的數據,可以看到 target 中綁定的數據是 button 中對應的自定義數據,因為這里是點擊按鈕觸發的事件,所以 target 的數據為 button 中定義的數據,如下:

在這里插入圖片描述
接下來講解一下兩個注意事項:

  • 假如事件在傳遞參數的時候,自定義屬性是由多個單詞來組成的,單詞與單詞之間使用中劃線(-)來分隔,獲取事件對象的數據的時候需要使用駝峰格式,比如上面的 parentid 和 parentname 修改為中劃線格式,如下:

    <view bind:tap="parentHandler" data-parent-id="1" data-parent-name="tom"><button data-id="1" data-name="tom">按鈕</button>
    </view>
    

    使用中劃線命名屬性之后,我們在開發者模式中看一下如何獲取對應的數據屬性,打開 console 模式,點擊按鈕,在打印的數據中可以看到,對應的屬性名變為了駝峰命名寫法,如下:

    在這里插入圖片描述
    在定義數據的時候,使用的是中劃線,在獲取數據的時候,使用駝峰格式;

    因此我們需要注意,當使用中劃線命名單詞的時候,獲取事件對象的數據需要使用駝峰格式獲取數據;

  • 假如事件在傳遞參數的時候,自定義參數使用駝峰命名,在獲取事件對象的數據的時候,需要使用全小寫的格式,如下:

    在這里插入圖片描述

簡單對上面的內容進行總結:

  • 事件傳參使用 data-* 的格式;
  • event.currentTarget 是指事件綁定者,event.target 是指事件觸發者;
  • 使用 data- 方法傳遞參數時,多個單詞由中劃線-連接時,獲取事件數據時需要使用駝峰寫法;
  • 使用 data- 方法傳遞參數時,多個單詞由駝峰寫法定義時,獲取事件數據時需要使用全小寫格式;

參考視頻:尚硅谷微信小程序開發教程

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/72803.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/72803.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/72803.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

安卓設備root檢測與隱藏手段

安卓設備root檢測與隱藏手段 引言 安卓設備的root權限為用戶提供了深度的系統控制能力&#xff0c;但也可能帶來安全風險。因此&#xff0c;許多應用&#xff08;如銀行軟件、游戲和流媒體平臺&#xff09;會主動檢測設備是否被root&#xff0c;并限制其功能。這種對抗催生了ro…

如何在Ubuntu上直接編譯Apache Doris

以下是在 Ubuntu 22.04 上直接編譯 Apache Doris 的完整流程&#xff0c;綜合多個版本和環境的最佳實踐&#xff1a; 注意&#xff1a;Ubuntu的數據盤VMware默認是20G&#xff0c;編譯不夠用&#xff0c;給到50G以上吧 一、環境準備 1. 安裝系統依賴 # 基礎構建工具鏈 apt i…

vuejs相關鏈接和格式化插件推薦

vue官網&#xff1a; https://cn.vuejs.org/ 配合路由設置&#xff1a; https://router.vuejs.org/zh/guide/ element plus (vue3) | element UI (vue2)&#xff1a; https://element-plus.org/zh-CN/#/zh-CN 構建工具vite&#xff1a; https://cn.vitejs.dev/ 右鍵選擇…

IDEA中Git版本回退終極指南:Reset與Revert雙方案詳解

目錄 前言一、版本回退前置知識二、Reset方案&#xff1a;整體改寫歷史1、IDEA圖形化操作&#xff08;推薦&#xff09;1.1、查看提交歷史1.2、選擇目標版本1.3、選擇回退模式1.3.1、Soft&#xff08;推薦&#xff09;1.3.2、Mixed1.3.3、Hard&#xff08;慎用&#xff09;1.3.…

PHP并發請求優化:使用`curl_multi_select()`實現高效的多請求處理

PHP并發請求優化&#xff1a;使用curl_multi_select()實現高效的多請求處理 背景 最近在項目中遇到一個需求&#xff0c;需要從多個 1 級網站&#xff08;超過 200 個&#xff09;獲取數據&#xff0c;并且是通過 POST 請求瞬間發送到這些網站上。開始時我直接使用了 curl_ex…

【leetcode hot 100 206】反轉鏈表

解法一&#xff1a;&#xff08;頭插法&#xff09;在遍歷鏈表時&#xff0c;將當前節點的 next 指針改為指向前一個節點。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}* ListNode(int val)…

【QT】-易錯點筆記-2025-2-7

1,QList<phy_simulator*> pList;為空不能append()追加,要先new,再用 QList<phy_simulator> pList為空時,確實不能調用 append() 方法。原因很簡單,QList 是一個類對象,在 C++ 中,指針本身并不代表它指向的對象。因此,當你有一個指向 QList<phy_simulato…

AI-Deepseek + PPT

01--Deepseek提問 首先去Deepseek問一個問題&#xff1a; Deepseek的回答&#xff1a; 在汽車CAN總線通信中&#xff0c;DBC文件里的信號處理&#xff08;如初始值、系數、偏移&#xff09;主要是為了 將原始二進制數據轉換為實際物理值&#xff0c;確保不同電子控制單元&…

實驗一:在Windows 10/11下配置和管理TCP/IP

目錄 1.【實訓目標】 2.【實訓環境】 3.【實訓內容】 4.【實訓步驟】 1.【實訓目標】 1.了解網絡基本配置中包含的協議、服務、客戶端。 2.了解Windows支持的網絡協議及參數設置方法。 3.掌握TCP/IP協議的配置。 2.【實訓環境】 硬件環境&#xff1a;每人一臺計算機&a…

Java直通車系列14【Spring MVC】(深入學習 Controller 編寫)

目錄 基本概念 編寫 Controller 的步驟和要點 1. 定義 Controller 類 2. 映射請求 3. 處理請求參數 4. 調用業務邏輯 5. 返回響應 場景示例 1. 簡單的 Hello World 示例 2. 處理路徑變量和請求參數 3. 處理表單提交 4. 處理 JSON 數據 5. 異常處理 基本概念 Cont…

EA - 開源工程的編譯

文章目錄 EA - 開源工程的編譯概述筆記環境備注x86版本EABase_x86EAAssert_x86EAThread_x86修改 eathread_atomic_standalone_msvc.h原始修改后 EAStdC_x86EASTL_x86EAMain_x86EATest_x86備注備注END EA - 開源工程的編譯 概述 EA開源了‘命令與征服’的游戲源碼 嘗試編譯. 首…

一招解決Pytorch GPU版本安裝慢的問題

Pytorch是一個流行的深度學習框架&#xff0c;廣泛應用于計算機視覺、自然語言處理等領域。安裝Pytorch GPU版本可以充分利用GPU的并行計算能力&#xff0c;加速模型的訓練和推理過程。接下來&#xff0c;我們將詳細介紹如何在Windows操作系統上安裝Pytorch GPU版本。 查看是否…

為解決局域網IP、DNS切換的Windows BAT腳本

一、背景 為解決公司普通人員需要切換IP、DNS的情況&#xff0c;于是搞了個windows下的bat腳本&#xff0c;可以對有線網絡、無線網絡進行切換設置。 腳本內容 echo off title 多網絡接口IP切換工具:menu cls echo echo 請選擇要配置的網絡接口: echo echo 1. 有線網絡&am…

uni_app實現下拉刷新

1. 在頁面配置中啟用下拉刷新 首先&#xff0c;你需要在頁面的 pages.json 文件中啟用下拉刷新功能。 {"pages": [{"path": "pages/index/index","style": {"navigationBarTitleText": "首頁","enablePull…

OpenCV計算攝影學(14)實現對比度保留去色(Contrast Preserving Decolorization)的函數decolor()

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 將彩色圖像轉換為灰度圖像。它是數字印刷、風格化的黑白照片渲染&#xff0c;以及許多單通道圖像處理應用中的基本工具。 cv::decolor 是 OpenCV…

Qt常用控件之 縱向列表QListWidget

縱向列表QListWidget QListWidget 是一個縱向列表控件。 QListWidget屬性 屬性說明currentRow當前被選中的是第幾行。count一共有多少行。sortingEnabled是否允許排序。isWrapping是否允許換行。itemAlignment元素的對齊方式。selectRectVisible被選中的元素矩形是否可見。s…

關于 QPalette設置按鈕背景未顯示出來 的解決方法

若該文為原創文章&#xff0c;轉載請注明原文出處 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/146047054 長沙紅胖子Qt&#xff08;長沙創微智科&#xff09;博文大全&#xff1a;開發技術集合&#xff08;包含Qt實用技術、樹莓派、三維、OpenCV…

PostgreSQL 安裝與使用

下載地址: EDB: Open-Source, Enterprise Postgres Database Management 安裝圖形化安裝界面安裝。安裝完后將bin目錄配置到系統環境變量 執行psql -h localhost -p 5432 -U postgres 密碼在安裝過程中設置的 ? 0、修改密碼 ALTER USER sonar WITH PASSWORD 123456; 1、新…

【基礎3】快速排序

核心思路 快速排序是Java中Arrays.sort()的實現原理&#xff0c;采用分治策略&#xff0c;通過選擇基準元素&#xff0c;將數組分為兩個子數組&#xff0c;使得左邊元素 ≤ 基準元素 ≤ 右邊元素&#xff0c;然后遞歸排序子數組。 舉個簡單的例子&#xff0c;圖書管理員需要按…

FreeSWITCH 簡單圖形化界面40 - 使用mod_curl模塊進行http請求

FreeSWITCH 簡單圖形化界面40 - 使用mod_curl模塊進行http請求 0、界面預覽00、簡介1、編譯安裝1.1 編輯模塊配置文件 2、使用2.1 撥號規則GET 請求POST 請求JSON 數據 2.2 Lua 腳本GET 請求POST 請求JSON 數據 3 、示例3.1 示例 1&#xff1a;提交 CDR 到第三方接口3.2 示例 2…