热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

只使用CSS在几秒钟内改变颜色-ChangecolorforsomesecondsusingonlyCSS

IsitpossibletochangethecolorofadivonhoverforXseconds,thenreturntoitsoriginalcolo

Is it possible to change the color of a div on hover for X seconds, then return to its original color using only CSS?

是否可以将div的颜色在悬停状态下更改X秒,然后仅使用CSS返回到原来的颜色?

I do not want any fade ins or outs between the color. For example, if I want to change the color of the div to yellow for 1 second on hover, it must remain yellow for 1 second, then immediately return to the original color.

我不希望在颜色之间有任何褪色。例如,如果我想在鼠标悬停1秒时将div的颜色更改为黄色,那么它必须保持黄色1秒,然后立即返回原始颜色。

This (http://jsfiddle.net/hZ49y/1/) is what I have so far. It works as I described above, but I feel that this way of using animation is not intuitive and hard to understand. Should I stick to using Javascript for this purpose? What are some alternatives?

这个(http://jsfiddle.net/hZ49y/1/)是我目前所拥有的。它就像我上面描述的那样工作,但是我觉得这种使用动画的方式不是直观的,很难理解。我应该坚持使用Javascript实现这个目的吗?有哪些选择呢?

3 个解决方案

#1


3  

It is possible, but requires some math!

这是可能的,但需要一些数学知识!

Here is the Fiddle

这是小提琴

You must use another parameter of animation: animation-iteration-count as 1

您必须使用动画的另一个参数:动画-迭代-计数为1

div:hover {
    animation: myfirst 2s 1;
}

@keyframes myfirst
{
    0%      {background:red;}
    25%     {background:yellow;}
    75%     {background:yellow;}
    100%    {background:red;}
}

This is going to perform a 4s animation with the following "key-frames":

这将使用以下“关键帧”来执行4s动画:

0s > red
1s > yellow (stays 2 seconds here)
3s > yellow
4s > red

>红色1s >黄色(在这里停留2秒)3s >黄色4s >红色

The only problem is that the animation stops on mouse out. But you can use Javascript to activate the animation (by toggle a class), so the animation doesn't stops on mouse out.

唯一的问题是动画停止在鼠标上。但是您可以使用Javascript来激活动画(通过切换类),因此动画不会停止在鼠标外。


Update:

更新:

Here is a Fiddle with js to control css animation.

这里有一个小提琴与js控制css动画。

#2


1  

CSS animations don't explicitly allow instantaneous, non-transitioning changes from frame-to-frame, but you can achieve the effect in practice by setting keyframes so close to each other that it's practically impossible for an intervening frame to come in (forked jsFiddle):

CSS动画并没有明确地允许从帧到帧的即时、非转换更改,但是你可以通过设置关键帧来达到实际效果,这些关键帧之间的距离如此之近,以至于几乎不可能插入一个帧(叉形jsFiddle):

@keyframes myfirst
{
0%      {background:yellow;}
99.999% {background:yellow;}
100%    {background:red;}
}

#3


0  

I got this with animation. It works exactly as you asked, the only problem is that after page load the box is yellow for a second.

我是用动画制作的。它完全按照您的要求工作,唯一的问题是在页面加载之后,该框暂时为黄色。

http://jsfiddle.net/4TcMP/1/

http://jsfiddle.net/4TcMP/1/


推荐阅读
  • ECharts图表绘制函数集
    本文档提供了使用ECharts库创建柱状图、饼图和双折线图的JavaScript函数。每个函数都详细列出了参数说明,并通过示例展示了如何调用这些函数以生成不同类型的图表。 ... [详细]
  • 本文介绍了一种算法,用于在一个给定的二叉树中找到一个节点,该节点的子树包含最大数量的值小于该节点的节点。如果存在多个符合条件的节点,可以选择任意一个。 ... [详细]
  • 本文详细介绍如何在Spring Boot项目中集成和使用JPA,涵盖JPA的基本概念、Spring Data JPA的功能以及具体的操作步骤,帮助开发者快速掌握这一强大的持久化技术。 ... [详细]
  • 本文探讨了在Node.js环境中如何有效地捕获标准输出(stdout)的内容,并将其存储到变量中。通过具体的示例和解决方案,帮助开发者解决常见的输出捕获问题。 ... [详细]
  • 本文深入探讨了JLine库中的ConsoleReader.drawBuffer()方法的使用场景和具体实现,通过多个实际代码示例,帮助开发者更好地理解和应用此方法。 ... [详细]
  • Activity跳转动画 无缝衔接
    Activity跳转动画 无缝衔接 ... [详细]
  • 深入解析Android Activity生命周期
    本文详细探讨了Android中Activity的生命周期,通过实例代码和详细的步骤说明,帮助开发者更好地理解和掌握Activity各个阶段的行为。 ... [详细]
  • 本文探讨了如何从文本文件中正确读取一行数据,并将其赋值给C语言中的变量,同时解决了常见的错误和注意事项。 ... [详细]
  • 拖拉切割直线 ... [详细]
  • 本文详细介绍了Java中的泛型概念及其在类、接口和方法中的应用。泛型是自JDK 1.5以来引入的一项重要特性,旨在增强代码的灵活性和安全性。 ... [详细]
  • 设计模式系列-原型模式
    一、上篇回顾上篇创建者模式中,我们主要讲述了创建者的几类实现方案,和创建者模式的应用的场景和特点,创建者模式适合创建复杂的对象,并且这些对象的每个组成部分的详细创建步骤可以是动态的变化的,但 ... [详细]
  • 本文介绍了一个基础算法题目,旨在通过求解特定范围内所有数字的阶乘之和来提升编程技能。重点在于理解和实现双重循环结构。 ... [详细]
  • 本文详细探讨了在 Xamarin.Forms 中使用 AbsoluteLayout 进行精确布局的方法,以及如何利用 Device.StartTimer 实现定时任务。通过具体的代码示例,帮助开发者更好地理解和应用这些功能。 ... [详细]
  • 抽象工厂模式 c++
    抽象工厂模式包含如下角色:AbstractFactory:抽象工厂ConcreteFactory:具体工厂AbstractProduct:抽象产品Product:具体产品https ... [详细]
  • 【Java数据结构和算法】008栈
    目录0、警醒自己一、栈的应用场景和介绍1、栈的应用场景一个实际的场景:我的思考:2、栈的介绍入栈演示图:出栈演示图 ... [详细]
author-avatar
liuc
这个家伙很懒,什么也没留下!
Tags | 热门标签
RankList | 热门文章
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有