人們總是喜歡往HTML標籤上新增自訂屬性來儲存和操作資料。但這樣做的問題是,你不知道將來會不會有其它腳本把你的自訂屬性給重置掉,此外,你這樣做也會導致html語法上不符合Html規範,以及一些其它副作用。這就是為什麼在HTML5規範裡增加了一個自訂data屬性,你可以拿它做很多有用的事情。
你可以去唸一下HTML5的詳細規範,但這個自訂data屬性的用法非常的簡單,就是你可以往HTML標籤上新增任意以"data-"開頭的屬性,這些屬性頁面上是不顯示的,它不會影響到你的頁面佈局和風格,但它卻是可讀可寫的。
下面的一個程式碼片段是一個有效的HTML5標記:
複製程式碼
程式碼
data-myid="3e4ae6c4e">Some awesome data
複製程式碼
複製程式碼
複製程式碼
程式碼如下:
var myid= jQuery("#awesome").data('myid');
複製程式碼
複製程式碼
程式碼如下:
你可以透過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-*" 資料。