html5的自定義data-*屬性和jquery的data()方法的使用示例
更新時間:2013年08月21日 15:38:53 作者:
人們總喜歡往HTML標簽上添加自定義屬性來存儲和操作數(shù)據(jù),這就是為什么在HTML5規(guī)范里增加了一個自定義data屬性,你可以拿它做很多有用的事情
人們總喜歡往HTML標簽上添加自定義屬性來存儲和操作數(shù)據(jù)。但這樣做的問題是,你不知道將來會不會有其它腳本把你的自定義屬性給重置掉,此外,你這樣做也會導致html語法上不符合Html規(guī)范,以及一些其它副作用。這就是為什么在HTML5規(guī)范里增加了一個自定義data屬性,你可以拿它做很多有用的事情。
你可以去讀一下HTML5的詳細規(guī)范,但這個自定義data屬性的用法非常的簡單,就是你可以往HTML標簽上添加任意以 "data-"開頭的屬性,這些屬性頁面上是不顯示的,它不會影響到你的頁面布局和風格,但它卻是可讀可寫的。
下面的一個代碼片段是一個有效的HTML5標記:
<div id="awesome"
data-myid="3e4ae6c4e">Some awesome data</div>
可是,怎么來讀取這些數(shù)據(jù)呢?你當然可以遍歷頁面元素來讀取你想要的屬性,但jquery已經(jīng)內(nèi)置了方法來操作這些屬性。使用jQuery的.data()方法來訪問這些"data-*" 屬性。其中一個方法就是 .data(obj),這個方法是在 jQuery1.4.3版本后出現(xiàn)的,它能返回相應的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值,你能得到相應的value:
var gameStatus= jQuery("#awesome-json").data('awesome').game;
console.log(gameStatus);
你也可以通過.data(key,value)方法直接給"data-*" 屬性賦值。一個重要的你要注意的事情是,這些"data-*" 屬性應該和它所在的元素有一定的關(guān)聯(lián),不要把它當成存放任意東西的存儲工具。
補充:盡管"data-*" 是HTML5才出現(xiàn)的屬性,但jquery是通用的,所以,在非HTML5的頁面或瀏覽器里,你仍然可以使用.data(obj)方法來操作"data-*" 數(shù)據(jù)
你可以去讀一下HTML5的詳細規(guī)范,但這個自定義data屬性的用法非常的簡單,就是你可以往HTML標簽上添加任意以 "data-"開頭的屬性,這些屬性頁面上是不顯示的,它不會影響到你的頁面布局和風格,但它卻是可讀可寫的。
下面的一個代碼片段是一個有效的HTML5標記:
復制代碼 代碼如下:
<div id="awesome"
data-myid="3e4ae6c4e">Some awesome data</div>
可是,怎么來讀取這些數(shù)據(jù)呢?你當然可以遍歷頁面元素來讀取你想要的屬性,但jquery已經(jīng)內(nèi)置了方法來操作這些屬性。使用jQuery的.data()方法來訪問這些"data-*" 屬性。其中一個方法就是 .data(obj),這個方法是在 jQuery1.4.3版本后出現(xiàn)的,它能返回相應的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值,你能得到相應的value:
復制代碼 代碼如下:
var gameStatus= jQuery("#awesome-json").data('awesome').game;
console.log(gameStatus);
你也可以通過.data(key,value)方法直接給"data-*" 屬性賦值。一個重要的你要注意的事情是,這些"data-*" 屬性應該和它所在的元素有一定的關(guān)聯(lián),不要把它當成存放任意東西的存儲工具。
補充:盡管"data-*" 是HTML5才出現(xiàn)的屬性,但jquery是通用的,所以,在非HTML5的頁面或瀏覽器里,你仍然可以使用.data(obj)方法來操作"data-*" 數(shù)據(jù)
您可能感興趣的文章:
- jquery獲取自定義屬性(attr和prop)實例介紹
- jQuery中使用data()方法讀取HTML5自定義屬性data-*實例
- jquery 獲取自定義屬性(attr和prop)的實現(xiàn)代碼
- 使用jQuery獲取data-的自定義屬性
- jquery自定義屬性(類型/屬性值)
- jQuery Easyui Tabs擴展根據(jù)自定義屬性打開頁簽
- jquery操作HTML5 的data-*的用法實例分享
- jquery遍歷標簽中自定義的屬性方法
- jQuery實現(xiàn)的一個自定義Placeholder屬性插件
- 用jquery獲取自定義的標簽屬性的值簡單實例
- jQuery判斷自定義屬性data-val用法示例
相關(guān)文章
jQuery animate和CSS3相結(jié)合實現(xiàn)緩動追逐效果附源碼下載
這篇文章主要介紹了jQuery animate和CSS3相結(jié)合實現(xiàn)緩動追逐效果的相關(guān)資料,需要的朋友可以參考下2016-04-04擴展Jquery插件處理mouseover時內(nèi)部有子元素時發(fā)生樣式閃爍
在我們對一個dom添加mouseover和mouseout時,也就是jquery的hover事件,如果該dom有子元素,鼠標移到子元素時會觸發(fā)mouseout事件,但往往實際情況我們希望在子元素上不觸發(fā)out事件2011-12-12jQuery學習筆記之jQuery.fn.init()的參數(shù)分析
這篇文章主要介紹了jQuery.fn.init()的參數(shù)分析,需要的朋友可以參考下2014-06-06JQuery使用$.ajax和checkbox實現(xiàn)下次不在通知功能
這篇文章主要介紹了JQuery使用$.ajax和checkbox實現(xiàn)下次不在通知功能,本文給出HTML代碼、JS代碼、和后端JAVA代碼完整示例,需要的朋友可以參考下2015-04-04