日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

HTML 5 的自定义 data-* 属性和jquery的data()方法的使用

發(fā)布時(shí)間:2023/12/13 HTML 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 HTML 5 的自定义 data-* 属性和jquery的data()方法的使用 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

?

      HTML 5 的自定義 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ù)。

轉(zhuǎn)載于:https://www.cnblogs.com/juancreate2014/p/3529098.html

總結(jié)

以上是生活随笔為你收集整理的HTML 5 的自定义 data-* 属性和jquery的data()方法的使用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。