css动画:文字向上移动并逐渐消失 点击按钮显示+1上移淡出

简介: css动画:文字向上移动并逐渐消失 点击按钮显示+1上移淡出

背景


今天有个同学请教我一个css效果怎样实现,据他描述是点击后一个文字上浮然后慢慢消失。就下面这样子:

image.png

我第一时间想到的是css动画,以前在w3cschool粗略过了一遍css教程,记得有这样的功能。其实学习就是这样,有些知识只需要了解下,没必要完全掌握,知道有这个东西,然后在要用到的时候启动cv大法。

解决


于是我迅速上w3cschool找了下,很快找到相关内容,是用最基本的from to语法,就是从一个样式到另外一个样式,浏览器会自动在规定时间内做过渡处理。

@keyframes mymove {
  from {样式1}
  to {样式2}
}

于是捣鼓了下很快实现了。

代码


<!DOCTYPE html>
<html>
<head>
<style> 
#myDIV {
  color:red;
  height: 200px;
  animation: mymove 1s;
  position:absolute;
  opacity:0;
}
@keyframes mymove {
  from {top:100px;opacity:100;}
  to {top:50px;opacity:0;}
}
</style>
</head>
<body>
<div id="myDIV">+1</div>
</body>
</html>

效果如下


image.jpeg

拓展


但是我发现个问题,人家是点击页面里的某个按钮,而我这个是页面刷新进入后才发生效果。这可不行。于是我把关键代码放到一个样式类plus1中,需要加1的时候就设置好样式,执行完就去移除样式。说干就干,我引入jQuery,放一个div,然后让它接收点击事件,执行下面代码:$("#myDIV").addClass("plus1").removeClass("plus1");然而并没有反应,我猜测是刚设置样式就立刻移除了,所以并不会产生效果。那么得加个延时才行。

$(".toupiao").click(function(){
  $("#myDIV").addClass("plus1");
  setTimeout( function(){$("#myDIV").removeClass("plus1");}, 1000);
});

注意后面的延时时间1000ms,和动画完成的时间要一致,意思在动画执行完成后再移除样式。完整代码如下:

<!DOCTYPE html>
<html>
<head>
<script src="https://cdn.staticfile.org/jquery/1.11.2/jquery.min.js"></script>
<style>
#myDIV {
  color:red;
  position:absolute;
  opacity:0;
}
.plus1{ animation: mymove 1s;}
.toupiao{margin-top:150px; border:1px solid red; padding:10px; width:100px; text-align:center;}
@keyframes mymove {
  from {top:100px;opacity:100;}
  to {top:0px;opacity:0;}
}
</style>
</head>
<body>
<div id="myDIV">+1</div>
<div class="toupiao">点赞</div>
</body>
<script>
$(".toupiao").click(function(){
  $("#myDIV").addClass("plus1");
  setTimeout( function(){$("#myDIV").removeClass("plus1");}, 1000);
});
</script>
</html>

再次测试效果


image.jpeg

测试结果可以,不过点快好像还有点小bug,感觉这种实现方式还是有点怪,应该有完美的方式达到动画完成就执行另外一个动作,用addClass和click方法的回调函数测试了很久发现并没有效果。

其实关于css动画有一个叫做Animate.css(官网:animate.style/)的封装了大量的动画,直接调用即可,没必要重复搞车轮子。以上只当的探索学习了解css。

目录
相关文章
|
1月前
|
机器学习/深度学习 前端开发 JavaScript
|
23天前
|
前端开发 搜索推荐 UED
实现 CSS 动画效果的兼容性
【10月更文挑战第16天】实现 CSS 动画效果的兼容性需要对不同浏览器的特性有深入的了解,并采取适当的策略和方法。通过不断的实践和优化,你可以在各种浏览器上创造出流畅、美观且兼容的动画效果,为用户带来更好的体验。在实际开发中,要密切关注浏览器的发展动态,及时掌握最新的兼容性技巧和解决方案,以确保你的动画设计能够在广泛的用户群体中得到良好的呈现。
|
5天前
|
数据采集 存储 前端开发
Puppeteer教程:使用CSS选择器点击和爬取动态数据
本文介绍如何使用Puppeteer结合CSS选择器爬取动态网页数据,以贝壳网的二手房价格为例,通过代理IP提高爬虫成功率。文章详细讲解了Puppeteer的安装和配置、代码实现及数据趋势分析,帮助读者掌握动态网页爬取技术。
Puppeteer教程:使用CSS选择器点击和爬取动态数据
|
2天前
|
Web App开发 前端开发 JavaScript
如何在不牺牲动画效果的前提下,优化 CSS3 动画的性能?
如何在不牺牲动画效果的前提下,优化 CSS3 动画的性能?
7 1
|
28天前
|
前端开发 JavaScript API
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
本文通过构建一个 3D 翻卡动画深入探讨了 CSS Houdini 的强大功能,展示了如何通过 Worklets、自定义属性、Paint API 等扩展 CSS 的能力,实现高度灵活的动画效果。文章首先介绍了 Houdini 的核心概念与 API,并通过构建一个动态星空背景、圆形进度条以及交互式 3D 翻卡动画的实际示例,展示了如何利用 CSS Houdini 赋予网页设计更多创造力。最后,还演示了如何将这种 3D 翻卡效果集成到公司网站中,提升用户体验。CSS Houdini 的创新能力为网页设计带来了前所未有的灵活性,推动了前端开发迈向新的高度。
24 0
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
|
2月前
|
前端开发
前端基础(五)_CSS文本文字属性、背景颜色属性
本文详细介绍了CSS中关于文本和背景颜色的样式属性。包括字体大小、字体族、字体加粗、字体样式、文本行高、`font`属性、文本颜色、文本对齐方式、文本装饰线、首行缩进等文本属性,以及背景颜色、背景图片、背景重复、背景位置等背景属性。文章通过示例代码展示了这些属性的具体应用和效果。
30 3
前端基础(五)_CSS文本文字属性、背景颜色属性
|
2月前
|
JavaScript 前端开发
JS配合CSS3实现动画和拖动小星星小Demo
本文通过代码示例展示了如何使用JavaScript和CSS3实现动画效果和拖动小星星的交互效果,包括文字掉落动画和鼠标拖动产生小星星动画的实现方法。
44 0
JS配合CSS3实现动画和拖动小星星小Demo
|
1月前
|
前端开发
CSS 动画介绍及语法
CSS 动画介绍及语法
27 0
|
1月前
|
Web App开发 前端开发 iOS开发

热门文章

最新文章