国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

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

2020-03-24 18:17:02
字體:
供稿:網(wǎng)友
HTML HTML5自定義data-* data(obj)屬性和html' target='_blank'>jquery的data()方法的使用
可能大家在使用jquery mobile時,經(jīng)常會看到data-role、data-theme等的使用,比如:通過如下代碼即可實現(xiàn)頁眉的效果:

復(fù)制代碼代碼如下:
div data-role="header"
h1 我是標題 /h1
/div

通過手機瀏覽,效果如下: 為什么寫一個data-role= header 就能實現(xiàn)底部為黑色、文字居中顯示的效果呢?
本文提供一種最簡單的實現(xiàn)辦法,讓大家對這些用法有個直觀的了解。
我們寫一個html頁面,自定義一個data-chb= header 的屬性,希望具備這個屬性的div區(qū)域背景顏色為黑色,文字為白色,居中顯示;不具備data-chb自定義屬性的div按照默認方式顯示,html代碼如下:

復(fù)制代碼代碼如下:
body
div data-chb="header"
h1 我是使用了data-chb自定義屬性的div /h1
/div
br/
div
我沒有使用data-chb自定義屬性,該怎么展現(xiàn)就怎么展現(xiàn);
/div
/body

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

復(fù)制代碼代碼如下:
style
.ui_header {
background-color: black;
text-align: center;
color:white;
border:1px solid #000;
}
/style

然后我們通過如下js方法實現(xiàn)在頁面加載時,動態(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;
//也可以通過如下方式獲得自定義屬性
//var customAttr = elem.dataset["chb"];
//如果是我們預(yù)先定義好的header值,表示需要處理
if(customAttr=="header"){
//添加樣式
elem.setAttribute("class","ui_header");
}
}
}
}
/script

最后頁面顯示效果如下:

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

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

復(fù)制代碼代碼如下:
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屬性值:

復(fù)制代碼代碼如下:
var myid= jQuery("#awesome").data('myid');

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

復(fù)制代碼代碼如下:
div id="awesome-json" data-awesome='{"game":"on"}' /div

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

復(fù)制代碼代碼如下:
var gameStatus= jQuery("#awesome-json").data('awesome').game;

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

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 西藏| 南乐县| 阿鲁科尔沁旗| 蕉岭县| 永德县| 白山市| 贡嘎县| 治多县| 城步| 探索| 广东省| 城口县| 阿克陶县| 清苑县| 习水县| 那曲县| 井冈山市| 卫辉市| 新余市| 乡城县| 农安县| 宝应县| 个旧市| 永福县| 电白县| 乐清市| 富川| 新兴县| 延吉市| 黄山市| 富川| 健康| 黄浦区| 武平县| 思南县| 胶州市| 九龙城区| 徐汇区| 手游| 淮南市| 清原|