CSS实现隐藏搜索框功能(动画正反向序列)


Posted in HTML / CSS onJuly 21, 2021

顶部菜单栏中放置搜索框是一个常见的场景,但如果搜索功能使用的不那么频繁,同时菜单栏中内容本来就比较拥挤,再放一个完整的搜索框在那就显得不那么美观。因此也有一个挺常见的做法是,只放一个搜索图标,需要时再显示整个搜索框,如下图所示:

CSS实现隐藏搜索框功能(动画正反向序列)

实现思路

起始状态时搜索框没有显示,鼠标移入后从右侧滑入,因此不能使用搜索框自身的 hidden 或透明度属性,需要使用父元素的 overflow: hidden 将其隐藏,并把输入框移动到父元素的显示范围以外,需要时再移动回来。

CSS 中有 transitionanimation 两种方式来实现动画效果,由于这里只有搜索框位置移动、图标透明度改变两个简单效果,用 transition 就足够了。

这两个动画本身实现很简单,但有一些小细节:

  • 两个动画不是同时进行,而是有先后,需要使用 transition-delay 实现两个效果的序列
  • 显示、隐藏两个过程好像完全一样,但仔细看会发现动画的顺序有不同:显示时图标先消失、搜索框后移入;隐藏时搜索框先移出、图标后出现。因此需要单独设置。

代码实现

完整的样式表附在文末,不想看具体思路的可以跳过本节直接去复制。

基础样式

先普普通通的写一下基础样式,这里用的图标是 material design icon

<div class="search">
  <input class="bar" placeholder="请输入内容" />
  <span class="material-icons icon">search</span>
</div>
.icon {
  width: 24px;
  height: 24px;
}

.bar {
  height: 26px;
  width: 200px;
  padding: 1px 9px;
  border: #fff 1px solid;
  border-radius: 3px;
  background-color: transparent;
  color: #fff;
}
::placeholder {
  color: #ccc;	/* 修改input中placeholder的颜色*/
}

.search {
  height: 30px;
  display: flex;
  align-items: center;
}

CSS实现隐藏搜索框功能(动画正反向序列)

隐藏搜索框

移动搜索框位置的方法有很多,比如可以使用 absolute 或者 relative 定位。

  • 如果将搜索框设为 absolute 定位(position: absolute),搜索框会从输入流中抽出,通俗的说就是父元素在渲染时会当它不存在,这样父元素的宽度、搜索图标的位置都需要额外指定。
  • 相比之下,relative 定位(position: relative)只是简单地移动元素的位置,对其他元素没有任何影响,在此处使用更加简单一些。

还有一种更直接的方法:transform 属性。通过这个属性,可以实现对元素的平移、旋转、缩放等变形操作,同时对其他元素不产生影响。在这里使用的 translateX() 属性就是将元素沿X轴(横向)平移指定距离。单从平移来说,各方面效果和使用 relative 定位没有明显区别。

PS: transition, transform, translate 这几个词不会只有我一直分不清吧555

.search {
  overflow: hidden;
}
.bar {
  transform: translateX(224px);
  /* 
    上一句也可以替换为下面两句,效果相同
    position: relative;
    left: 224px;
  */
}

动画序列

动画通过 transition 属性实现。transition 是 transition-property,transition-duration,transition-timing-function 和 transition-delay 四个属性的简写(类比border: red 1px solid;),四个属性分别指定了过渡动画的属性、持续时间、时间曲线、延迟时间。

  • 属性即要应用过渡动画的属性
  • 时间曲线是动画的速度变化,比如开始慢、中间快、结束慢,可以比匀速运动更好看更平滑
  • 延迟时间即达到触发条件后延迟一段时间再触发动画,可以用来实现多个动画有先后顺序地执行

transition 属性本质上是小学电脑课学过的 flash 补间动画,指定一个属性的起止两个状态,自动补全中间的过渡动画。元素本来的属性是起始状态,鼠标移上后的动画,自然元素的 :hover 伪类属性是终止状态。

.icon {
  opacity: 1;
  transition: opacity 0.3s ease; /* delay 属性默认值为0 */
}
.search:hover .icon {
  opacity: 0;
}

.bar {
  transform: translateX(224px);
  transition: transform 0.3s ease-in-out 0.3s;
}
.search:hover .bar {
  transform: translateX(24px);
}

逆向序列

这样能够基本实现想要的动画效果了,但是在隐藏搜索框的时候也是图标先出现,搜索框后滑出,不够美观。解决方案也很简单,为 hover 伪类单独设置不同的 delay 属性即可。

有一点需要注意一下,hover 伪类中的 delay 属性对应的是鼠标移上时的延迟,元素本身属性中的 delay 对应的是鼠标移出时恢复动画的延迟。可能和第一反应不太一样(不过仔细想想倒也挺合理的),别写反了。

.icon {
  transition: opacity 0.3s ease 0.3s;
}

.search:hover .icon {
  transition-delay: 0s;
}

.bar {
  transition: transform 0.3s ease-in-out 0s;
}

.search:hover .bar {
  transition-delay: 0.3s;
}

触发区域

其实但就想要的动画效果,以上几步就足够了。但是这样还有一个小问题:动画是通过父元素 .search 的 hover 状态触发的,因此如果鼠标移入搜索图标左侧本来应该是搜索框的位置(但是现在什么也没有,被隐藏了),还是会触发显示搜索框动画。这其实也不是不能接受。

如果想只在鼠标悬停在图标时才触发动画,只要将触发条件改成 .icon 的悬停状态即可。不过由于 CSS 中只有后继元素选择器而没有前驱元素选择器(因为 DOM 渲染 CSS 的原则是不能出现回溯),需要调整一下 HTML 中图标和搜索框的顺序。

<div class="search">
  <span class="material-icons icon">search</span>
  <input class="bar" placeholder="请输入内容" />
</div>

然后修改相应的样式和选择器即可。

.icon:hover {
  opacity: 0;
  transition-delay: 0s;
}

.icon:hover + .bar {	/* + 紧邻兄弟选择器 */
  transform: translateX(24px);
  transition-delay: 0.3s;
}

.search {
  display: flex;
  flex-direction: row-reverse;	/* 让搜索框还在图标左边 */
}

附录:完整样式表

<div class="search">
  <span class="material-icons icon">search</span>
  <input class="bar" placeholder="请输入内容" />
</div>
.icon {
  width: 24px;
  height: 24px;
  opacity: 1;
  transition: opacity 0.3s ease 0.3s;
}

.icon:hover {
  opacity: 0;
  transition-delay: 0s;
}

.bar {
  height: 26px;
  width: 180px;
  padding: 1px 9px;
  border: #fff 1px solid;
  border-radius: 3px;
  background-color: transparent;
  color: #fff;
  transform: translateX(224px);
  transition: transform 0.3s ease-in-out 0s;
}

.icon:hover + .bar {
  transform: translateX(24px);
  transition-delay: 0.3s;
}

::placeholder {
  color: #ccc;
}

.search {
  height: 30px;
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  overflow: hidden;
}

到此这篇关于CSS实现隐藏搜索框功能(动画正反向序列)的文章就介绍到这了,更多相关css动画正反向序列内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

 
HTML / CSS 相关文章推荐
CSS3 3D制作实战案例分析
Sep 18 HTML / CSS
利用CSS的Sass预处理器(框架)来制作居中效果
Mar 10 HTML / CSS
css3 box-shadow阴影(外阴影与外发光)图示讲解
Aug 11 HTML / CSS
CSS3五个技巧给你的网站带来出色的效果
Apr 02 HTML / CSS
通过css3的filter滤镜改变png图片的颜色的示例代码
May 06 HTML / CSS
css3遮罩层镂空效果的多种实现方法
May 11 HTML / CSS
css3实现背景模糊的三种方式(小结)
May 15 HTML / CSS
css3利用transform变形结合事件完成扇形导航
Oct 26 HTML / CSS
HTML5 对各个标签的定义与规定:body的介绍
Jun 21 HTML / CSS
html5 canvas简单封装一个echarts实现不了的饼图
Jun 12 HTML / CSS
Canvas系列之滤镜效果
Feb 12 HTML / CSS
几款流行的HTML5 UI框架比较(小结)
Apr 08 HTML / CSS
详解CSS3.0(Cascading Style Sheet) 层叠级联样式表
html5实现点击弹出图片功能
Jul 16 #HTML / CSS
纯CSS3实现div按照顺序出入效果
CSS3中Animation实现简单的手指点击动画的示例
详解CSS中的特指度和层叠问题
Jul 15 #HTML / CSS
html form表单基础入门案例讲解
html+css实现环绕倒影加载特效
You might like
一个PHP模板,主要想体现一下思路
2006/12/25 PHP
php实现约瑟夫问题的方法小结
2015/03/23 PHP
Laravel Validator自定义错误返回提示消息并在前端展示
2019/05/09 PHP
JavaScript 类型的包装对象(Typed Wrappers)
2011/10/27 Javascript
javascript-表格排序(降序/反序)实现介绍(附图)
2013/05/30 Javascript
解析Javascript小括号“()”的多义性
2013/12/03 Javascript
jQuery-ui引入后Vs2008的无智能提示问题解决方法
2014/02/10 Javascript
两种不同的方法实现js对checkbox进行全选和反选
2014/05/13 Javascript
jQuery中:not选择器用法实例
2014/12/30 Javascript
JavaScript 消息框效果【实现代码】
2016/04/27 Javascript
js插件Jcrop自定义截取图片功能
2016/10/14 Javascript
jQuery插件HighCharts绘制2D柱状图、折线图的组合双轴图效果示例【附demo源码下载】
2017/03/09 Javascript
JavaScript实现移动端轮播效果
2017/06/06 Javascript
JavaScript中立即执行函数实例详解
2017/11/04 Javascript
js根据需要计算数组中重复出现某个元素的个数
2019/01/18 Javascript
微信小程序class封装http代码实例
2019/08/24 Javascript
[01:16:28]DOTA2-DPC中国联赛 正赛 iG vs Magma BO3 第二场 2月23日
2021/03/11 DOTA
在Python中操作字符串之startswith()方法的使用
2015/05/20 Python
python创建临时文件夹的方法
2015/07/06 Python
Python实现向服务器请求压缩数据及解压缩数据的方法示例
2017/06/09 Python
Python实现求两个csv文件交集的方法
2017/09/06 Python
Python批量生成特定尺寸图片及图画任意文字的实例
2019/01/30 Python
Python-numpy实现灰度图像的分块和合并方式
2020/01/09 Python
Python中使用socks5设置全局代理的方法示例
2020/04/15 Python
基于python 凸包问题的解决
2020/04/16 Python
HTML5 Web存储方式的localStorage和sessionStorage进行数据本地存储案例应用
2012/12/09 HTML / CSS
Hunkemöller西班牙:欧洲最大的内衣连锁店
2018/08/15 全球购物
请说出几个常用的异常类
2013/01/08 面试题
3个CCIE对一个工程师的面试题
2012/05/06 面试题
学生档案自我鉴定
2013/10/07 职场文书
2014村务公开实施方案
2014/02/25 职场文书
清明节网上祭英烈活动总结
2014/04/30 职场文书
倡议书格式模板
2014/05/13 职场文书
2014年网络管理员工作总结
2014/12/01 职场文书
先进个人主要事迹范文
2015/11/04 职场文书
解决Goland 同一个package中函数互相调用的问题
2021/05/06 Golang