Home Web Front-end H5 Tutorial classList attribute in HTML5

classList attribute in HTML5

Mar 19, 2017 am 11:56 AM
php php tutorial Video tutorial

[Introduction] Previously we introduced some newly added selectors in HTML5, namely querySelector(), querySelectorAll() and getElementsByClassName(). These three have their own unique functions. If necessary, you can read the relevant content in HTML5 actual combat and analysis. Today, I have introduced to you some newly added selectors in HTML5, namely querySelector(), querySelectorAll() and getElementsByClassName(). These three have their own unique functions. If necessary, you can read the relevant content in HTML5 actual combat and analysis. Today I will introduce to you the classList attribute.

What exactly does the classList attribute do? Let’s leave classList alone for now. We consider the question, that is, how do we delete one of the class names among elements with multiple class names? Menglong struggled with his brain and finally came up with a way to achieve it. Delete the class name meng among the three class names li, meng and long. The code is as follows

HTML code

<p class="li meng long">梦龙小站</p>
Copy after login
Copy after login
Copy after login
Copy after login
  1. JavaScript code
//获取要删除类名meng的p  
var p = document.getElementsByTagName("p")[0];  
  
//获取类名字符串并拆分成数组  
var allClassName = p.className.split(" ");  
  
//找到要删除的类名  
var i, len,   
    pos = -1;  
  
for(i=0, len = allClassName.length; i < len; i++){  
    if(allClassName[i] == "meng"){  
        pos = i;  
        break;  
    }  
}  
  
//删除类名  
allClassName.splice(pos, 1);  
  
alert(allClassName) //li,long  
  
//将其余的类名拼成字符串并重新添加到元素的类名中  
p.className = allClassName.join(" ");
Copy after login

Preview effect

classList attribute in HTML5

## In order to remove "meng" from the element class name, the above code All are required. Use a similar algorithm to replace the class name and confirm whether the class name is contained in the element. If you add a class name, you can complete it by splicing strings, but you must make sure through detection that the same class name will not be added multiple times. Many JavaScript libraries have implemented this method to simplify the operation. To delete a class name, you must first obtain the existing class name, find the location where the class name is to be deleted, and then delete it.

As can be seen from the above method, it takes several lines of code to implement a simple deletion function. If you don’t want to write several lines of code, you have to introduce a library and use the methods in the library. With HTML5, there is no need to be so troublesome. We can use the classList attribute in HTML5 to complete these steps. This classList attribute is an instance of the new collection type DOMTokenList. Similar to other DOM collections. DOMTokenList has a length attribute that indicates how many elements it contains. To obtain each element, you can use the item() method or square bracket syntax. Additionally, below are the methods defined for this new type.

1. remove(value)

The remove(value) method means to delete the given string from the list. A small example is as follows:

HTML code

<p class="li meng long">梦龙小站</p>
Copy after login
Copy after login
Copy after login
Copy after login

JavaScript code

//获取要删除类名meng的p  
var p = document.getElementsByTagName("p")[0];  
  
alert(p.classList)  //li meng long  
  
p.classList.remove("meng")   
  
alert("p.className: " + p.className)  //p.className: li long
Copy after login
Preview effect

classList attribute in HTML5

2. contains(value)

The contains(value) method indicates whether a given value exists in the list Value, if it exists, return "true", otherwise return "false". A small example is as follows:

HTML code

<p class="li meng long">梦龙小站</p>
Copy after login
Copy after login
Copy after login
Copy after login

JavaScript code

//获取要删除类名meng的p  
var p = document.getElementsByTagName("p")[0];  
  
alert(p.classList.contains("meng")) //true  
  
alert(p.classList.contains("menglong")) //false
Copy after login

3. add(value)

The add(value) method indicates that the string in the list is added to the list. If it already exists, it will not be added. A small example is as follows:

HTML code

<p class="li meng long">梦龙小站</p>
Copy after login
Copy after login
Copy after login
Copy after login

JavaScript code

//添加类名 menglong  
  
//获取要删除类名meng的p  
var p = document.getElementsByTagName("p")[0];  
  
p.classList.add("menglong");  
  
alert("p.className: " + p.className)  //p.className: li meng long menglong
Copy after login

Preview effect

classList attribute in HTML5

4. toggle(value)

toggle(value) method, if the given value already exists in the list value, delete it; if the given value is not in the list, add it. A small example is as follows:

HTML code

<p class="li meng long">梦龙小站</p>  

梦龙小站

Copy after login

JavaScript code

//切换类名 meng  
  
//获取要删除类名li的p  
var p = document.getElementsByTagName("p");  
var i, len;  
  
for(i=0, len = p.length; i< len; i++){  
    p[i].classList.toggle("meng");  
}  
  
  
alert("p[0].className: " + p[0].className)  //p[0].className: li long  
alert("p[1].className: " + p[1].className)  //p[1].className: li meng long
Copy after login

Preview effect

classList attribute in HTML5

Small examples about classList have been presented to you. These small methods can be clearly demonstrated and explained through small examples. . With classList, unless you need to delete all class names or completely rewrite the class attribute of the element, the className attribute is no longer needed, and there are many practical methods attached. Browsers that support the classList attribute include Firefox 3.6+ and Chrome.

The classList attribute of HTML5 actual combat and analysis is introduced here. The accumulation of bit by bit is tomorrow’s success. If you learn a little HTML5 in one day, you will definitely learn it successfully one day. Thank you all for supporting Menglong Station. For more updates about HTML5, please pay attention to Menglong Station’s updates on HTML5 practice and analysis.

The above is the detailed content of classList attribute in HTML5. For more information, please follow other related articles on the PHP Chinese website!

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

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

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)

CakePHP Project Configuration CakePHP Project Configuration Sep 10, 2024 pm 05:25 PM

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

CakePHP Date and Time CakePHP Date and Time Sep 10, 2024 pm 05:27 PM

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

CakePHP File upload CakePHP File upload Sep 10, 2024 pm 05:27 PM

To work on file upload we are going to use the form helper. Here, is an example for file upload.

CakePHP Routing CakePHP Routing Sep 10, 2024 pm 05:25 PM

In this chapter, we are going to learn the following topics related to routing ?

Discuss CakePHP Discuss CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

How To Set Up Visual Studio Code (VS Code) for PHP Development How To Set Up Visual Studio Code (VS Code) for PHP Development Dec 20, 2024 am 11:31 AM

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

CakePHP Creating Validators CakePHP Creating Validators Sep 10, 2024 pm 05:26 PM

Validator can be created by adding the following two lines in the controller.

See all articles