HTML5的data-*自定義屬性

業餘草發表於2015-06-29
HTML5增加了一項新功能是自定義資料屬性,也就是data-*自定義屬性。在HTML5中我們可以使用以data-為字首來設定我們需要的自定義屬性,來進行一些資料的存放。當然高階瀏覽器下可通過指令碼進行定義和資料存取。在專案實踐中非常有用。目前採取這樣的做法的框架也有很多,最常見的當屬jQueryMobile。
具體使用方法例下:
<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共同學習! 

相關文章