1. 程式人生 > >HTML5的data-*自己定義屬性

HTML5的data-*自己定義屬性

ons 關註 oms css樣式 元素 strong false tel java

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共同學習!


HTML5的data-*自己定義屬性