如何在 JavaScript 中检查给定元素是否具有指定的类?

概述

要首先执行某个任务,我们需要通过其类或 ID 来访问该特定元素,因此在访问该元素之前,我们检查该类是否存在于该特定元素中。 classList 对象包含 JavScript 中的内置方法 classList.contains()。此方法确定给定元素是否属于指定类。整个过程将会发生,因为首先我们必须通过 getElementById()、getElementsByClassName() 或任何其他方法访问该元素。访问它后,我们必须使用 classList.contains() 方法检查该类。

语法

这个问题使用的语法是 –

classList.contains(className);
  • classList – 这是 JavaScript 中的一个对象,它接收特定元素中包含的类的数组。

  • contains – 这是 classList 对象的一个​​方法,它检查指定的类是否存在于给定元素中。

  • className – 这是我们必须在给定元素中搜索的指定名称。

算法

  • 步骤 1 – 在 body 标记内创建一些 HTML 元素。为每个元素指定一些类。

  • 步骤 2 – 在 HTML 按钮中指定 onclick() 事件方法。

  • 第 3 步 – 创建 JavaScript 箭头函数。访问任何 HTML 并将其存储在变量中。

  • 步骤 4 – 使用 classList 对象的 contains() 方法。将变量作为参数传递到 contains() 方法中。

  • 步骤 5 – 如果返回 true,则 HTML 元素中存在特定类,否则如果返回 false,则元素中不存在特定类。

示例1:当元素包含指定类时

我们在 body 标签中使用了“

”标签,其中包含类名:class =“my-para first lorems”,所以这些是类名。我们的任务是检查元素以查看它是否包含指定的元素。为此,我们使用了 contains() 方法,它是 classList 对象的方法。因此,我们要检查的类作为参数传递到“contains()”方法中,该方法检查类的确定性。

<!DOCTYPE html>
<html lang="en">
<head>
   <title>Check for specified class in a given element</title>
   <style>
      body{
         background-color: #0a0a0a;
         color: white;
      }
   </style>
</head>
   <body>
      <p id="para" class="my-para first lorems">I am para with certain classes, check now.</p>
      <button onclick="check()" style="margin-bottom: 8px;">Check Now</button><br>
      <div id="output" style="display: inline-block; padding: 0.3rem;"></div>
      
      <script>
         check = () => {
            var ptag = document.getElementById("para");
            var cl = ptag.classList;
            var clContain = cl.contains("my-para");
      
            if (clContain) {
               document.getElementById("output").innerHTML += "Element contains specified  class";
               document.getElementById("output").style.background = "green";
               document.getElementById("output").style.color = "white";
            } else {
               document.getElementById("output").innerHTML += "Element does not contains the specified class";
               document.getElementById("output").style.background = "tomato";
               document.getElementById("output").style.color = "white";
            }
         }
      
      </script>
   </body>
</html>

上述示例的输出,因为“Elements contains specified class”的输出为 true。

示例2:当元素不包含指定类时

下图显示“Element 不包含指定的类”,这意味着当检查 classList.contains() 时,它一定返回了 false。因此错误条件已终止。

<!DOCTYPE html>
<html lang="en">
<head>
   <title>Check for pecified class in a given element</title>
   <style>
      body{
         background-color: #0a0a0a;
         color: white;
      }
   </style>
</head>
   <body>
      <p id="para" class="my-para first lorems">I am para with certain classes, check now.</p>
      <button onclick="check()" style="margin-bottom: 8px;">Check Now</button><br>
      <div id="output" style="display: inline-block; padding: 0.3rem;"></div>

      <script>
         check = () => {
            var ptag = document.getElementById("para");
            var cl = ptag.classList;
            var clContain = cl.contains("mypara");
      
            if (clContain) {
               document.getElementById("output").innerHTML += "Element contains specified  class";
               document.getElementById("output").style.background = "green";
               document.getElementById("output").style.color = "white";
            } else {
               document.getElementById("output").innerHTML += "Element does not contains the specified class";
               document.getElementById("output").style.background = "tomato";
               document.getElementById("output").style.color = "white";
            }
         }
      </script>
   </body>
</html>

结论

classList的返回类型是DOMTokenList,它是一个数组类型。它包含该特定元素中存在的类的列表。可以通过使用任何 for 循环或映射对其进行迭代来查看 DOMTokenList。

var ptag = document.getElementById("para").classList;
ptag.forEach(element => {
   console.log(element);
});

“contains()”方法返回布尔类型的结果,为 true 或 false。 classList 对象包含类的数组。因此,当 contains() 方法检查指定的类时,它会检查 DOMTokenList,并代表它做出决定并返回 true 或 false。

以上就是如何在 JavaScript 中检查给定元素是否具有指定的类?的详细内容,更多请关注双恒网络其它相关文章!

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 精力有限,不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别
9.本站默认解压密码为:www.sudo1.com
本站提供的一切软件、教程和内容信息仅限用于学习和研究目的。
不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。
本站信息来自网络收集整理,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑或手机中彻底删除上述内容。
如果您喜欢该程序和内容,请支持正版,购买注册,得到更好的正版服务。
我们非常重视版权问题,如有侵权请邮件与我们联系处理。敬请谅解!

云资源网 » 如何在 JavaScript 中检查给定元素是否具有指定的类?

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
提示下载完但解压或打开不了?
最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。 若排除这种情况,可在对应资源底部留言,或 联络我们.。
你们有qq群吗怎么加入?
当然有的,如果你是帝国cms、易优cms、和pbootcms系统的爱好者你可以加入我们的QQ千人交流群https://www.sudo1.com/page-qun.html。
  • 会员数(个)
  • 12334资源数(个)
  •        
  • 资源(G)
  •        
  • 今日下载
  • 1405稳定运行(天)

提供最优质的资源集合

立即查看 了解详情