html5的自訂data-*屬性和jquery的data()方法的使用樣本

來源:互聯網
上載者:User

人們總喜歡往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-*" 資料

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.