Jquery如何使用animation动画效果改变背景色

Jquery如何使用animation动画效果改变背景色

一、问题引入 1. jquery的animate动画虽然强大,但是无法使用其进行背景色(background-color)的动画效果变化,因为animate动画效果只能动态改变数值型的参数,例如:top,left,width,height…等等 2. 但好在CSS它自带的animation动画效果更加强大,它可以为我们提供背景色的动态变化。所以我们可以利用Js+CSS的方法达成我们预期效果。

Jquery如何使用animation动画效果改变背景色

一、问题引入

  1. jquery的animate动画虽然强大,但是无法使用其进行背景色(background-color)的动画效果变化,因为animate动画效果只能动态改变数值型的参数,例如:top,left,width,height…等等

    好像网上也有说要装一个 “jquery.ui” 的插件之类的。但是博主我实在不想引入过多的插件,且恰好本人掌握的CSS比较好一点点,所以就想了下面这么个法子。

  2. 但好在 CSS 它自带的animation动画效果更加强大,它可以为我们提供背景色的动态变化。所以我们可以利用 Js+CSS 的方法达成我们预期效果。

二、demo展示


        Jquery无法通过animate动画改变背景色

            #btn{
                display: block;
                width:100px;
                margin:50px auto 0px;
                font:bold 30px/50px 'Microsoft Yahei';
                background-color: lightblue;
            }

            .box{
                margin:100px auto 0px;
                background-color: green;
                width:400px;
                height:400px;
            }

            @keyframes color_turn{
                from{
                    background-color: green;
                }
                to{
                    background-color: blue;
                }
            }

            .change_color{
                animation: color_turn 500ms ease 2 alternate;
            }

            $(function(){
                    var obtn = $('#btn');
                var obox = $('.box');

                obtn.click(function(){
                    /*
                          由于需要动画能够重复播放,所以我们需要反复删除和添加 change_color 这个类,
                          按照正常逻辑,先删除该类,再添加应当会正常播放动画,
                          但经多次试验只有第一次触发能够播放变色动画,接着再也无法触发了。这是由于两句执行的时间间隔太小,导致出现bug,无法达到预期效果

                          所以我们要想办法让下面这两句代码执行的时间间隔长一点
                          obox.removeClass('change_color');
                          obox.addClass('change_color');
                        */
                          obox.removeClass('change_color');
                          // obox.addClass('change_color');
                          /*----通过定时器延迟 10ms 后执行移除类的指令,这样就能解决问题了-----*/
                          var timer = setTimeout(function(){
                              obox.addClass('change_color');
                          },10);
                })

            })

2.1 程序设计思想

  1. 首先设计好一个由绿色变为蓝色的动画效果,使用一个类名为 “change_color” 的选择器来存放。
  2. 通过 js 实现点击按钮一次,先对 div 标签清除类名为 “change_color” 的类(第一次触发没有该类,不用管), 当定时器,经过 10ms 后会执行添加该类的命令,增加类后,动画便开始播放。通过定时器延长了两句代码的间隔时间,使得点击按钮可以重复播放背景色变化的动画效果。

2.2 重点与难点(坑)

  1. 之所以,要使用定时器来添加 “change_color” 这个类,是因为如果移除类与增加类两句代码 挨得太近,会导致bug,即无法实现重复点击按钮,反复播放动画。
    具体原因尚不明确,但猜测是因为判定移除该类的程序需要的时间长,所以两句代码放太近,会导致最后只判定到该类还存在(即没有移除过),而已有的类是不会触发动画的(只有在原来没有该类的基础上,添加类后,才会触发动画且只播放一次)
    所以为了能够重复播放,需要反复删除和添加类,同时由于两句执行时间间隔不能太小,所以设置了一个定时器,使得 10ms 后才执行添加类,保证程序能够成功判定类已被移除过。 别看 10ms 很小,里面的机器周期数是巨多的
  2. 其实还有一种方式,但前提是 中间的代码足够长 (即机器周期足够长)
obtn.click(function(){

            obox.removeClass('change_color');
            ...
            ...
            ...
            obox.addClass('change_color');
})

每次点击,播放动画前先移除类,经过若干个机器周期(究竟多少个,代码要多长,我也不清楚),再增加该类,便能达到预期效果。

2.3 效果展示

Jquery如何使用animation动画效果改变背景色

Original: https://www.cnblogs.com/fry-hell/p/13331117.html
Author: 油炸地狱
Title: Jquery如何使用animation动画效果改变背景色

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/611618/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • ELK收集MySQL慢日志并告警

    采用的是 filebeat采集日志, Redis做日志存储, logstash消费处理日志,将处理过的日志存储到 ES, kibana做日志展示, Elastalert做监控告警长…

    Linux 2023年5月27日
    092
  • Dockerfile 使用 SSH docker build

    如果在书写 Dockerfile 时,有些命令需要使用到 SSH 连接,比如从私有仓库下载文件等,那么我们应该怎么做呢? Dockerfile 文件配置 为了使得 Dockerfi…

    Linux 2023年6月7日
    078
  • 记一次 android 线上 oom 问题

    背景 公司的主打产品是一款跨平台的 App,我的部门负责为它提供底层的 sdk 用于数据传输,我负责的是 Adnroid 端的 sdk 开发。 sdk 并不直接加载在 App 主进…

    Linux 2023年6月6日
    099
  • C语言实现扫雷游戏(完整版)

    头文件定义、函数声明 下面就是扫雷中使用到的所有函数,为了省事我把所有的代码都放在一个C文件中实现 宏定义中设置了游戏的界面布局,以及设置地雷的个数(这里默认的是10个地雷),界面…

    Linux 2023年6月6日
    0128
  • 正则表达式

    基本正则表达式 元字符 . 匹配任意单个字符 [root@localhost ~]# mkdir /temp [root@localhost temp]# touch {1..9}…

    Linux 2023年6月13日
    087
  • 设计模式在业务系统中的应用

    本文的重点在于说明工作中所使用的设计模式,为了能够更好的理解设计模式,首先简单介绍一下业务场景。使用设计模式,可以简化代码、提高扩展性、可维护性和复用性。有哪些设计模式,这里就不再…

    Linux 2023年6月8日
    098
  • ASCLL 字符码

    信息在计算机上是用二进制数表示的,这种表示法让人很难理解。因此,计算机上都配有输入和输出设备,这些设备的主要目的就是以一种人类可阅读的形式将信息在这些设备上显示出来供人阅读理解。为…

    Linux 2023年6月7日
    0107
  • [编程一生]历史文章分类汇总

    2021年过去了,总结一下我的239篇原创。方便大家利用自带的搜索功能当智能机器人来用。 面试类 方法论 架构类 网络通信与 操作系统原理 稳定性建设 Java 中间件 程序人生 …

    Linux 2023年6月13日
    085
  • centos 更换yum 源

    1.如果系统有wget : 备份yum repo cd /etc/yum.repos.d for i in $(ls);do mv ${i}{,.bak};done for i i…

    Linux 2023年6月13日
    076
  • 每天一个 HTTP 状态码 101

    101 Switch Protocols 指示服务器端响应了客户端切换协议的要求… 101 Switching Protocols 当客户端的请求具有 Upgrade …

    Linux 2023年6月7日
    0108
  • python 正则匹配

    正则匹配 现公司要开发一个业务管理系统,要求注册环节的密码需要提示用户其安全等级,密码按如下规则进行计分,并根据不同的得分为密码进行安全等级划分;此外,密码的组成可以由字母,数字,…

    Linux 2023年6月8日
    090
  • 那些shellcode免杀总结

    首发先知: https://xz.aliyun.com/t/7170 自己还是想把一些shellcode免杀的技巧通过白话文、傻瓜式的文章把技巧讲清楚。希望更多和我一样web狗也能…

    Linux 2023年5月28日
    070
  • boot issue

    Q:生产过程中不小心把 boot文件删除了 ,或者升级kenerl时发现版本不兼容,需要回退,此时没有快照备份情况如何操作? A:boot 主要文件是内核和grub引导文件 1.进…

    Linux 2023年6月6日
    0107
  • MySQL实现备份(1)

    完全备份和部分备份 冷备份、热备份、温备份 温备份适用于:myisam 热备份适用于:innodb 物理备份和逻辑备份 完全备份:备份所有数据 部分备份:只备份部分数据内容 两者第…

    Linux 2023年6月7日
    0134
  • SUPERVISOR监控tomcat配置文件

    下方为Supervisor管理tomcat的配置,多注意红色位置路径修改: [program:tomcat] ; 管理的子程序名字,要和项目有关联,不能乱写 command=/us…

    Linux 2023年6月6日
    084
  • 双系统设置默认启动系统

    在原有windows系统下,我们装完Ubuntu系统后,会出现Ubuntu的grub引导界面(倒计时后自动进入Ubuntu),如下图所示。 假设我们需要将倒计时后默认启动的系统改为…

    Linux 2023年5月27日
    0102
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球