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)

大家都在看

  • 聊聊 Netty 那些事儿之 Reactor 在 Netty 中的实现(创建篇)

    本系列Netty源码解析文章基于 4.1.56.Final版本 在上篇文章《聊聊Netty那些事儿之从内核角度看IO模型》中我们花了大量的篇幅来从内核角度详细讲述了五种 IO&am…

    Linux 2023年6月6日
    093
  • cron 表达式

    cron 表达式 1.简介:一个cron表达式最少有5个空格来分割时间元素,总共有7个元素,分别如下: ① 秒(0-59) ② 分钟(0-59) ③ 小时(0-23) ④ 天(月的…

    Linux 2023年6月7日
    071
  • 【计算题】考研数据结构计算题型整理

    题型1:递归程序,一般使用公式进行递推 int fact(int n){ if(n 本题是求阶乘的递归代码,即n * (n-1) * …. * 1。每次递归调用 fac…

    Linux 2023年6月13日
    0115
  • 我的第一个程序

    新建一个java文件 文件后缀名为.java Hello.java 【注意点】系统可能没有显示文件后缀名,我们需要手动代开 编写代码 public class Hello{    …

    Linux 2023年6月7日
    070
  • centos7 安装MariaDB 10.6

    镜像下载、域名解析、时间同步请点击阿里云开源镜像站 背景 centos7使用yum install mariadb-server命令安装的默认版本是5.5的,这是因为系统默认源只有…

    Linux 2023年5月27日
    0375
  • k8s-简介

    Kubenetes是一个针对容器应用,进行自动部署,弹性伸缩和管理的开源系统,K8s 作为缩写的结果来自计算”K”和”s”之间的八个…

    Linux 2023年6月13日
    088
  • 前几天看到微信多开方式

    @echo offset wechatpath=WeChat.exeecho. echo. echo —————&#82…

    Linux 2023年6月14日
    0100
  • TCP/IP方法安装打印机

    在计算机安装打印机驱动和添加打印机 (TCP/IP 方法 ) 一:打印机的型号和驱动。 1.1 :如何知道自己的打印机是什么品牌和型号?: 通过观察打印机表面的logo 或者其他文…

    Linux 2023年6月13日
    0126
  • 微服务架构项目搭建过程中的Mysql安装和相关问题

    搭建微服务架构的过程中需要使用Mysql数据库,Mysql数据库搭建着实不是一个容易的事情,会碰到各种各样的问题,如果没有一个安装数据库的思路真的很难把数据库安装好,并且掉入到安装…

    Linux 2023年6月14日
    0112
  • Linux—进程管理

    Linux 进程管理 1、进程管理介绍 1.1 什么是进程? 进程(Process)是计算机中的 程序关于某 数据集合上的一次 运行活动,是系统进行 资源分配和调度的 基本单位,是…

    Linux 2023年6月7日
    095
  • 5.4 Linux Vim基本操作

    《Vim三种工作模式》一节给大家详细介绍了 Vim 的 3 种工作模式,本节来学习如何使用 Vim 编辑文件。 首先学习如何使用 Vim 打开文件。 Vim 打开文件 使用 Vim…

    Linux 2023年6月7日
    0102
  • linux常用命令(持续更新中…)

    查看所有开机启动服务:systemctl list-unit-files # 按Enter翻页 查看所有开机启动服务:systemctl list-unit-files | gre…

    Linux 2023年6月7日
    084
  • Linux命令之find、grep、echo、tar、whoami、uname

    1. whoami–查看当前登录的用户名 book@100ask:~/linux$ whoami book 2. echo–打印命令,配合’&g…

    Linux 2023年6月6日
    0102
  • Linux上安装并启动tomcat

    1、下载tomcat安装包 官网链接:https://archive.apache.org/dist/tomcat/tomcat-7/v7.0.57/bin/ 2、将tomcat上…

    Linux 2023年6月6日
    0120
  • Shell第四章《正则表达式》

    1.1、名词解释 正则表达式(regular expression, RE)是一种字符模式,用于在查找过程中匹配指定的字符。在大多数程序里,正则表达式都被置于两个正斜杠之间;例如/…

    Linux 2023年6月6日
    0108
  • Linux高可用之Keepalived

    注意: 各节点时间必须同步 确保各节点的用于集群服务的接口支持MULTICAST通信(组播); 安装 从CentOS 6.4开始keepalived随系统base仓库提供,可以使用…

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