CSS3实现伪类hover离开时平滑过渡效果示例


Posted in HTML / CSS onAugust 10, 2017

由于hover伪类添加的动画效果,仅当鼠标放在元素上时会被触发,而当鼠标离开时,效果会中断,会显得很生硬。

大多数人的想法都是使用js的onmouseover和onmouseleave事件来实现动画效果。其实不必这么麻烦,CSS3便可以帮你解决这些问题。

<!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>离开时效果生硬</title>
        <style type="text/css">
            div{
                width: 100px;
                height: 100px;
                border:1px solid;
    
                margin:0px auto;
                margin-top: 200px;
            }
            div:hover{
                transform: scale(2);
                transition: all 1s linear;
            }
        </style>
    </head>
    <body>
        <div></div>
    </body>
    </html>

由于div元素只有在:hover伪类触发的时候,效果才能加到div元素上。

当鼠标离开div元素的时候,:hover伪类将不再生效,瞬间丢掉hover里写的动画效果。

此时,我们应当在原本元素上再写一个一模一样的transition效果,将离开断掉的动画效果续接上。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>简单解决</title>
    <style type="text/css">
        div{
            width: 100px;
            height: 100px;
            border:1px solid;

            margin:0px auto;
            margin-top: 200px;

            /* 在原本元素上再加一个transition */
            transition: all 1s linear;
        }
        div:hover{
            transform: scale(2);
            transition: all 1s linear;
        }
    </style>
</head>
<body>
    <div></div>
</body>
</html>

此时,不管鼠标在什么时候离开元素,都会原样返回。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
简单介绍CSS3中Media Query的使用
Jul 07 HTML / CSS
基于Jquery和Css3代码制作可以缩放的搜索框
Nov 19 HTML / CSS
结合 CSS3 transition transform 实现简单的跑马灯效果的示例
Feb 07 HTML / CSS
animation和transition的区别
Oct 12 HTML / CSS
Html5游戏开发之乒乓Ping Pong游戏示例(二)
Jan 21 HTML / CSS
HTML5之SVG 2D入门13—svg对决canvas及长处和适用场景分析
Jan 30 HTML / CSS
推荐10个HTML5响应式框架
Feb 25 HTML / CSS
Html5新增标签有哪些
Apr 13 HTML / CSS
HTML5地理定位_动力节点Java学院整理
Jul 12 HTML / CSS
高清屏下canvas重置尺寸引发的问题的解决
Oct 14 HTML / CSS
HTML5 drag和drop具体使用详解
Jan 18 HTML / CSS
html+css合并表格边框的示例代码
Mar 31 HTML / CSS
使用CSS3来代替JS实现交互
Aug 10 #HTML / CSS
css3实现wifi信号逐渐增强效果实例
Aug 09 #HTML / CSS
CSS3 实现弹幕的示例代码
Aug 07 #HTML / CSS
浅谈CSS3特性查询(Feature Query: @supports)功能简介
Jul 31 #HTML / CSS
css3旋转木马_动力节点Java学院整理
Jul 12 #HTML / CSS
css3边框_动力节点Java学院整理
Jul 11 #HTML / CSS
使用 css3 实现圆形进度条的示例
Jul 05 #HTML / CSS
You might like
ThinkPHP使用PHPExcel实现Excel数据导入导出完整实例
2014/07/22 PHP
基于PHP的简单采集数据入库程序【续篇】
2014/07/30 PHP
PHP如何使用cURL实现Get和Post请求
2020/07/11 PHP
利用location.hash实现跨域iframe自适应
2010/05/04 Javascript
js对象的构造和继承实现代码
2010/12/05 Javascript
如何在一个页面显示多个百度地图
2013/04/07 Javascript
javascript unicode与GBK2312(中文)编码转换方法
2013/11/14 Javascript
JavaScript sub方法入门实例(把字符串显示为下标)
2014/10/17 Javascript
在父页面得到zTree已选中的节点的方法
2015/02/12 Javascript
js控制网页前进和后退的方法
2015/06/08 Javascript
JS实现双击屏幕滚动效果代码
2015/10/28 Javascript
JS鼠标拖拽实例分析
2015/11/23 Javascript
jQuery实现模仿微博下拉滚动条加载数据效果
2015/12/25 Javascript
AngularJS过滤器filter用法分析
2016/12/11 Javascript
Vue自定义图片懒加载指令v-lazyload详解
2020/12/31 Javascript
JS仿淘宝搜索框用户输入事件的实现
2017/06/19 Javascript
JS中call和apply函数用法实例分析
2018/06/20 Javascript
Vue 组件封装 并使用 NPM 发布的教程
2018/09/30 Javascript
vue h5移动端禁止缩放代码
2019/10/28 Javascript
AngularJS动态生成select下拉框的方法实例
2019/11/17 Javascript
vue+axios全局添加请求头和参数操作
2020/07/24 Javascript
30分钟搭建Python的Flask框架并在上面编写第一个应用
2015/03/30 Python
numpy.linspace 生成等差数组的方法
2018/07/02 Python
Python的条件表达式和lambda表达式实例
2019/01/31 Python
使用python自动追踪你的快递(物流推送邮箱)
2020/03/17 Python
html5表单及新增的改良元素详解
2016/06/07 HTML / CSS
西班牙Polo衫品牌:Polo Club
2020/08/09 全球购物
2014学年自我鉴定
2014/02/23 职场文书
党的群众路线教育实践活动学习心得体会
2014/03/03 职场文书
《画家乡》教学反思
2014/04/22 职场文书
祖国在我心中演讲稿200字
2014/08/28 职场文书
运动会广播稿150字(9篇)
2014/09/20 职场文书
战马观后感
2015/06/08 职场文书
务工证明怎么写
2015/06/18 职场文书
python 常用的异步框架汇总整理
2021/06/18 Python
vue css 相对路径导入问题级踩坑记录
2022/06/05 Vue.js