html5的自定義data-*屬性與jquery的data()方法的使用
發(fā)布時(shí)間:2014-07-02 16:43:04 作者:佚名
我要評論

在HTML5規(guī)范里增加了一個自定義data屬性,你可以拿它做很多有用的事情,下面為大家介紹下HTML5的自定義data-* 屬性和jquery的data()方法的使用,感興趣的朋友不要錯過
人們總喜歡往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的詳細(xì)規(guī)范,但這個自定義data屬性的用法非常的簡單,就是你可以往HTML標(biāo)簽上添加任意以 "data-"開頭的屬性,這些屬性頁面上是不顯示的,它不會影響到你的頁面布局和風(fēng)格,但它卻是可讀可寫的。
下面的一個代碼片段是一個有效的HTML5標(biāo)記:
復(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)成存放任意東西的存儲工具。
譯者補(bǔ)充:盡管"data-*" 是HTML5才出現(xiàn)的屬性,但jquery是通用的,所以,在非HTML5的頁面或?yàn)g覽器里,你仍然可以使用.data(obj)方法來操作"data-*" 數(shù)據(jù)。
相關(guān)文章
- 這篇文章主要介紹了詳解HTML5 data-* 自定義屬性的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-01-24
HTML5自定義屬性前綴data-及dataset的使用方法(html5 新特性)
這篇文章主要介紹了HTML5自定義屬性前綴data-及dataset的使用方法(html5 新特性),需要的朋友可以參考下2017-08-24全面解析HTML5中的標(biāo)準(zhǔn)屬性與自定義屬性
這篇文章主要介紹了HTML5中的標(biāo)準(zhǔn)屬性與自定義屬性,文中也談到了JavaScript操作DOM時(shí)訪問自定義屬性的一些相關(guān)知識點(diǎn),非常推薦,需要的朋友可以參考下2016-02-18HTML5的自定義屬性data-*詳細(xì)介紹和JS操作實(shí)例
HTML5 增加了一項(xiàng)新功能是 自定義數(shù)據(jù)屬性 ,也就是 data-* 自定義屬性。在HTML5中我們可以使用以 data- 為前綴來設(shè)置我們需要的自定義屬性,來進(jìn)行一些數(shù)據(jù)的存放2014-04-10HTML5自定義data-* data(obj)屬性和jquery的data()方法的使用
可能大家在使用jquery mobile時(shí),經(jīng)常會看到data-role、data-theme等的使用,這些都是HTML5自定義屬性,本文整理一些,需要的朋友可以參考下2012-12-13- 這篇文章主要介紹了HTML5自定義屬性的問題分析,需要的朋友可以參考下2019-08-16