HTML5自定義data-* data(obj)屬性和jquery的data()方法的使用_HTML5教程
推薦:免費(fèi)獲得微軟MCSD證書趕快行動吧!各位園友們,趕快行動起來吧,免費(fèi)獲得微軟HTML5,JavaScript和CSS3的MCSD證書(價值一千多大洋)感興趣就一起來吧
可能大家在使用jquery mobile時,經(jīng)常會看到data-role、data-theme等的使用,比如:通過如下代碼即可實(shí)現(xiàn)頁眉的效果:
<div data-role="header">
<h1>我是標(biāo)題</h1>
</div>
通過手機(jī)瀏覽,效果如下:
為什么寫一個data-role="header"就能實(shí)現(xiàn)底部為黑色、文字居中顯示的效果呢?
本文提供一種最簡單的實(shí)現(xiàn)辦法,讓大家對這些用法有個直觀的了解。
我們寫一個html頁面,自定義一個data-chb="header"的屬性,希望具備這個屬性的div區(qū)域背景顏色為黑色,文字為白色,居中顯示;不具備data-chb自定義屬性的div按照默認(rèn)方式顯示,html代碼如下:
<body>
<div data-chb="header">
<h1>我是使用了data-chb自定義屬性的div</h1>
</div>
<br/>
<div>
我沒有使用data-chb自定義屬性,該怎么展現(xiàn)就怎么展現(xiàn);
</div>
</body>
要想實(shí)現(xiàn)"背景顏色為黑色,文字為白色,居中顯示"的顯示效果,我們定義如下的css:
<style>
.ui_header {
background-color: black;
text-align: center;
color:white;
border:1px solid #000;
}
</style>
然后我們通過如下js方法實(shí)現(xiàn)在頁面加載時,動態(tài)添加css定義,改變具備data-chb屬性的div的顯示樣式:
<script type="text/javascript">
window.onload=function(){
var elems = document.getElementsByTagName("div");
if(elems!=null&&elems.length>0){
var length = elems.length;
//遍歷所有DIV控件
for(var i=0;i<length;i++){
var elem = elems[i];
//獲取該控件的自定義屬性
var customAttr = elem.dataset.chb;
//也可以通過如下方式獲得自定義屬性
//var customAttr = elem.dataset["chb"];
//如果是我們預(yù)先定義好的header值,表示需要處理
if(customAttr=="header"){
//添加樣式
elem.setAttribute("class","ui_header");
}
}
}
}
</script>
最后頁面顯示效果如下:
人們總喜歡往HTML標(biāo)簽上添加自定義屬性來存儲和操作數(shù)據(jù)。但這樣做的問題是,你不知道將來會不會有其它腳本把你的自定義屬性給重置掉,此外,你這樣做也會導(dǎo)致html語法上不符合Html規(guī)范,以及一些其它副作用。這就是為什么在HTML5規(guī)范里增加了一個自定義data屬性,你可以拿它做很多有用的事情。
你可以去讀一下HTML5的詳細(xì)規(guī)范,但這個自定義data屬性的用法非常的簡單,就是你可以往HTML標(biāo)簽上添加任意以 "data-"開頭的屬性,這些屬性頁面上是不顯示的,它不會影響到你的頁面布局和風(fēng)格,但它卻是可讀可寫的。
下面的一個代碼片段是一個有效的HTML5標(biāo)記:
<div id="awesome"
data-myid="3e4ae6c4e">Some awesome data</div>
可是,怎么來讀取這些數(shù)據(jù)呢?你當(dāng)然可以遍歷頁面元素來讀取你想要的屬性,但jquery已經(jīng)內(nèi)置了方法來操作這些屬性。使用jQuery的.data()方法來訪問這些"data-*" 屬性。其中一個方法就是 .data(obj),這個方法是在 jQuery1.4.3版本后出現(xiàn)的,它能返回相應(yīng)的data屬性。
舉個例子,你可以用下面的寫法讀取 data-myid屬性值:
var myid= jQuery("#awesome").data('myid');
console.log(myid);你還可以在"data-*" 屬性里使用json語法,例如,如果你寫出下面的html:
<div id="awesome-json" data-awesome='{"game":"on"}'></div>
你可以通過js直接訪問這個數(shù)據(jù),通過json的key值,你能得到相應(yīng)的value:
var gameStatus= jQuery("#awesome-json").data('awesome').game;
console.log(gameStatus);你也可以通過.data(key,value)方法直接給"data-*" 屬性賦值。一個重要的你要注意的事情是,這些"data-*" 屬性應(yīng)該和它所在的元素有一定的關(guān)聯(lián),不要把它當(dāng)成存放任意東西的存儲工具。
譯者補(bǔ)充:盡管"data-*" 是HTML5才出現(xiàn)的屬性,但jquery是通用的,所以,在非HTML5的頁面或?yàn)g覽器里,你仍然可以使用.data(obj)方法來操作"data-*" 數(shù)據(jù)。
分享:HTML5 新舊語法標(biāo)記對我們有什么好處眾所周知,HTML是互聯(lián)網(wǎng)有史以來最偉大的發(fā)明,HTML5的目的就是要根據(jù)目前互聯(lián)網(wǎng)的狀況對其進(jìn)行改進(jìn)
- 只要五步 就可以用HTML5/CSS3快速制作便簽貼特效(圖)
- 網(wǎng)易微博Web App用HTML5開發(fā)的過程介紹
- HTML5 對各個標(biāo)簽的定義與規(guī)定:body的介紹
- 關(guān)于HTML5的安全問題開發(fā)人員需要牢記的
- 關(guān)于HTML5的22個初級技巧(圖文教程)
- 開發(fā)人員所需要知道的HTML5性能分析面面觀
- HTML5 Web Database 數(shù)據(jù)庫的SQL語句的使用方法
- HTML5實(shí)踐-圖片設(shè)置成灰度圖
- HTML5安全介紹之內(nèi)容安全策略(CSP)簡介
- HTML5 Web存儲方式的localStorage和sessionStorage進(jìn)行數(shù)據(jù)本地存儲案例應(yīng)用
- Bootstrap 學(xué)習(xí)分享
- input元素的url類型和email類型簡介
HTML5教程Rss訂閱Div+Css教程搜索
HTML5教程推薦
- 程序設(shè)計HTML5 Canvas API
- html5播放視頻且動態(tài)截圖實(shí)現(xiàn)步驟與代碼(支持safari其他未測試)
- html5 瀏覽器支持 如何讓所有的瀏覽器都支持HTML5標(biāo)簽樣式
- HTML5之SVG 2D入門10—濾鏡的定義及使用
- HTML4和HTML5之間除了相似以外的10個主要不同
- HTML5中的Article和Section元素認(rèn)識及使用
- 關(guān)于HTML5的22個初級技巧(圖文教程)
- 關(guān)于HTML5的22個初級技巧(圖文教程)
- html5中為audio標(biāo)簽增加停止按鈕動作實(shí)現(xiàn)方法
- 基于Modernizr 讓網(wǎng)站進(jìn)行優(yōu)雅降級的分析
- 相關(guān)鏈接:
- 教程說明:
HTML5教程-HTML5自定義data-* data(obj)屬性和jquery的data()方法的使用。