HTML5中的自定義屬性

自定義屬性(Custom Attributes) 允許在標準 HTML 屬性之外,為元素添加額外的元數據(metadata)。

1. 標準方式:data-* 屬性

HTML5 引入了 data-* 前綴的自定義屬性規范,所有以 data- 開頭的屬性都會被瀏覽器視為自定義數據。

基本語法:
<div id="user" data-id="123" data-name="張三" data-is-admin="true">用戶信息
</div>
  • 可訪問性:可通過 JavaScript 的 dataset 屬性訪問。

2. JavaScript 訪問 data-* 屬性

可以通過 element.dataset 對象訪問 data-* 屬性的值:

示例:
const userElement = document.getElementById('user');// 獲取 data-id 屬性值(自動轉換為駝峰命名)
const userId = userElement.dataset.id; // "123"// 獲取 data-is-admin 屬性值
const isAdmin = userElement.dataset.isAdmin; // "true"(字符串類型)// 修改屬性值
userElement.dataset.age = '28'; // 會創建 data-age="28"// 刪除屬性
delete userElement.dataset.name; // 移除 data-name
注意事項:
  • 命名轉換data-* 中的連字符(如 data-first-name)會自動轉換為駝峰命名(dataset.firstName)。
  • 數據類型:所有值都以字符串形式存儲,如需其他類型需手動轉換(如 parseInt)。

3. 實際應用場景

(1)組件化數據傳遞

在自定義組件中存儲配置信息:

<video-player data-src="video.mp4" data-autoplay="false"></video-player>
(2)DOM 與數據綁定

在列表渲染中關聯數據 ID:

<ul><li data-item-id="1">項目 1</li><li data-item-id="2">項目 2</li>
</ul>
(3)事件驅動邏輯

在按鈕中存儲操作類型:

<button data-action="delete">刪除</button>
<button data-action="edit">編輯</button>
document.querySelectorAll('[data-action]').forEach(button => {button.addEventListener('click', () => {const action = button.dataset.action;// 根據 action 執行不同邏輯});
});

4. 非標準自定義屬性

除了 data-*,HTML 還允許使用非標準的自定義屬性,但存在一些限制:

<div my-custom-attr="value">非標準屬性</div>
訪問方式:
const div = document.querySelector('div');// 使用 getAttribute/setAttribute
const value = div.getAttribute('my-custom-attr'); // "value"
div.setAttribute('my-custom-attr', 'new-value');// 直接訪問(不推薦,可能不被所有瀏覽器支持)
div.myCustomAttr; // undefined(非標準方式)
注意事項:
  • 驗證問題:HTML 驗證工具可能報錯。
  • 樣式兼容性:無法通過 CSS 選擇器直接匹配(如 [my-custom-attr])。
  • 最佳實踐:盡量使用 data-* 屬性而非非標準屬性。

5. 自定義屬性 vs. 其他存儲方式

存儲方式優點缺點適用場景
data-* 屬性標準化、語義化、DOM 中可見只能存儲字符串類型簡單數據傳遞
element.id快速訪問只能存儲字符串且需全局唯一元素標識
element.classList可用于樣式切換只能存儲字符串數組狀態標記
element.setAttribute靈活存儲任意屬性非標準化,可能影響驗證臨時數據存儲
JavaScript 變量無類型限制,可存儲復雜對象與 DOM 無直接關聯復雜邏輯處理

注意

  1. 優先使用 data-*:避免使用非標準自定義屬性。
  2. 保持屬性名簡潔:如 data-user-id 而非 data-the-id-of-the-current-user
  3. 避免敏感數據:不要在自定義屬性中存儲密碼、token 等敏感信息。
  4. 結合組件化:在自定義組件中使用 data-* 傳遞配置參數。
  5. 數據類型轉換:使用時注意將字符串轉換為合適的類型(如 Number()JSON.parse())。

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

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

相關文章

前端項目利用Gitlab CI/CD流水線自動化打包、部署云服務

疊甲前言 本文僅作為個人學習GitLab的CI/CD功能記錄&#xff0c;不適合作為專業性指導&#xff0c;如有紕漏&#xff0c;煩請君指正。 Gitlab的CI/CD做什么用的 自工作以來&#xff0c;去過大大小小公司&#xff0c;有一些公司技術人員專業性欠佳&#xff0c;每當產品經理或…

基于typescript嚴格模式以實現undo和redo功能為目標的命令模式代碼參考

下面是一個完整的、嚴格模式下的 TypeScript 實現&#xff0c;包含 CommandManager、Command 和 CompositeCommand 類&#xff0c;支持 undo/redo 功能。完整實現代碼1. Command 接口和基類// src/commands/ICommand.ts export interface ICommand {execute(): void;undo(): vo…

2022年CIE SCI2區TOP,NSGA-II+直升機-無人機搜救任務分配,深度解析+性能實測

目錄1.摘要2.數學模型3.求解方法4.結果展示5.參考文獻6.代碼獲取7.算法輔導應用定制讀者交流1.摘要 無人機任務分配對于保障搜救活動高效有序開展具有重要意義&#xff0c;但現有研究較少考慮無人機作業環境與性能對任務分配的影響。針對低空風場和地形因素對無人機能耗與性能…

暑期算法訓練.4

目錄 15.力扣 904.水果成籃 15.1 題目解析&#xff1a; 15.2 算法思路&#xff1a; 15.2.1 暴力解法&#xff1a; 15.2.1 滑動窗口 15.3代碼演示&#xff1a; 15.4 總結反思&#xff1a; 16 力扣 438.找出字符串中所有字母的異位詞 16.1 題目解析&#xff1a; 16.2算法…

關于個人博客系統的測試報告

1&#xff09;項目背景2&#xff09;項目功能介紹 登陸寫博客/編輯已存在博客刪除博客注銷 2&#xff09;基于項目功能設計相關測試用例3&#xff09;基于測試用例編寫自動化測試 準備工作登陸界面相關博客首頁相關博客詳情頁相關編輯博客相關刪除博客相關注銷相關 4&#xff0…

Spring Boot 與微服務詳細總結

一、Spring Boot 核心概述 Spring Boot 是簡化 Spring 應用開發的框架&#xff0c;作為 Spring 技術棧的整合方案和 J2EE 開發的一站式解決方案&#xff0c;其核心優勢體現在&#xff1a; 快速創建獨立運行的 Spring 項目&#xff0c;輕松集成主流框架內置 Servlet 容器&…

輕松上手:從零開始啟動第一個 Solana 測試節點

嗨&#xff0c;各位技術愛好者們&#xff01; 大家是否對 Solana 的“光速”交易處理能力感到好奇&#xff1f;或者你是一名開發者&#xff0c;正準備在 Solana 上構建下一個殺手級 dApp&#xff1f;無論大家是出于學習目的還是實際開發需求&#xff0c;親手運行一個 Solana 節…

Gerrit workflow

提交代碼 每次提交代碼前&#xff0c;先執行 git pull --rebase &#xff0c;確保已經合并天上代碼&#xff0c;解決沖突 git add git commit -m git push origin HEAD:refs/for/{BRANCH_NAME} 可考慮設置 alias 方式&#xff0c;參考下文 CR-2 情況處理(verify-1情況一樣處理…

量化交易如何查詢CFD指數實時行情

CFD即所謂的差價合約&#xff0c;是投資者在不擁有實際資產的情況下&#xff0c;交易金融市場的一種方式。最近筆者研究這一塊比較多&#xff0c;但查遍整個中文互聯網卻很少找到關于CFD實時行情的查詢教程。因此有了這篇文章。以下我將通過一個簡單的Python代碼示例&#xff0…

sql練習二

首先&#xff0c;建表。創建學生表和score表接著導入創建好基礎信息就可以開始做了。3、分別查詢student表和score表的所有記錄4、查詢student表的第2條到第5條記錄5、從student表中查詢計算機系和英語系的學生的信息6、從student表中查詢年齡小于22歲的學生信息7、從student表…

windows11下基于docker單機部署ceph集群

windows下基于docker單機部署ceph集群 創建ceph專用網絡 docker network create --driver bridge --subnet 172.20.0.0/16 ceph-network查看是否創建成功&#xff08;查看創建狀態&#xff09; docker network inspect ceph-network拉取鏡像&#xff1a;(鏡像源自行選擇) docke…

使用DataGrip連接安裝在Linux上的Redis

目錄 一、前言 二、開放防火墻端口 三、使用DataGrip連接安裝在Linux上的Redis 一、前言 在學習黑馬Redis從入門到實戰的視頻&#xff0c;完成了Redis在linux上的安裝配置之后&#xff0c;我們可以使用圖形化界面方便操作使用redis數據庫。在24年JavaWebAI學習時連接MySQL數…

MySQL的union、union all導致排序失效

今天練習SQL&#xff0c;使用union all 連接各個查詢導致我的各個查詢排序失效&#xff0c;最后發現使用union all后會忽略各個模塊的order by&#xff0c;只有最外層的order by才會生效原SQL如下&#xff1a;( selectexam_id tid,count(distinct uid) uv, count(uid) pv frome…

LVS 集群技術實踐:NAT 與 DR 模式的配置與對比

1 實驗環境規劃 實驗目標是搭建一個負載均衡集群&#xff0c;通過 LVS 調度器將流量分發到兩臺真實服務器&#xff08;RS1 和 RS2&#xff09;。2.網絡配置3 實驗步驟關閉防火墻和 SELinux安裝 HTTP 服務&#xff08;在 RS21和 RS2 上&#xff09;&#xff1a;sudo systemctl s…

YOLOv8中添加SENet注意力機制

注意力機制(Attention Mechanism)是深度學習中的一種方法,在圖像處理領域,尤其是在卷積神經網絡(CNN)和視覺Transformer等架構中。圖像數據具有局部相關性,注意力機制可以幫助模型聚焦于圖像中更重要的區域,從而提升處理效果。 SENet(Squeeze-and-Excitation Network)…

SpringBoot五分鐘快速入門指南

使用 Spring Boot 構建應用 本指南提供了關于Spring Boot如何幫助您加速應用開發的一些示例。隨著您閱讀更多 Spring 入門指南,您將看到 Spring Boot 的更多用例。本指南旨在讓您快速了解 Spring Boot。如果您想創建自己的基于 Spring Boot 的項目,請訪問 Spring Initializr…

docker,防火墻關閉后,未重啟docker,導致端口映射失敗

首先&#xff0c;看這篇文章前&#xff0c;建議先把網上其他的文章說的方法嘗試一遍&#xff01;&#xff01;&#xff01; 1. 現象 docker啟動某一個容器&#xff0c;然后映射端口時顯示失敗2. 解決 把網上的方法嘗試一遍之后&#xff0c;最后發現是防火墻的問題&#xff01;&…

事務處理與AOP(web后端筆記第四期)

p.s.這是萌新自己自學總結的筆記&#xff0c;如果想學習得更透徹的話還是請去看大佬的講解 目錄事務spring事物管理事物屬性--回滾事物屬性--傳播行為(propagation)AOP一些核心概念通知類型通知的執行順序切入點表達式executionannotation連接點事務 事物是一組操作的集合&…

第36周———— RNN實現阿爾茨海默病診斷

目錄 前言 1.檢查GPU 2.查看數據 3.劃分數據集 4.創建模型與編譯訓練 ????5.編譯及訓練模型 6.結果可視化 7.模型預測 8.總結&#xff1a; 前言 &#x1f368; 本文為&#x1f517;365天深度學習訓練營中的學習記錄博客 &#x1f356; 原作者&#xff1a;K同學啊 1.檢查G…

equals和hashcode方法重寫

在 Java 中&#xff0c;當你需要基于對象的內容而非引用地址來判斷兩個對象是否相等時&#xff0c;就需要重寫equals和hashCode方法。以下是具體場景和實現原則&#xff1a;一、為什么需要同時重寫這兩個方法&#xff1f;equals方法&#xff1a;默認比較對象的內存地址&#xf…