CSS3在我们网页设计中是最关键的一环,为什么这么说呢?我们在浏览别人的网站时,经常会看到特别好看的动画效果,比如一个按钮啊,一个图片啊,每次看到都能够让人有种赏心悦目的感觉,这就使网站更具有吸引力和互动性。接下来我就用css3的一些属性来完成点击按钮气泡动画特效。

先看gif效果图:

是不是很酷炫,哈哈,别着急,干货马上献上。

HTML代码:

Clickme!

关键CSS代码:

body {

font-size: 16px;

font-family: 'Helvetica', 'Arial', sans-serif;

text-align: center;

background-color: #f8faff;

}

.bubbly-button {

font-family: 'Helvetica', 'Arial', sans-serif;

display: inline-block;

font-size: 1em;

padding: 1em 2em;

margin-top: 100px;

margin-bottom: 60px;

-webkit-appearance: none;

appearance: none;

background-color: #ff0081;

color: #fff;

border-radius: 4px;

border: none;

cursor: pointer;

position: relative;

transition: transform ease-in 0.1s, box-shadow ease-in 0.25s;

box-shadow: 0 2px 25px rgba(255, 0, 130, 0.5);

}

.bubbly-button:focus {

outline: 0;

}

.bubbly-button:before, .bubbly-button:after {

position: absolute;

content: '';

display: block;

width: 140%;

height: 100%;

left: -20%;

z-index: -1000;

transition: all ease-in-out 0.5s;

background-repeat: no-repeat;

}

.bubbly-button:before {

display: none;

top: -75%;

background-image: radial-gradient(circle, #ff0081 20%, transparent 20%), radial-gradient(circle, transparent 20%, #ff0081 20%, transparent 30%), radial-gradient(circle, #ff0081 20%, transparent 20%), radial-gradient(circle, #ff0081 20%, transparent 20%), radial-gradient(circle, transparent 10%, #ff0081 15%, transparent 20%), radial-gradient(circle, #ff0081 20%, transparent 20%), radial-gradient(circle, #ff0081 20%, transparent 20%), radial-gradient(circle, #ff0081 20%, transparent 20%), radial-gradient(circle, #ff0081 20%, transparent 20%);

background-size: 10% 10%, 20% 20%, 15% 15%, 20% 20%, 18% 18%, 10% 10%, 15% 15%, 10% 10%, 18% 18%;

}

.bubbly-button:after {

display: none;

bottom: -75%;

background-image: radial-gradient(circle, #ff0081 20%, transparent 20%), radial-gradient(circle, #ff0081 20%, transparent 20%), radial-gradient(circle, transparent 10%, #ff0081 15%, transparent 20%), radial-gradient(circle, #ff0081 20%, transparent 20%), radial-gradient(circle, #ff0081 20%, transparent 20%), radial-gradient(circle, #ff0081 20%, transparent 20%), radial-gradient(circle, #ff0081 20%, transparent 20%);

background-size: 15% 15%, 20% 20%, 18% 18%, 20% 20%, 15% 15%, 10% 10%, 20% 20%;

}

.bubbly-button:active {

transform: scale(0.9);

background-color: #e60074;

box-shadow: 0 2px 25px rgba(255, 0, 130, 0.2);

}

.bubbly-button.animate:before {

display: block;

animation: topBubbles ease-in-out 0.75s forwards;

}

.bubbly-button.animate:after {

display: block;

animation: bottomBubbles ease-in-out 0.75s forwards;

}

@keyframes topBubbles {

0% {

background-position: 5% 90%, 10% 90%, 10% 90%, 15% 90%, 25% 90%, 25% 90%, 40% 90%, 55% 90%, 70% 90%;

}

50% {

background-position: 0% 80%, 0% 20%, 10% 40%, 20% 0%, 30% 30%, 22% 50%, 50% 50%, 65% 20%, 90% 30%;

}

100% {

background-position: 0% 70%, 0% 10%, 10% 30%, 20% -10%, 30% 20%, 22% 40%, 50% 40%, 65% 10%, 90% 20%;

background-size: 0% 0%, 0% 0%, 0% 0%, 0% 0%, 0% 0%, 0% 0%;

}

}

@keyframes bottomBubbles {

0% {

background-position: 10% -10%, 30% 10%, 55% -10%, 70% -10%, 85% -10%, 70% -10%, 70% 0%;

}

50% {

background-position: 0% 80%, 20% 80%, 45% 60%, 60% 100%, 75% 70%, 95% 60%, 105% 0%;

}

100% {

background-position: 0% 90%, 20% 90%, 45% 70%, 60% 110%, 75% 80%, 95% 70%, 110% 10%;

background-size: 0% 0%, 0% 0%, 0% 0%, 0% 0%, 0% 0%, 0% 0%;

}

}

当然需要一点javascript代码:

var animateButton = function(e) {

e.preventDefault;

//reset animation

e.target.classList.remove('animate');

e.target.classList.add('animate');

setTimeout(function(){

e.target.classList.remove('animate');

},700);

};

var classname = document.getElementsByClassName("bubbly-button");

for (var i = 0; i < classname.length; i++) {

classname[i].addEventListener('click', animateButton, false);

}

以上代码实现不难,关键都是在CSS3这一块儿,所以看不懂一些属性的童鞋下去好好补补CSS3这一块儿的知识,相信你也能玩转CSS3动画特效,有了它,我们的网页无疑是锦上添花,画龙点睛呐!!哈哈

结束语:

代码这种东西不仅要学还要动手去敲的,时间长了就会显得生疏,好了,大家可以下去试试了。

html 气泡动画效果,css3实现好看的气泡按钮动画特效相关推荐

  1. css3加载中动画效果,CSS3实现加载中的动画效果

    Loading 的菊花图形组合的不太好,基本上实现这个功能了 动画解析 这个动画用到的 CSS3 特性: transform 主要使用 transform 属性的 rotate,将线条组合成 Load ...

  2. Python之数据分析(动画效果、animation模块、气泡动画)

    文章目录 1.动画效果 2.原理分析 3.动画源码 本篇文章其实与数据分析没有太大关系,因为是涉及到数据分析的数据可视化方面的内容,因此也必须要学习.主要内容是如何制作一个气泡动画效果,当然也是使用m ...

  3. css动画帧动画效果,CSS3动画之逐帧动画

    什么是逐帧动画 要了解 CSS3 逐帧动画,首先要明确什么是逐帧动画. 看一下维基百科中的定义: 定格动画,又名逐帧动画,是一种动画技术,其原理即将每帧不同的图像连续播放,从而产生动画效果. 简而言之 ...

  4. css3 线条出现动画效果,CSS3实现的线条波浪动画效果

    HTML结构 该css3线条波浪动画效果的HTML结构如下: CSS样式 然后通过下面的CSS代码来制作线条波浪动画效果. @keyframes move_wave { 0% { transform: ...

  5. html ie动画效果,css3强大的动画效果animate使用说明及浏览器兼容介绍

    好久没更新blog,上次发文(11月8日)到现在刚好一个月,期间项目上的东西比较多,一时觉得时间比较紧,没来得及更新.这个星期总算是告一段落,补上几篇技术性的文章.好吧,第一篇是关于css3动画的使用 ...

  6. html中如何设置动画效果,css3如何设置动画?

    首先我们来了解一下css3实现简单动画需要用到的属性:animation属性,@keyframes"规则". animation属性和@keyframes"规则" ...

  7. html如何添加加载动画效果,CSS3创建加载动画效果

    加载动画在网页设计中是很常见的.用户们都希望网页加载又快又流畅而不是盯着屏幕苦等,而加载动画能够在内容加载完成前给用户视觉反馈,从而能够吸引用户而不让他们直接放弃继续浏览你的网站. 创建加载效果所需的 ...

  8. css加载更多动画效果,css3实现loading动画效果

    通过css3动画实现三种loading加载动画 效果1:通过css3的border-radius与transform的rotate()实现 效果2:通过css3动画animation的animatio ...

  9. html5 云朵飘动效果,CSS3如何实现飘动的云朵动画 CSS3实现飘动的云朵动画代码

    css3如何实现飘动的云朵动画?本篇文章小编给大家分享一下CSS3实现飘动的云朵动画代码,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看. 运行效果 ht ...

最新文章

  1. 全国默哀 网站首页都要变成灰色的简单解决办法
  2. JVM致命错误日志(hs_err_pid.log)分析
  3. macbook pro 识别不到外接显示器
  4. [USACO1.1]坏掉的项链Broken Necklace
  5. centos7 安装 python3.5
  6. JS检测浏览器是否最大化
  7. php多级查询,MySQL 多级查询
  8. fedora安装java
  9. PHP佳音高清图片上传下载源码
  10. 校园二手交易系统平台
  11. 格物致知诚意正心修身齐家治国平天下是什么意思【转载】
  12. outlook设置263邮件服务器,如何设置Outlook邮件客户端收发邮件?
  13. FLV player 在线播放器【www.lantianye3.top】
  14. 计算机毕业设计springboot+vue基本微信小程序的社区疫情防控系统
  15. 关于Hadoop在java客户端进行下载时的异常java.io.FileNotFoundException: Hadoop home directory is no existed的解决办法
  16. 移动互联网时代 移动生活的碎片化解决方案
  17. Android 自定义圆角+阴影布局
  18. 介绍Kadence Elements元素模板:按您的方式设计网站
  19. Ray 分布式简单教程(1)
  20. 什么是CSS,有什么作用?\nCSS(Cascading Style Sheet):层叠样式表语言。\nCSS的作用是:\n修饰HTM

热门文章

  1. 超棒的NFS文档-来自chinaunix,讲到的NFS的几乎所有方面,包括版本、参数设定等...
  2. python常用常用函数
  3. MATLAB-Simulink基础知识
  4. 学分,选够了吗? Alpha冲刺阶段
  5. 【书签】web自动化测试之selenium
  6. 动物实验可用计算机模拟,《动物实验类试题》.doc
  7. 从零开始搭建SpringBoot的Demo
  8. 一些比赛的题解(共32场)
  9. VisualDrag低代码拖拽模板
  10. 蓝光发展两度出售优质资产,加速资金回笼背后,只剩“无奈”二字