校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > HTML5自定義data-* data(obj)屬性和jquery的data()方法的使用

HTML5自定義data-* data(obj)屬性和jquery的data()方法的使用

熱門標(biāo)簽:平頂山電子地圖標(biāo)注怎么修改 電銷機(jī)器人視頻 會(huì)聲會(huì)影怎樣做地圖標(biāo)注效果 江蘇高頻外呼系統(tǒng)線路 搜狗星級(jí)酒店地圖標(biāo)注 高德地圖標(biāo)注錯(cuò)誤怎么修改 地圖標(biāo)注自己去過(guò)的地方 洛陽(yáng)市伊川縣地圖標(biāo)注中心官網(wǎng) 標(biāo)準(zhǔn)智能外呼系統(tǒng)

可能大家在使用jquery mobile時(shí),經(jīng)常會(huì)看到data-role、data-theme等的使用,比如:通過(guò)如下代碼即可實(shí)現(xiàn)頁(yè)眉的效果:

復(fù)制代碼
代碼如下:

<div data-role="header">
<h1>我是標(biāo)題</h1>
</div>

通過(guò)手機(jī)瀏覽,效果如下:

為什么寫一個(gè)data-role="header"就能實(shí)現(xiàn)底部為黑色、文字居中顯示的效果呢?


本文提供一種最簡(jiǎn)單的實(shí)現(xiàn)辦法,讓大家對(duì)這些用法有個(gè)直觀的了解。


我們寫一個(gè)html頁(yè)面,自定義一個(gè)data-chb="header"的屬性,希望具備這個(gè)屬性的div區(qū)域背景顏色為黑色,文字為白色,居中顯示;不具備data-chb自定義屬性的div按照默認(rèn)方式顯示,html代碼如下:

復(fù)制代碼
代碼如下:

<body>
<div data-chb="header">
<h1>我是使用了data-chb自定義屬性的div</h1>
</div>
<br/>
<div>
我沒(méi)有使用data-chb自定義屬性,該怎么展現(xiàn)就怎么展現(xiàn);
</div>
</body>

要想實(shí)現(xiàn)"背景顏色為黑色,文字為白色,居中顯示"的顯示效果,我們定義如下的css:

復(fù)制代碼
代碼如下:

<style>
.ui_header {
background-color: black;
text-align: center;
color:white;
border:1px solid #000;
}
</style>

然后我們通過(guò)如下js方法實(shí)現(xiàn)在頁(yè)面加載時(shí),動(dòng)態(tài)添加css定義,改變具備data-chb屬性的div的顯示樣式:

復(fù)制代碼
代碼如下:

<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;
//也可以通過(guò)如下方式獲得自定義屬性
//var customAttr = elem.dataset["chb"];
//如果是我們預(yù)先定義好的header值,表示需要處理
if(customAttr=="header"){
//添加樣式
elem.setAttribute("class","ui_header");
}
}
}
}
</script>

最后頁(yè)面顯示效果如下:



人們總喜歡往HTML標(biāo)簽上添加自定義屬性來(lái)存儲(chǔ)和操作數(shù)據(jù)。但這樣做的問(wèn)題是,你不知道將來(lái)會(huì)不會(huì)有其它腳本把你的自定義屬性給重置掉,此外,你這樣做也會(huì)導(dǎo)致html語(yǔ)法上不符合Html規(guī)范,以及一些其它副作用。這就是為什么在HTML5規(guī)范里增加了一個(gè)自定義data屬性,你可以拿它做很多有用的事情。

你可以去讀一下HTML5的詳細(xì)規(guī)范,但這個(gè)自定義data屬性的用法非常的簡(jiǎn)單,就是你可以往HTML標(biāo)簽上添加任意以 "data-"開(kāi)頭的屬性,這些屬性頁(yè)面上是不顯示的,它不會(huì)影響到你的頁(yè)面布局和風(fēng)格,但它卻是可讀可寫的。
下面的一個(gè)代碼片段是一個(gè)有效的HTML5標(biāo)記

復(fù)制代碼
代碼如下:

<div id="awesome"
data-myid="3e4ae6c4e">Some awesome data</div>

可是,怎么來(lái)讀取這些數(shù)據(jù)呢?你當(dāng)然可以遍歷頁(yè)面元素來(lái)讀取你想要的屬性,但jquery已經(jīng)內(nèi)置了方法來(lái)操作這些屬性。使用jQuery的.data()方法來(lái)訪問(wèn)這些"data-*" 屬性。其中一個(gè)方法就是 .data(obj),這個(gè)方法是在 jQuery1.4.3版本后出現(xiàn)的,它能返回相應(yīng)的data屬性。
舉個(gè)例子,你可以用下面的寫法讀取 data-myid屬性值:

復(fù)制代碼
代碼如下:

var myid= jQuery("#awesome").data('myid');

console.log(myid);你還可以在"data-*" 屬性里使用json語(yǔ)法,例如,如果你寫出下面的html:

復(fù)制代碼
代碼如下:

<div id="awesome-json" data-awesome='{"game":"on"}'></div>

你可以通過(guò)js直接訪問(wèn)這個(gè)數(shù)據(jù),通過(guò)json的key值,你能得到相應(yīng)的value:

復(fù)制代碼
代碼如下:

var gameStatus= jQuery("#awesome-json").data('awesome').game;

console.log(gameStatus);你也可以通過(guò).data(key,value)方法直接給"data-*" 屬性賦值。一個(gè)重要的你要注意的事情是,這些"data-*" 屬性應(yīng)該和它所在的元素有一定的關(guān)聯(lián),不要把它當(dāng)成存放任意東西的存儲(chǔ)工具。
譯者補(bǔ)充:盡管"data-*" 是HTML5才出現(xiàn)的屬性,但jquery是通用的,所以,在非HTML5的頁(yè)面或?yàn)g覽器里,你仍然可以使用.data(obj)方法來(lái)操作"data-*" 數(shù)據(jù)。

標(biāo)簽:松原 蚌埠 果洛 廣東 常德 阿克蘇 鄂爾多斯 廣西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML5自定義data-* data(obj)屬性和jquery的data()方法的使用》,本文關(guān)鍵詞  HTML5,自定義,data-,data,obj,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《HTML5自定義data-* data(obj)屬性和jquery的data()方法的使用》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于HTML5自定義data-* data(obj)屬性和jquery的data()方法的使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 尼木县| 石屏县| 邹平县| 砀山县| 南充市| 社旗县| 五大连池市| 垫江县| 宽甸| 宕昌县| 武平县| 确山县| 蓝山县| 社会| 博罗县| 涿州市| 吉林市| 汾阳市| 竹山县| 中西区| 宁明县| 望奎县| 汕头市| 正宁县| 岳普湖县| 绥中县| 黔江区| 同德县| 如东县| 西贡区| 大埔区| 拜泉县| 吐鲁番市| 榆林市| 兴山县| 华坪县| 明星| 商丘市| 宜都市| 云南省| 阿拉善右旗|