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。

目录
相关文章
|
4月前
|
自然语言处理 前端开发 JavaScript
用 通义灵码 一键生成“水波纹按钮”,连 CSS 动画都不用自己写了!
通义灵码是一款智能编程辅助工具,它可以根据自然语言指令自动生成高质量的代码。例如,只需输入“生成一个按钮,点击时带水波纹动画,模拟 Material Ripple 效果”,它就能生成具备完整交互逻辑、CSS 动画和良好性能的按钮组件。不仅如此,它还支持拓展功能,如长按触发提示、添加图标等,并能自动优化样式适配不同场景。通过通义灵码,开发者可以大幅提升效率,专注于创意实现,而不必纠结于繁琐的代码细节。
|
9月前
|
前端开发 JavaScript
CSS 过渡和动画
CSS过渡和动画是用于为网页元素添加动态效果的两种重要技术
432 143
|
22天前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
Animation属性 css3为Animation动画提供的几个属性如下: 属性名 属性值 animation-name 指定动画名称,该属性指定一个已有的关键帧定义。 animation-duration 指定动画持续时间。 animation-timing-funtion 指定动画变化速度。 animation-delay 指定动画延迟多长时间才开始执行。 animation-iteration-count 指定动画的循环执行次数。 animation:这是一个复合属性。
58 0
|
4月前
|
前端开发
文字显示在div 最下面,css怎么写
文字显示在div 最下面,css怎么写
304 0
|
10月前
css3 svg制作404页面动画效果HTML源码
css3 svg制作404页面动画效果HTML源码
165 34
|
10月前
jQuery+CSS3实现404背景游戏动画源码
jQuery+CSS3实现404背景游戏动画源码
138 22
|
11月前
|
JavaScript 前端开发
jQuery和CSS3滑动展开菜单按钮插件
这是一款jQuery和CSS3滑动展开菜单按钮插件。该滑动展开菜单按钮在用户点击主菜单按钮之后,子菜单以滑动的方式依次展开
144 21
|
11月前
|
Web App开发 移动开发 JavaScript
纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码
这是一款基于纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码。画面中左下角是一个圆锥形礼炮卡通效果,呈现出节日庆祝时礼花爆破、五彩纸屑纷飞的动画特效。整体动画效果采用纯css3+svg实现,没有引入任何外部图形或js脚本元素。建议使用支持HTML5与css3效果较好的火狐(Firefox)或谷歌(Chrome)等浏览器预览本源码。
204 6
|
5月前
|
存储 自然语言处理 前端开发
抖音快手小红书虚拟评论截图生成器,模拟对话制作工具,html+js+css
这是一款纯前端实现的多平台虚拟评论生成器,支持抖音、快手、小红书风格,适用于产品演示与UI设计。采用Vanilla JS与Flexbox布局,利用IndexedDB存储数据,CSS Variables切换主题。
|
5月前
|
存储 前端开发 安全
病历单生成器在线制作,病历单生成器app,HTML+CSS+JS恶搞工具
本项目为医疗病历模拟生成器,旨在为医学教学和软件开发测试提供数据支持,严格遵守《医疗机构病历管理规定》。

热门文章

最新文章

  • 1
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
  • 4
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
  • 5
    React 中如何安装与使用 Tailwind CSS
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
  • 9
    (CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
  • 下一篇
    开通oss服务