What are built-in and custom Data Attributes in JavaScript?

In Javascript, data attributes are special attributes that allow you to store custom data on HTML elements. Data attributes are defined using the data- prefix, followed by the name of the attribute.

There are two types of data attributes in JavaScript: built-in data attributes and custom data attributes.

Built-in data attributes are attributes that are predefined by the HTML specification and have specific meanings and behaviors. Some examples of built-in data attributes are data-id, data-src, and data-title. These attributes are used by the browser or by third-party libraries to store and access data on elements.

Custom data attributes, on the other hand, are attributes that you can define and use to store custom data on elements. These attributes are not predefined by the HTML specification and do not have any special meaning or behavior. You can use them to store any kind of data that you need to access in your JavaScript code.

Here is an example of using data attributes in JavaScript:

<!-- Define a custom data attribute on an element -->
<div id="my-element" data-custom-data="hello, world"></div>

<script>
  // Get a reference to the element
  const element = document.getElementById("my-element");

  // Get the value of the custom data attribute
  const customData = element.dataset.customData;

  // Output the value of the custom data attribute
  console.log(customData); // Output: "hello, world"
</script>

In this code, a custom data attribute named data-custom-data is defined on the div element. The dataset property is used to access the value of the attribute in JavaScript. This property returns an object containing all of the element’s data attributes, with the attribute names as keys and the attribute values as values.

You can use data attributes to store any kind of data that you need to access in your JavaScript code. They are a convenient and flexible way of attaching custom data to HTML elements and can be useful in many different scenarios.

I hope this helps! Let me know if you have any questions.