麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

html5的自定義data-*屬性和jquery的data()方法的使用示例

2019-11-20 22:22:42
字體:
來源:轉載
供稿:網友
人們總喜歡往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-*" 數據
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产精品免费视频观看 | 日韩精品久久久久久久九岛 | 国内精品久久久久久影视8 嫩草影院在线观看网站成人 | 嫩嫩的freehdxxx | 国产成人精品无人区一区 | 巨根插入 | 亚洲午夜激情网 | 国产精品av久久久久久网址 | 日韩毛片免费观看 | 成人啪啪色婷婷久 | 羞羞视频入口 | 日韩av官网| 91久久久久久久一区二区 | 国产精品区在线12p 午夜视频色 | 91精品国产一区二区三区四区在线 | 久久综合九色 | 精品久久一区二区 | 黄色免费在线视频网站 | 欧美黄色免费视频 | 亚州欧美在线 | 国产 日韩 亚洲 欧美 | 国产精品91久久久 | 羞羞视频免费观看网站 | av在线久草 | 3344永久免费 | 久久精品视频日本 | 在线成人免费视频 | 黑色丝袜美美女被躁视频 | 91 在线视频观看 | 国产98色| 91精品国啪老师啪 | 国产亚洲在| 欧美日韩国产成人在线观看 | 精品欧美一区二区精品久久 | 91快色| 中文字幕国产欧美 | 黄色一级电影网 | 成年人在线视频免费 | 中文字幕在线播放不卡 | 久久国产在线观看 | 亚洲码无人客一区二区三区 |