HTML5的data-*自定義屬性
HTML5增加了一項新功能是自定義資料屬性,也就是data-*自定義屬性。在HTML5中我們可以使用以data-為字首來設定我們需要的自定義屬性,來進行一些資料的存放。當然高階瀏覽器下可通過指令碼進行定義和資料存取。在專案實踐中非常有用。目前採取這樣的做法的框架也有很多,最常見的當屬jQueryMobile。
具體使用方法例下:
在IE瀏覽器裡,我們通過獲取物件後直接呼叫就可以了
這種方式通過訪問一個元素的 dataset 屬性來存取 data-* 自定義屬性的值。這個 dataset 屬性是HTML5 JavaScript API的一部分,用來返回一個所有選擇元素 data- 屬性的DOMStringMap物件。
使用這種方法時,不是使用完整的屬性名,如data-home來存取資料,應該去掉data-字首。
還有一點特別注意的是:data-屬性名如果包含了連字元,例如:data-date-of-birth ,連字元將被去掉,並轉換為駝峰式的命名,前面的屬性名轉換後應該是:dateOfBirth。
這樣操作起來是不是非常的方便。但有些瀏覽器可能還不支援。所以在此期間最好用的getAttribute和setAttribute來操作或配合jquery進行使用。
data-屬性選擇器
在實際開發時,可以根據自定義的data-屬性選擇相關的元素。例如使用querySelectorAll選擇元素:
//選擇所有包含'data-div'屬性的元素
document.querySelectorAll ('[data-div]') ;
//選擇所有包含'data-a-href' 屬性值為red的元素
document.querySelectorAll ('[data-a-href="#"]') ;
同樣的我們也可以通過data-屬性值對相應的元素設定CSS樣式,例如下面這個例子:
具體使用方法例下:
<div id = "head" data-home = "http://blog.csdn.net/xmtblog" data-author = "偽專家"></div>
在傳統的做法中我們可以配合jquery使用,如下:$("#head").attr("data-home");
$("#head").attr("data-home","new");
或者純js做法:在IE瀏覽器裡,我們通過獲取物件後直接呼叫就可以了
document.getElementById("head").["data-home"];
document.getElementById("head").["data-home"] = "new";
在火狐和谷歌瀏覽器裡,我們可以通過getAttribute方法來實現呼叫:document.getElementById("head").getAttribute("data-home");
document.getElementById("head").setAttribute("data-home","new");
再HTML5中的簡潔操作方法:(dataset屬性存取data-*自定義屬性的值)這種方式通過訪問一個元素的 dataset 屬性來存取 data-* 自定義屬性的值。這個 dataset 屬性是HTML5 JavaScript API的一部分,用來返回一個所有選擇元素 data- 屬性的DOMStringMap物件。
使用這種方法時,不是使用完整的屬性名,如data-home來存取資料,應該去掉data-字首。
還有一點特別注意的是:data-屬性名如果包含了連字元,例如:data-date-of-birth ,連字元將被去掉,並轉換為駝峰式的命名,前面的屬性名轉換後應該是:dateOfBirth。
<div id = "head" data-home = "http://blog.csdn.net/xmtblog" data-author = "偽專家" data-date-of-birth>QQ群:135430763</div>
<script type="text/javascript">
var el = document.querySelector('#head');
console.log(el.id);
console.log(el.dataset);//一個DOMStringMap
console.log(el.dataset.home);
console.log(el.dataset.author);
console.log(el.dataset.dateOfBirth);
el.dataset.dateOfBirth = '1985-01-05'; // 設定data-date-of-birth的值.
//判斷屬性
console.log('testAttr' in el.dataset);//false
el.dataset.testAttr = 'testAttr';
console.log('testAttr' in el.dataset);//true
</script>
如果你想刪掉一個 data-屬性 ,可以這麼做: delete el.dataset.home ; 或者 el.dataset.home = null;。這樣操作起來是不是非常的方便。但有些瀏覽器可能還不支援。所以在此期間最好用的getAttribute和setAttribute來操作或配合jquery進行使用。
data-屬性選擇器
在實際開發時,可以根據自定義的data-屬性選擇相關的元素。例如使用querySelectorAll選擇元素:
//選擇所有包含'data-div'屬性的元素
document.querySelectorAll ('[data-div]') ;
//選擇所有包含'data-a-href' 屬性值為red的元素
document.querySelectorAll ('[data-a-href="#"]') ;
同樣的我們也可以通過data-屬性值對相應的元素設定CSS樣式,例如下面這個例子:
<style type ="text/css">
.head {
width : 256px ;
height : 200px ;
}
.head[data-a='btn-a'] {
color : brown
}
.head[data-a='btn-color'] {
color : red
}
</style>
<div class = "head" data-qq = "QQ群:135430763" data-a = "btn-a" > button按鈕 </div>
<div class = "head" data-qq = "QQ群:135430763" data-a = "btn-color" > button按鈕</div>
歡迎大家關注我的部落格!如有疑問,請加QQ群:135430763共同學習! 相關文章
- data-* 自定義屬性
- jQuery data()方法和HTML5 data-*自定義屬性jQueryHTML
- jQuery的data()函式操作html5的自定義data-*屬性jQuery函式HTML
- 自動獲取HTML5的data-*屬性HTML
- html5標籤的data-*屬性用法簡單介紹HTML
- 自定義View:自定義屬性(自定義按鈕實現)View
- CSS 自定義屬性指北CSS
- Android自定義屬性Android
- Android自定義控制元件——自定義屬性Android控制元件
- 初識css自定義屬性CSS
- CSS 自定義屬性(變數)CSS變數
- 屬性動畫:如何自定義View動畫View
- easyui tree自定義屬性用法UI
- CSS自定義屬性Expression(轉)CSSExpress
- 4. 自定義控制元件(4) --- 自定義屬性控制元件
- Android自定義控制元件之自定義屬性Android控制元件
- 【譯】CSS 自定義屬性的策略指南CSS
- Android 自定義View:深入理解自定義屬性(七)AndroidView
- HTML5 data-*HTML
- ubuntu下OpenLDAP新增自定義屬性UbuntuLDA
- 使用 CSS 自定義屬性(變數)CSS變數
- Android自定義View 屬性新增AndroidView
- 給自定義View新增xml屬性ViewXML
- .net自定義控制元件下拉的屬性控制元件
- Android自定義組合控制元件之自定義屬性Android控制元件
- android中自定義屬性重複定義Android
- Android 自定義View:屬性動畫(六)AndroidView動畫
- css自定義屬性和聚光燈效果CSS
- spring 自定義屬性解析器Spring
- android 自定義控制元件 自定義屬性詳細介紹Android控制元件
- 使用CSS自定義屬性構建骨架屏CSS
- CSS變數(自定義屬性)實踐指南CSS變數
- Spring Boot讀取自定義外部屬性Spring Boot
- Spring Cloud自定義引導屬性源SpringCloud
- JSP自定義標籤系列---rtexprvalue屬性JS
- 自定義html標籤和表單屬性HTML
- 自定義View:Paint的常用屬性介紹及使用ViewAI
- H5自定義屬性的一些方式H5