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-* 自定義屬性
- HTML5 data-*HTML
- CSS 自定義屬性指北CSS
- 初識css自定義屬性CSS
- ReactNative自定義元件及屬性React元件
- CSS 自定義屬性(變數)CSS變數
- 給Product新增自定義屬性
- 4. 自定義控制元件(4) --- 自定義屬性控制元件
- Android 自定義View:深入理解自定義屬性(七)AndroidView
- 【譯】CSS 自定義屬性的策略指南CSS
- React Native 自定義元件及屬性React Native元件
- ubuntu下OpenLDAP新增自定義屬性UbuntuLDA
- 自定義元件-資料、方法、屬性元件
- spring 自定義屬性解析器Spring
- 使用 CSS 自定義屬性(變數)CSS變數
- Android 自定義View:屬性動畫(六)AndroidView動畫
- Spring Cloud自定義引導屬性源SpringCloud
- Spring Boot讀取自定義外部屬性Spring Boot
- CSS變數(自定義屬性)實踐指南CSS變數
- 使用CSS自定義屬性構建骨架屏CSS
- 自定義View:Paint的常用屬性介紹及使用ViewAI
- 帶你深入理解Android中的自定義屬性!!!Android
- HTML5 novalidate 屬性HTML
- 【朝花夕拾】Android自定義View篇之(四)自定義View的三種實現方式及自定義屬性詳解AndroidView
- Python日誌記錄中新增自定義屬性Python
- SpringBoot入門(二):日誌及自定義屬性Spring Boot
- CSS Var 自定義屬性中使用 Scss 變數CSS變數
- [譯] 為函式自定義屬性的八種實現方法函式
- [BUG反饋]模型屬性自定義函式提交不了模型函式
- 安卓Property Animator動畫詳解(二)-自定義屬性安卓動畫
- Qt編寫自定義控制元件屬性設計器QT控制元件
- CSS自定義屬性與前端頁面的主題切換CSS前端
- HTML5 Audio & Video 屬性解析HTMLIDE
- CSS自定義屬性 —— 別說你懂CSS相對單位CSS
- HenCoder Android 自定義 View 1-6: 屬性動畫(上手篇)AndroidView動畫
- 你瞭解HTML5的download屬性嗎?HTML
- html5/css3新增屬性HTMLCSSS3
- vue自定義全域性元件(或自定義外掛)Vue元件
- 自定義JsonConverter,反序列化不符合規範的陣列屬性JSON陣列