婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

熱門標簽:平頂山電子地圖標注怎么修改 電銷機器人視頻 會聲會影怎樣做地圖標注效果 江蘇高頻外呼系統線路 搜狗星級酒店地圖標注 高德地圖標注錯誤怎么修改 地圖標注自己去過的地方 洛陽市伊川縣地圖標注中心官網 標準智能外呼系統

可能大家在使用jquery mobile時,經常會看到data-role、data-theme等的使用,比如:通過如下代碼即可實現頁眉的效果:

復制代碼
代碼如下:

<div data-role="header">
<h1>我是標題</h1>
</div>

通過手機瀏覽,效果如下:

為什么寫一個data-role="header"就能實現底部為黑色、文字居中顯示的效果呢?


本文提供一種最簡單的實現辦法,讓大家對這些用法有個直觀的了解。


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

復制代碼
代碼如下:

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

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

復制代碼
代碼如下:

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

然后我們通過如下js方法實現在頁面加載時,動態添加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"];
//如果是我們預先定義好的header值,表示需要處理
if(customAttr=="header"){
//添加樣式
elem.setAttribute("class","ui_header");
}
}
}
}
</script>

最后頁面顯示效果如下:



人們總喜歡往HTML標簽上添加自定義屬性來存儲和操作數據。但這樣做的問題是,你不知道將來會不會有其它腳本把你的自定義屬性給重置掉,此外,你這樣做也會導致html語法上不符合Html規范,以及一些其它副作用。這就是為什么在HTML5規范里增加了一個自定義data屬性,你可以拿它做很多有用的事情。

你可以去讀一下HTML5的詳細規范,但這個自定義data屬性的用法非常的簡單,就是你可以往HTML標簽上添加任意以 "data-"開頭的屬性,這些屬性頁面上是不顯示的,它不會影響到你的頁面布局和風格,但它卻是可讀可寫的。
下面的一個代碼片段是一個有效的HTML5標記

復制代碼
代碼如下:

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

可是,怎么來讀取這些數據呢?你當然可以遍歷頁面元素來讀取你想要的屬性,但jquery已經內置了方法來操作這些屬性。使用jQuery的.data()方法來訪問這些"data-*" 屬性。其中一個方法就是 .data(obj),這個方法是在 jQuery1.4.3版本后出現的,它能返回相應的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直接訪問這個數據,通過json的key值,你能得到相應的value:

復制代碼
代碼如下:

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

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

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

巨人網絡通訊聲明:本文標題《HTML5自定義data-* data(obj)屬性和jquery的data()方法的使用》,本文關鍵詞  HTML5,自定義,data-,data,obj,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《HTML5自定義data-* data(obj)屬性和jquery的data()方法的使用》相關的同類信息!
  • 本頁收集關于HTML5自定義data-* data(obj)屬性和jquery的data()方法的使用的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 泾阳县| 茶陵县| 杭锦后旗| 靖远县| 蒙城县| 桃园县| 鄂托克前旗| 礼泉县| 商南县| 禄劝| 进贤县| 海门市| 武隆县| 罗田县| 霍山县| 洪洞县| 吉隆县| 泗洪县| 磐安县| 鄂州市| 巴彦县| 商洛市| 龙岩市| 荃湾区| 金堂县| 双桥区| 江源县| 枣庄市| 榆中县| 深水埗区| 双江| 来安县| 东阿县| 安岳县| 湘潭县| 阿克陶县| 顺平县| 石柱| 鄢陵县| 哈巴河县| 涪陵区|