People always like to add custom attributes to the HTML tag to store and manipulate the data. But the problem with this is that you don't know if there will be other scripts that will reset your custom properties in the future, and you'll also cause HTML syntax to not conform to HTML specifications and some other side effects. That's why you've added a custom data property to the HTML5 specification, and you can do a lot of useful things with it.
You can read the detailed specification of the HTML5, but the use of this custom data property is very simple: You can add any attribute that begins with "data-" to the HTML tag, which is not displayed on the page, it doesn't affect your page layout and style, but it's readable and writable.
The following code fragment is a valid HTML5 tag:
Copy the code code as follows:
- Data-myid= "3e4ae6c4e" >some awesome Data
Copy Code
But how do you read this data? You can certainly traverse the page elements to read the properties you want, but jquery has built-in methods to manipulate these properties. Use the jquery. Data () method to access these "data-*" properties. One way to do this is. Data (obj), which appears after the jQuery1.4.3 version, which returns the corresponding data property.
For example, you can read the Data-myid property value in the following notation:
- var myid= jQuery ("#awesome"). Data (' myID '); Console.log (myID);
Copy Code
You can also use the JSON syntax in the "data-*" attribute, for example, if you write the following HTML:
Copy Code
You can access this data through JS directly, through the JSON key value, you can get the corresponding value:
- var gamestatus= jQuery ("#awesome-json"). Data (' awesome '). Game; Console.log (GameStatus);
Copy Code
You can also assign a value directly to the "data-*" property by using the. Data (Key,value) method. One important thing you should be aware of is that these "data-*" attributes should be associated with the element in which it resides, not as a storage tool for storing anything.
Although data-* is a HTML5 attribute, jquery is generic, so you can use the. Data (obj) method to manipulate "data-*" data in non-HTML5 pages or browsers.
The use of the HTML5 custom data-* property with the data () method of jquery