CSS类的操作

CSS类的操作

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <style type="text/css">
            .b1 {
                width: 100px;
                height: 100px;
                background-color: skyblue;
            }

            .b2 {
                /* width: 200px; */
                height: 200px;
                background-color: aquamarine;
            }
        </style>
        <script type="text/javascript">
            window.onload = function() {
                // 获取box
                var box = document.getElementById("box");
                // 获取btn01
                var btn01 = document.getElementById("btn01");
                // 获取btn02
                var btn02 = document.getElementById("btn02");
                // 为btn01绑定单击响应函数
                btn01.onclick = function() {
                    // 修改box的样式
                    /*
                    通过style属性来修改元素的样式,没修改一个样式,浏览器就需要重新渲染一次页面
                      这样的执行的性能是比较差的,而且这种形式当我们要修改多个样式时,也不方便
                    */
                    // box.style.width="200px";
                    // box.style.height="200px";
                    // box.style.backgroundColor="yellow";

                    // 修改box的class属性
                    /*
                    我们可以通过修改元素的class属性来间接的修改样式
                    只需要一次,即可同时修改多个样式
                      浏览器只需要重新渲染页面一次,性能比较好
                      并且这种方式,可以使表现和行为进一步的分离
                    */
                    toggleClass(box,"b2");
                }
                btn02.onclick=function(){
                    removeClass(box,"b2");
                }
            };
            // 定义一个函数,用来向一个元素中添加指定的class属性值
            /*
             - 参数:
               obj:要添加class属性的元素
               cn:要添加的class值
            */
            function addClass(obj, cn) {
                // 检查obj中是否含有cn》
                if (!hasClass(obj, cn)) {
                    obj.className += " " + cn;
                }

            }
            /*
            判断一个元素中是否含有指定的class属性值
             - 参数:
               obj:
               cn:
            */
            function hasClass(obj, cn) {
                // 判断obj中有没有cn class
                // 创建一个正则表达式
                // var reg=/\bb2\b/;
                var reg = new RegExp("\\b" + cn + "\\b");

                return reg.test(obj.className);

            }
            // 删除一个元素中的指定的class属性
            function removeClass(obj, cn) {
                // 创建一个正则表达式
                var reg = new RegExp("\\b" + cn + "\\b");

                // 删除class
                obj.className = obj.className.replace(reg, "");
            }
            /*
            toggleClass可以用来切换一个类
              - 如果元素中具有该类,则删除
              - 如果元素中没有该类,则添加
            */
            function toggleClass(obj,cn){
                // 判断obj中是否含有cn
                if(hasClass(obj,cn)){
                    // 有,则删除
                    removeClass(obj,cn);
                }else{
                    addClass(obj,cn);
                }
            }
        </script>
    </head>
    <body>
        <button id="btn01">点击按钮以后修改box的样式</button><br><br>
        <button id="btn02">点击按钮以后删除box的样式</button><br><br>
        <div id="box" class="b1"></div>
    </body>
</html>

原文地址:https://www.cnblogs.com/SSPOFA/p/12070543.html

时间: 2024-08-30 12:28:31

CSS类的操作的相关文章

jQuery - 获取并设置 CSS 类:对 CSS 元素进行操作

jQuery - 获取并设置 CSS 类 通过 jQuery,可以很容易地对 CSS 元素进行操作. 切换 CSS 类 jQuery 操作 CSS jQuery 拥有若干进行 CSS 操作的方法.我们将学习下面这些: addClass() - 向被选元素添加一个或多个类 removeClass() - 从被选元素删除一个或多个类 toggleClass() - 对被选元素进行添加/删除类的切换操作 css() - 设置或返回样式属性 实例样式表 下面的样式表将用于本页的所有例子: .import

jQuery 获取并设置 CSS 类

通过 jQuery,可以很容易地对 CSS 元素进行操作. 切换 CSS 类 jQuery 操作 CSS jQuery 拥有若干进行 CSS 操作的方法.我们将学习下面这些: addClass() - 向被选元素添加一个或多个类 removeClass() - 从被选元素删除一个或多个类 toggleClass() - 对被选元素进行添加/删除类的切换操作 css() - 设置或返回样式属性 实例样式表 下面的样式表将用于本页的所有例子: .important{font-weight:bold;

js操作css类

经常会使用js动态设置css类,两种方法. 1.className className是包含所有类的字符串,所以添加删除类就像操作字符串一样就好. 添加类的话比较简单,直接 obj.className += ' active'; 记得加空格. 移除类,需要使用字符串replace函数. obj.className.replace(' active', ''); 如果直接这样写,你会发现没用!!!! 后来才发现,replace不改变原值,而返回值是替换后的值,所以需要这样: obj.classNa

JQuery:JQuery操作CSS类

JQuery:CSS类jQuery - 获取并设置 CSS 类,通过 jQuery,可以很容易地对 CSS 元素进行操作.jQuery 操作 CSSjQuery 拥有若干进行 CSS 操作的方法.我们将学习下面这些: addClass() - 向被选元素添加一个或多个类 removeClass() - 从被选元素删除一个或多个类 toggleClass() - 对被选元素进行添加/删除类的切换操作 css() - 设置或返回样式属性 1.jQuery addClass() 方法实例1:下面的例子

第88天:HTML5中使用classList操作css类

在HTML5 API里,页面DOM里的每个节点上都有一个classList对象,程序员可以使用里面的方法新增.删除.修改节点上的CSS类.使用classList,程序员还可以用它来判断某个节点是否被赋予了某个CSS类. 一.Element.classList 这个classList对象里有很多有用的方法: 1 { 2 length: {number}, /* # of class on this element */ 3 add: function() { [native code] }, 4

使用HTML5里的classList操作CSS类

在HTML5 API里,页面DOM里的每个节点上都有一个classList对象,程序员可以使用里面的方法新增.删除.修改节点上的CSS类.使用classList,程序员还可以用它来判断某个节点是否被赋予了某个CSS类. Element.classList 这个classList对象里有很多有用的方法: { length: {number}, /* # of class on this element */ add: function() { [native code] }, contains:

深入理解脚本化CSS系列第三篇——脚本化CSS类

前面的话 在实际工作中,我们使用javascript操作CSS样式时,如果要改变大量样式,会使用脚本化CSS类的技术,本文将详细介绍脚本化CSS类 style 我们在改变元素的少部分样式时,一般会直接改变其行间样式 <div id="test" style="height:100px;width:100px;background-color:blue;"></div> <script> test.onclick = functio

第二十五篇 jQuery 学习7 获取并设置 CSS 类

jQuery 学习7 获取并设置 CSS 类 jQuery动态控制页面,那么什么是动态呢?我们就说一下静态,静态几乎又纯html+css完成,就是刷新页面之后,不会再出现什么变动,一个实打实的静态页面.那么动态,我们基于静态的特征说,动态:刷新页面之后,还可以发生样式改变等,就为动态. 这节课我们学习的是jQuery控制css,那么css样式都被改变了,算动态么?当然算啦,刷新页面之后发生了改变,就已经不是静态了,只要是变动了,就算是啦. 我们这节课学习四个控制css的方法: addClass(

JQ 的class类的操作 效果 遍历 内置遍历数组的函数 事件

class类的操作: 向指定元素添加相应类名: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script src="../public/jquery-3.3.1/jquery-3.3.1.min.js" type="text/javascript" charset="