Table of Contents
Reading and writing methods
getAttribute/setAttribute
Browser compatibility
Home Web Front-end HTML Tutorial HTML5 data-* custom attributes_html/css_WEB-ITnose

HTML5 data-* custom attributes_html/css_WEB-ITnose

Jun 24, 2016 am 11:42 AM

In jQuery's attr and prop, it is mentioned that improper use of property in versions before IE9 will cause memory leaks, and the difference between Attribute and Property is also very troublesome. Add it in HTML5 The data-* method is used to customize attributes. The so-called data-* is actually the data- prefix plus the customized attribute name. Data can be stored using such a structure. Using data-* can solve the current situation of confusing and unmanaged custom attributes.

Reading and writing methods

data-* has two setting methods, you can write directly on the HTML element tag

<div id="test" data-age="24">        Click Here    </div>
Copy after login

The data -age is a custom attribute. Of course, we can also operate it through JavaScript. Elements in HTML5 will have a dataset attribute, which is a collection of key-value pairs of the DOMStringMap type

var test = document.getElementById('test');        test.dataset.my = 'Byron';
Copy after login

In this way, a data-my custom attribute is added to the div. There are two things to pay attention to when using JavaScript to operate the dataset

1. We need to when adding or reading attributes Remove the prefix data-*. Like the above example, we do not use the form test.dataset.data-my = 'Byron';.

2. If the attribute name also contains a hyphen (-), it needs to be converted to camel case naming. But if a selector is used in CSS, we need to use the hyphen format

as just now The code appends content

<style type="text/css">        [data-birth-date]        {            background-color: #0f0;            width:100px;            margin:20px;        }    </style>
Copy after login

test.dataset.birthDate = '19890615';
Copy after login

In this way we set data-birth- through JavaScript Date custom attribute, add some styles to the div in the CSS style sheet, see the effect

is also read through the dataset object, using "." To get the attributes, you also need to remove the data- prefix, and the hyphens need to be converted into camel case naming

var test = document.getElementById('test');        test.dataset.my = 'Byron';        test.dataset.birthDate = '19890615';        test.onclick = function () {            alert(this.dataset.my + ' ' + this.dataset.age+' '+this.dataset.birthDate);        }
Copy after login

getAttribute/setAttribute

Some students may ask if there is any difference between this and getAttribute/setAttribute except naming. Let’s take a look

var test = document.getElementById('test');        test.dataset.birthDate = '19890615';        test.setAttribute('age', 25);        test.setAttribute('data-sex', 'male');        console.log(test.getAttribute('data-age')); //24        console.log(test.getAttribute('data-birth-date')); //19890516        console.log(test.dataset.age); //24        console.log(test.dataset.sex); //male
Copy after login

In this way we can see that both have set the attributes to attributes (nonsense, otherwise they can call them custom attributes), that is It is said that getAttribute/setAttribute can operate all dataset contents. The dataset contents are only a subset of attributes. The special thing is the naming, but there are only attributes with data- prefix in the dataset (there is no age=25 one).

So why do we still use data-*? One of the biggest advantages is that we can manage all custom attributes in a unified manner in the dataset object. It is very convenient to traverse everything without going to zero. It’s scattered, so it’s still good to use.

Browser compatibility

The bad news is that the browser compatibility of data-* is very unoptimistic

  • Internet Explorer 11
  • Chrome 8
  • Firefox 6.0
  • Opera 11.10
  • Safari 6
  • Among them, IE11 is simply blinding the eyes of friends. It seems that if you want to fully use this attribute The road is long and the journey is long

    This article is reproduced from: http://www.cnblogs.com/dolphinX/p/3348458.html

    Statement of this Website
    The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

    Hot AI Tools

    Undresser.AI Undress

    Undresser.AI Undress

    AI-powered app for creating realistic nude photos

    AI Clothes Remover

    AI Clothes Remover

    Online AI tool for removing clothes from photos.

    Undress AI Tool

    Undress AI Tool

    Undress images for free

    Clothoff.io

    Clothoff.io

    AI clothes remover

    Video Face Swap

    Video Face Swap

    Swap faces in any video effortlessly with our completely free AI face swap tool!

    Hot Tools

    Notepad++7.3.1

    Notepad++7.3.1

    Easy-to-use and free code editor

    SublimeText3 Chinese version

    SublimeText3 Chinese version

    Chinese version, very easy to use

    Zend Studio 13.0.1

    Zend Studio 13.0.1

    Powerful PHP integrated development environment

    Dreamweaver CS6

    Dreamweaver CS6

    Visual web development tools

    SublimeText3 Mac version

    SublimeText3 Mac version

    God-level code editing software (SublimeText3)

    What is the purpose of the <progress> element? What is the purpose of the <progress> element? Mar 21, 2025 pm 12:34 PM

    The article discusses the HTML &lt;progress&gt; element, its purpose, styling, and differences from the &lt;meter&gt; element. The main focus is on using &lt;progress&gt; for task completion and &lt;meter&gt; for stati

    Is HTML easy to learn for beginners? Is HTML easy to learn for beginners? Apr 07, 2025 am 12:11 AM

    HTML is suitable for beginners because it is simple and easy to learn and can quickly see results. 1) The learning curve of HTML is smooth and easy to get started. 2) Just master the basic tags to start creating web pages. 3) High flexibility and can be used in combination with CSS and JavaScript. 4) Rich learning resources and modern tools support the learning process.

    What is the purpose of the <datalist> element? What is the purpose of the <datalist> element? Mar 21, 2025 pm 12:33 PM

    The article discusses the HTML &lt;datalist&gt; element, which enhances forms by providing autocomplete suggestions, improving user experience and reducing errors.Character count: 159

    What is the viewport meta tag? Why is it important for responsive design? What is the viewport meta tag? Why is it important for responsive design? Mar 20, 2025 pm 05:56 PM

    The article discusses the viewport meta tag, essential for responsive web design on mobile devices. It explains how proper use ensures optimal content scaling and user interaction, while misuse can lead to design and accessibility issues.

    What is the purpose of the <iframe> tag? What are the security considerations when using it? What is the purpose of the <iframe> tag? What are the security considerations when using it? Mar 20, 2025 pm 06:05 PM

    The article discusses the &lt;iframe&gt; tag's purpose in embedding external content into webpages, its common uses, security risks, and alternatives like object tags and APIs.

    The Roles of HTML, CSS, and JavaScript: Core Responsibilities The Roles of HTML, CSS, and JavaScript: Core Responsibilities Apr 08, 2025 pm 07:05 PM

    HTML defines the web structure, CSS is responsible for style and layout, and JavaScript gives dynamic interaction. The three perform their duties in web development and jointly build a colorful website.

    What is the purpose of the <meter> element? What is the purpose of the <meter> element? Mar 21, 2025 pm 12:35 PM

    The article discusses the HTML &lt;meter&gt; element, used for displaying scalar or fractional values within a range, and its common applications in web development. It differentiates &lt;meter&gt; from &lt;progress&gt; and ex

    Understanding HTML, CSS, and JavaScript: A Beginner's Guide Understanding HTML, CSS, and JavaScript: A Beginner's Guide Apr 12, 2025 am 12:02 AM

    WebdevelopmentreliesonHTML,CSS,andJavaScript:1)HTMLstructurescontent,2)CSSstylesit,and3)JavaScriptaddsinteractivity,formingthebasisofmodernwebexperiences.

    See all articles