首頁 web前端 H5教程 詳解H5的自訂屬性data-*

詳解H5的自訂屬性data-*

May 24, 2017 am 11:41 AM
data html5 自訂屬性

HTML5 增加了一項新功能是 自訂資料屬性 ,也就是  data-* 自訂屬性。在HTML5中我們可以使用以 data- 為前綴來設定我們需要的自訂屬性,來進行一些資料的存放

當然高階瀏覽器下可透過腳本進行定義和資料存取。在專案實務中非常有用。

例如:

程式碼如下:


使用attribute方法存取data-* 自訂屬性的值

#  使用attributes方法存取 data-* 自訂屬性的值非常方便:

程式碼如下:

 // 使用getAttribute获取 data- 属性

  var user = 
document
 . getElementById ( 'user' ) ;

  var userName = plant . getAttribute ( 'data-uname' ) ; // userName = '脚本之家'

  var userId = plant . getAttribute ( 'data-uid' ) ; // userId = '12345'

  // 使用
set
Attribute设置 data- 属性

  user . setAttribute ( 'data-site' , 'http://www.jb51.net' ) ;
登入後複製


此方法能在所有的現代瀏覽器中正常運作,但它不是HTML 5 的自訂data-*屬性被使用目的,不然和我們以前使用的自訂屬性就沒有什麼區別了,例如:

程式碼如下:

 <p id = "user" uid = "12345" uname = "脚本之家" > </p>

  <script>

  // 使用getAttribute获取 data- 属性

  var user = document . getElementById ( &#39;user&#39; ) ;

  var userName = plant . getAttribute ( &#39;uname&#39; ) ; // userName = &#39;脚本之家&#39;

  var userId = plant . getAttribute ( &#39;uid&#39; ) ; // userId = &#39;12345&#39;

  // 使用setAttribute设置 data- 属性

  user . setAttribute ( &#39;site&#39; , &#39;http://www.jb51.net&#39; ) ;

  </script>
登入後複製


#  這種「原始」的自訂屬性和上面 data-* 自訂屬性沒什麼差別,知識屬性名稱不一樣。

dataset屬性訪問data-*自訂屬性的值

這種方式透過存取一個元素的dataset 屬性來存取data-* 自訂屬性的值。這個dataset 屬性是HTML5 JavaScript API的一部分,用來傳回一個所有選擇元素data- 屬性的DOMStringMap #物件

使用這種方法時,不是使用完整的屬性名,如 data-uid 來存取數據,應該去掉data- 前綴。

還有一點特別注意的是: data- 屬性名如果包含了連字符,例如:data-date-of-birth ,連字符將被去掉,並轉換為駝峰式的命名,前面的屬性名稱轉換後應該是: dateOfBirth 。

程式碼如下:

 <p id="user" data-id="1234567890" data-name="脚本之家" data-date-of-birth>码头</p>
  <script type="text/javascript">
  var el = document.querySelector(&#39;#user&#39;);
  console.log(el.id); // &#39;user&#39;
  console.log(el.dataset);//一个DOMStringMap
  console.log(el.dataset.id); // &#39;1234567890&#39;
  console.log(el.dataset.name); // &#39;脚本之家&#39;
  console.log(el.dataset.dateOfBirth); // &#39;&#39;
  el.dataset.dateOfBirth = &#39;1985-01-05&#39;; // 设置data-date-of-birth的值.
  console.log(&#39;someDataAttr&#39; in el.dataset);//false
  el.dataset.someDataAttr = &#39;mydata&#39;;
  console.log(&#39;someDataAttr&#39; in el.dataset);//true
  </script>
登入後複製

 如果你想刪除一個 data-屬性 ,可以這麼做: delete el . dataset . id ;  或 el .dataset . id = null ;  。

看起來很美,哈哈,但不幸的是,新的dataset 屬性只有在Chrome 8+ Firefox(Gecko) 6.0+ Internet Explorer 11+ Opera 11.10+ Safari 6+瀏覽器中實現,所以在此期間最好用的getAttribute和setAttribute來操作。

關於data-屬性選擇器

在實際開發時,您可能會發現它很有用,你可以根據自訂的data - 屬性選擇相關的元素。例如使用querySelectorAll選擇元素:

程式碼如下:


 // 選取所有包含 'data-flowering' 屬性的元素
 document . querySelectorAll ( '[data-flowering]' ) ;

#  // 選擇所有包含 'data-text-colour' 屬性值為red的元素
 document . querySelectorAll ( '[data-text-colour="red"]' ) ;


同樣的我們也可以透過data- 屬性值對對應的元素設定CSS樣式,例如下面這個例子:

#程式碼如下:

 <style type ="text/css">

  .user {

  
width
 : 256px ;

  
height
 : 200px ;

  }

  .user[data-name=&#39;feiwen&#39;] {

  color : brown

  }

  .user[data-name=&#39;css&#39;] {

  color : red

  }

  </style>

  <p 
class
 = "user" data-id = "123" data-name = "feiwen" > 1 </p>

  <p class = "user" data-id = "124" data-name = "css" > 码头 </p>
登入後複製

【相關推薦】

1. Html5免費影片教學

2. 關於H5的事件屬性詳解

3. 」詳解H5非常重要的28個新功能,新技巧與新技術

4. H5製作計時器的程式碼示範

5. #H5完成多圖片上傳的實例詳解

#

以上是詳解H5的自訂屬性data-*的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1318
25
PHP教程
1269
29
C# 教程
1248
24
HTML 中的表格邊框 HTML 中的表格邊框 Sep 04, 2024 pm 04:49 PM

HTML 表格邊框指南。在這裡,我們以 HTML 中的表格邊框為例,討論定義表格邊框的多種方法。

HTML 中的巢狀表 HTML 中的巢狀表 Sep 04, 2024 pm 04:49 PM

這是 HTML 中巢狀表的指南。這裡我們討論如何在表中建立表格以及對應的範例。

HTML 左邊距 HTML 左邊距 Sep 04, 2024 pm 04:48 PM

HTML 左邊距指南。在這裡,我們討論 HTML margin-left 的簡要概述及其範例及其程式碼實作。

HTML 表格佈局 HTML 表格佈局 Sep 04, 2024 pm 04:54 PM

HTML 表格佈局指南。在這裡,我們詳細討論 HTML 表格佈局的值以及範例和輸出。

HTML 輸入佔位符 HTML 輸入佔位符 Sep 04, 2024 pm 04:54 PM

HTML 輸入佔位符指南。在這裡,我們討論 HTML 輸入佔位符的範例以及程式碼和輸出。

HTML 有序列表 HTML 有序列表 Sep 04, 2024 pm 04:43 PM

HTML 有序列表指南。在這裡我們也分別討論了 HTML 有序列表和類型的介紹以及它們的範例

HTML onclick 按鈕 HTML onclick 按鈕 Sep 04, 2024 pm 04:49 PM

HTML onclick 按鈕指南。這裡我們分別討論它們的介紹、工作原理、範例以及各個事件中的onclick事件。

在 HTML 中移動文字 在 HTML 中移動文字 Sep 04, 2024 pm 04:45 PM

HTML 中的文字移動指南。在這裡我們討論一下marquee標籤如何使用語法和實作範例。

See all articles