JavaScript脚本操作CSS

脚本化CSS就是使用JavaScript脚本操作CSS,配合HTML5、Ajax、jQuery等技术,可以设计出细腻、逼真的页面特效和交互行为,提升用户体验,如网页对象的显示/隐藏、定位、变形、运动等动态样式。

1、CSS脚本化基础

CSS样式有两种形式:样式属性和样式表。DOM 2级规范提供了一套API,其中包括CSS样式表访问接口。在DOM 2级规范之前,允许使用标签对象的style属性访问行内样式属性。

1.1、访问行内样式

任何支持style特性的HTML标签,在JavaScript中都有一个对应的style脚本属性。style是一个可读可写的对象,包含了一组CSS样式。

使用style的cssText属性可以返回行内样式的字符串表示。同时style对象还包含一组与CSS样式属性一一映射的脚本属性。这些脚本属性的名称与CSS样式属性的名称对应。在JavaScript中,由于连字符是减号运算符,含有连字符的样式属性(如font-family),其脚本属性会以驼峰命名法重新命名(如fontFamily)。

【示例】border-right-color属性在脚本中应该使用borderRightColor:

    <div id="box" >盒子</div>
    <script>
    var box = document.getElementById("box");
    box.style.borderRightColor = "red";
    box.style.borderRightStyle = "solid";
    </script>

提示:使用CSS脚本属性时,需要注意几个问题:

  • float是JavaScript保留字,因此使用cssFloat表示与之对应的脚本属性的名称。
  • 在JavaScript中,所有CSS属性值都是字符串,必须加上引号。 elementNode.style.fontFamily = "Arial, Helvetica, sans-serif"; elementNode.style.cssFloat = "left"; elementNode.style.color = "#ff0000";
  • CSS样式声明结尾的分号不能够作为脚本属性值的一部分。
  • 属性值和单位必须完整地传递给CSS脚本属性,省略单位则所设置的脚本样式无效。

1.2、使用style对象

DOM 2级样式规范为style对象定义了一些属性,简单说明如下:

  • cssText:返回style的CSS样式字符串。
  • length:返回style的声明CSS样式的数量。
  • parentRule:返回style所属的CSSRule对象。
  • getPropertyCSSValue():返回包含指定属性的CSSValue对象。
  • getPropertyPriority():返回包含指定属性是否附加了!important命令。
  • item():返回指定下标位置的CSS属性的名称。
  • getPropertyValue():返回指定属性的字符串值。
  • removeProperty():从样式中删除给定属性。
  • setProperty():为指定属性设置值,也可以附加优先权标志。

1.3、使用styleSheets对象

在DOM 2级样式规范中,使用styleSheets对象可以访问页面中所有样式表,包括用<style>标签定义的内部样式表,以及用<link>标签或@import命令导入的外部样式表。

cssRules对象包含指定样式表中所有的规则(样式)。

提示:IE支持rules对象表示样式表中的规则,可以使用下面代码兼容不同浏览器:

    var cssRules = document.styleSheets[0].cssRules || document.styleSheets[0].rules;

在上面代码中,先判断浏览器是否支持cssRules对象,如果支持则使用cssRules(非IE浏览器),否则使用rules(IE浏览器)。

【示例】通过

    <style type="text/css">
    #box {
        width: 400px;
        height: 200px;
        background-color:#BFFB8F;
        border: solid 1px blue;
    }
    </style>
    <script>
    window.onload = function(){
        var box = document.getElementById("box");
        var cssRules = document.styleSheets[0].cssRules || document.styleSheets[0].rules;
        //判断浏览器类型
        box.innerHTML =  "<h3>盒子样式</h3>"
        box.innerHTML +=  "<br>边框:" + cssRules[0].style.border; //cssRules的border属性
        box.innerHTML +=  "<br>背景:" + cssRules[0].style.backgroundColor;
        box.innerHTML +=  "<br>高度:" + cssRules[0].style.height;
        box.innerHTML +=  "<br>宽度:" + cssRules[0].style.width;
    }
    </script>
    <div id="box"></div>

在这里插入图片描述

提示:cssRules(或rules)的style对象在访问CSS属性时,使用的是CSS脚本属性名,因此所有属性名称中不能使用连字符。例如:

    cssRules[0].style.backgroundColor;

1.4、使用selectorText对象

使用selectorText对象可以获取样式的选择器字符串表示。

【示例】使用selectorText属性获取第1个样式表(styleSheets[0])中的第3个样式(cssRules[2])的选择器名称,输出显示为“.blue”:

    <style type="text/css">
    #box { color:green; }
    .red { color:red; }
    .blue { color:blue; }
    </style>
    <link href="style1.css" rel="stylesheet" type="text/css" media="all" />
    <script>
    window.onload = function(){
        var cssRules = document.styleSheets[0].cssRules || document.styleSheets[0].rules;
        var box = document.getElementById("box");
        box.innerHTML =  "第一个样式表中第三个样式选择符 = " + cssRules[2].selectorText;
    }
    </script>
    <div id="box"></div>

![在这里插入图片描述](https://img-blog.csdnimg.cn/362be4183b8843b6b4ca2db68cf5f436.png

1.5、编辑样式

cssRules的style不仅可以读取,还可以写入属性值。

【示例】下面示例样式表中包含3个样式,其中蓝色样式类(.blue)定义字体显示为蓝色。用脚本修改该样式类(.blue规则)字体颜色为浅灰色(#999):

    <style type="text/css">
    #box { color:green; }
    .red { color:red; }
    .blue { color:blue; }
    </style>
    <script>
    window.onload = function(){
        var cssRules = document.styleSheets[0].cssRules || document.styleSheets[0].rules;
        cssRules[2].style.color="#999";        //修改样式表中指定属性的值
    }
    </script>
    <p class="blue">原为蓝色字体,现在显示为浅灰色。</p>

提示:上述方法修改样式表中的类样式,会影响其他对象或其他文档对当前样式表的引用,因此在使用时请务必谨慎。

在这里插入图片描述

1.6、添加样式

使用addRule()方法可以为样式表增加一个样式,具体用法如下:

    styleSheet.addRule(selector,style ,[index])

styleSheet表示样式表引用,参数说明如下:

  • selector:表示样式选择符,以字符串的形式传递。
  • style:表示具体的声明,以字符串的形式传递。
  • index:表示一个索引号,即添加样式在样式表中的索引位置,默认为-1,表示位于样式表的末尾,该参数可以不设置。Firefox支持使用insertRule()方法添加样式,用法如下: styleSheet.insertRule(rule ,[index])

参数说明如下:

  • rule:表示一个完整的样式字符串
  • index:与addRule()方法中的index参数作用相同,但默认为0,放置在样式表的末尾。

【示例】先在文档中定义一个内部样式表,然后使用styleSheets集合获取当前样式表,利用数组默认属性length获取样式表中包含的样式个数。最后在脚本中使用addRule()(或insertRule())方法增加一个新样式,样式选择符为p,样式声明背景色为红色,字体颜色为白色,段落内部补白为1个字体大小:

    <style type="text/css">
    #box { color:green; }
    .red { color:red; }
    .blue { color:blue; }
    </style>
    <script>
    window.onload = function(){
     var styleSheets = document.styleSheets[0];     //获取样式表引用
     var index = styleSheets.length;                //获取样式表中包含样式的个数
     if(styleSheets.insertRule){                    //判断浏览器是否支持insertRule()方法
                                                    //在内部样式表中增加p标签选择符的样式,插入样式表的末尾
          styleSheets.insertRule("p{background-color:red;color:#fff;padding:1em;}", index);
     }else{                                         //如果浏览器不支持insertRule()方法
          styleSheets.addRule("P", "background-color:red;color:#fff;padding:1em;", index);
     }
    }
    </script>
    <p>在样式表中增加样式操作</p>

在这里插入图片描述

1.7、读取渲染样式

CSS样式具有重叠特性,因此定义的样式与最终显示的样式并非完全相同。DOM定义了一个方法帮助用户快速检测当前对象的显示样式,不过IE和标准DOM之间实现的方法不同。

1.IE浏览器

IE使用currentStyle对象读取元素的最终显示样式,该对象为一个只读对象,包含元素的style属性,以及浏览器预定义的默认style属性。

2.非IE浏览器

DOM使用getComputedStyle()方法获取目标对象的显示样式,但是它属于document.defaultView对象。getComputedStyle()方法包含了两个参数:第一个参数表示元素,用来获取样式的对象;第二个参数表示伪类字符串,定义显示位置,一般可以省略,或者设置为null。

【示例】使用if语句判断当前浏览器是否支持document.defaultView,如果支持则进一步判断是否支持document.defaultView.getComputedStyle,如果支持则使用getComputedStyle()方法读取最终显示样式;否则,判断当前浏览器是否支持currentStyle,如果支持则使用它读取最终显示样式:

    <style type="text/css">
    #box { color:green; }
    .red { color:red; }
    .blue {color:blue; background-color:#FFFFFF;}
    </style>
    <script>
    window.onload = function(){
        var styleSheets = document.styleSheets[0];        //获取样式表引用指针
        var index = styleSheets.length;                   //获取样式表中包含样式的个数
        if(styleSheets.insertRule){                       //判断浏览器是否支持
          styleSheets.insertRule("p{background-color:red;color:#fff;padding:1em;}", index);
        }else{
         styleSheets.addRule("P", "background-color:red;color:#fff;padding:1em;", index);
        }
        var p = document.getElementsByTagName("p")[0];
        if( document.defaultView && document.defaultView.getComputedStyle)
         p.innerHTML = "背景色:"+document.defaultView.getComputedStyle(p,null).backgroundColor+"<br>字体颜色:"+document.
defaultView.getComputedStyle(p,null).color;
        else if( p.currentStyle)
         p.innerHTML = "背景色:"+p.currentStyle.backgroundColor+"<br>字体颜色:"+p.currentStyle.color;
        else p.innerHTML = "当前浏览器无法获取最终显示样式";
    }
    </script>
    <p class="blue">在样式表中增加样式操作</p>

在这里插入图片描述

1.8、读取媒体查询

使用window.matchMedia()方法可以访问CSS的Media Query语句。window.matchMedia()方法接收一个mediaQuery语句的字符串作为参数,返回一个MediaQueryList对象。该对象有以下两个属性:

  • media:返回所查询的mediaQuery语句字符串。
  • matches:返回一个布尔值,表示当前环境是否匹配查询语句。
    var result = window.matchMedia('(min-width: 600px)');
    result.media                                          //(min-width: 600px)
    result.matches                                        //true

【示例1】根据mediaQuery是否匹配当前环境,执行不同的JavaScript代码:

    var result = window.matchMedia('(max-width: 700px)');
    if (result.matches) {
        console.log('页面宽度小于等于700px');
    } else {
        console.log('页面宽度大于700px');
    }

【示例2】根据mediaQuery是否匹配当前环境,加载相应的CSS样式表:

    var result = window.matchMedia("(max-width: 700px)");
    if (result.matches){
        var linkElm = document.createElement('link');
        linkElm.setAttribute('rel', 'stylesheet');
        linkElm.setAttribute('type', 'text/css');
        linkElm.setAttribute('href', 'small.css');
        document.head.appendChild(linkElm);
    }

注意:如果window.matchMedia无法解析mediaQuery参数,应该返回false,而不是报错。例如:

    window.matchMedia('bad string').matches  //false

window.matchMedia方法返回的MediaQueryList对象有两个方法,用来监听事件:addListener方法和removeListener方法。如果mediaQuery查询结果发生变化,就调用指定回调函数。例如:

    var mql = window.matchMedia("(max-width: 700px)");
    //指定回调函数
    mql.addListener(mqCallback);
    //撤销回调函数
    mql.removeListener(mqCallback);
    function mqCallback(mql) {
        if (mql.matches) {
    //宽度小于等于700px
        } else {
    //宽度大于700px
        }
    }

上面代码中,回调函数的参数是MediaQueryList对象。回调函数的调用可能存在两种情况:一种是显示宽度从700px以上变为以下,另一种是从700px以下变为以上,所以在回调函数内部要判断一下当前的屏幕宽度。

2、实战

2.1、获取元素尺寸

使用offsetWidth和offsetHeight属性可以获取元素的尺寸,其中offsetWidth表示元素在页面中所占据的总宽度,offsetHeight表示元素在页面中所占据的总高度。

【示例】使用offsetWidth和offsetHeight属性获取元素大小。

    <div style="height:200px;width:200px;">
        <div style="height:50%;width:50%;">
            <div style="height:50%;width:50%;">
                <div style="height:50%;width:50%;">
                    <div id="div" style="height:50%;width:50%;border-style:solid;"></div>
                </div>
            </div>
        </div>
    </div>
    <script>
    var div = document.getElementById("div");
    var w = div.offsetWidth;                   //返回元素的总宽度
    var h = div.offsetHeight;                  //返回元素的总高度
    </script>

提示:上面示例在怪异模式下和标准模式的浏览器中解析结果差异很大,其中怪异模式解析返回宽度为21px,高度为21px,而在标准模式的浏览器中返回高度和宽度都为19px。

注意,offsetWidth和offsetHeight是获取元素尺寸的最好方法,但是当元素隐藏显示时,即设置样式属性display的值为none时,则offsetWidth和offsetHeight属性返回值都为0。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/123987.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

学习笔记:CANOE模拟LIN主节点和实际从节点进行通信测试

先写点感想&#xff0c;在LIN开发阶段&#xff0c;我一般用图莫斯USB工具来进行模拟主机节点发送数据。后来公司买了CANOE工具就边学习边搭建了LIN的测试工程&#xff0c;网上的资料真的很少&#xff0c;主要是靠自己一点点摸索前进&#xff0c;总算入门。几个月后的今天&#…

基于swing的人事管理系统

概述 个人项目人事管理系统&#xff0c;针对部门和人员之间的管理。 详细 一、项目UI 二、项目结构 三、项目使用方法 Eclipse导入现有现有项目到工作空间即可&#xff0c;会自动加载包内相关jar包&#xff0c;使用的java源文件 四、部分代码 MainFrm.java package view…

Docker指定容器使用内存

Docker指定容器使用内存 作者&#xff1a;铁乐与猫 如果是还没有生成的容器&#xff0c;你可以从指定镜像生成容器时特意加上 run -m 256m 或 --memory-swap512m来限制。 -m操作指定的是物理内存&#xff0c;还有虚拟交换分区默认也会生成同样的大小&#xff0c;而–memory-…

ubuntu系统黑屏,且光标不闪烁

选择第二个&#xff0c;进入恢复模式 选择第二个&#xff0c;进入恢复模式 选择root 输入&#xff1a; startx然后就可以进入文本界面或者图形化界面了&#xff0c;如果不行&#xff0c;报错&#xff0c;可能需要需要下载这个包&#xff0c;把这个错误到网上搜索一下就可以找…

批量迁移redis实例的key

我们知道migrate 命令可以迁移redis的多个key&#xff0c;但是如果redis的key有非常多&#xff0c;那用起来就很不方便了。 所以下面分享一个脚本来实现批量key的迁移&#xff0c;主要使用的命令为dump和restore 脚本如下&#xff1a; #!/bin/bash redis-cli -h host1 -p 63…

Redis被攻击纪实

一、前言 声明&#xff1a;本文仅供技术交流使用&#xff0c;严禁采用本文的方法进行任何非法活动。 上周新来的同事分享Redis的原理和机制&#xff0c;想起2017年的时候测试环境Redis被攻击&#xff0c;最后只能重新安装服务器&#xff0c;今天试验一把利用Redis漏洞进行攻击…

成集云 | 英克对接零售O2O+线上商城 | 解决方案

方案介绍 零售O2O线上商城是一种新型的商业模式&#xff0c;它通过线上和线下的融合&#xff0c;提供更加便捷的购物体验。其中&#xff0c;O2O指的是线上与线下的结合&#xff0c;通过互联网平台与实体店面的结合&#xff0c;实现线上线下的互动和协同。线上商城则是指通过互…

AI优秀企业案例——机器人流程自动化:达观数据RPA

通过学习业内领先公司的最佳实践&#xff0c;我们可以更好地将它们应用到我们自己的公司和业务中。特别是第三部分&#xff0c;提供了大量应用案例&#xff0c;让我们一起期待看到这些案例的结尾。 1.简介 达观数据是一家专注于智能文本机器人的国家高新技术企业&#xff0c;…

Leetcode-面试题 02.02 返回倒数第 k 个节点

快慢指针&#xff1a;让快指针先移动n个节点&#xff0c;之后快慢指针一起依次向后移动一个结点&#xff0c;等到快指针移动到链表尾时&#xff0c;慢指针则移动到倒数第n个结点位置。 /*** Definition for singly-linked list.* public class ListNode {* int val;* …

矩阵等价和向量组等价的一些问题

什么是向量组&#xff1f;答&#xff1a;向量组是由若干同维数的列向量&#xff08;或同维数的行向量&#xff09;组成的集合。什么是向量组等价&#xff1f;答&#xff1a;两个向量组&#xff0c;各自拼成矩阵A和B&#xff0c;向量组等价就是三秩相等&#xff0c;即r&#xff…

点信息标注_BillboardTextActor3D

开发环境&#xff1a; Windows 11 家庭中文版Microsoft Visual Studio Community 2019VTK-9.3.0.rc0vtk-example参考代码 demo解决问题&#xff1a;点附近创建左边或其他信息&#xff0c;且信息面板显示状态不受相机缩放、旋转影响 prj name: BillboardTextActor3D #include…

STM32笔记—定时器

目录 一、TIM简介 二、基本定时器&#xff08;TIM6和TIM7&#xff09; 1. TIM6和TIM7简介 2. TIM6和TIM7的主要特性 3. TIM6和TIM7的功能 3.1 时基单元 3.2 计数模式 3.3 时钟源 三、通用定时器 1. TIMx(2、3、4、5)简介 2. TIMx主要功能 3. 时钟选择 4. 影子寄存…

计算机视觉驾驶行为识别应用简述

一、什么是计算机视觉识别&#xff1f; 计算机视觉识别是一种基于图像处理和机器学习的人工智能应用技术&#xff0c;可以用于多个场景。常见应用场景包括人脸识别、场景识别、OCR识别以及商品识别等。今天以咱们国产系统豌豆云为例&#xff0c;为大家梳理一下在车辆驾驶行为中…

在Google Kubernetes集群创建分布式Jenkins(二)

上一篇博客在Google Kubernetes集群创建分布式Jenkins(一)-CSDN博客我介绍了如何在GCP的K8S集群上部署一个分布式的Jenkins&#xff0c;并实现了一个简单的Pipeline的运行。 在实际的开发中&#xff0c;我们通常都会按照以下的CICD流程来设置Pipeline 在我司的实际实践中&…

如何让群晖Audio Station公开共享的本地音频公网可访问?

文章目录 1. 本教程使用环境&#xff1a;2. 制作音频分享链接3. 制作永久固定音频分享链接&#xff1a; 之前文章我详细介绍了如何在公网环境下使用pc和移动端访问群晖Audio Station&#xff1a; 公网访问群晖audiostation听歌 - cpolar 极点云 群晖套件不仅能读写本地文件&a…

9.spark自适应查询-AQE之动态调整Join策略

目录 概述动态调整Join策略原理实战 动态优化倾斜的 Join原理实战 概述 broadcast hash join 类似于 Spark 共享变量中的广播变量&#xff0c;Spark join 如果能采取这种策略&#xff0c;那join 的性能是最好的 自适应查询AQE(Adaptive Query Execution) 动态调整Join策略 原…

vue 子页面通过暴露属性,实现主页面的某事件的触发

目录 1.前言2.代码2-1 子页面2-2 主页面 1.前言 需求&#xff1a;当我在子页面定义了一个定时器&#xff0c;点击获取验证码&#xff0c;计时器开始倒计时&#xff0c;在这个定时器没有走完&#xff0c;退出关闭子页面&#xff0c;再次进入子页面&#xff0c;定时器此时会被刷…

linux基础:3.linux基础环境开发工具和配置。

linux基础环境开发工具和配置 一.学习yum工具进行软件安装&#xff1a;1.什么是yum&#xff1a;2.查看软件包&#xff1a;3.安装和删除&#xff1a;4.yum生态&#xff1a; 二.vim的使用&#xff1a;一.快速介绍一下vim二.vim正常模式&#xff1a;2-1&#xff1a;命令模式1.光标…

1、C语言面向对象引入类和对象的概念

什么是类和对象 类 类是用户自定义的一种数据类型&#xff0c;也称类类型——C语言中的结构体 对象 类的一种具象 代码测试 #include <stdio.h>//类 struct Animal{ char name[12];//成员属性 int age; char sex; void (*peat)();//成员方法 void (*pbeat)(); };void…

【排序算法】 快速排序(快排)!图解+实现详解!

&#x1f3a5; 屿小夏 &#xff1a; 个人主页 &#x1f525;个人专栏 &#xff1a; 算法—排序篇 &#x1f304; 莫道桑榆晚&#xff0c;为霞尚满天&#xff01; 文章目录 &#x1f4d1;前言&#x1f324;️快速排序的概念☁️快速排序的由来☁️快速排序的思想☁️快速排序的实…