首页 > web前端 > css教程 > 正文

移动端搜索框如何实现微信首页般优雅的滑动隐藏和显示效果?

花韻仙語
发布: 2025-02-25 11:36:19
原创
1168人浏览过

移动端搜索框如何实现微信首页般优雅的滑动隐藏和显示效果?

打造微信首页般流畅的移动端搜索框滑动效果

本文将介绍如何实现一个类似微信首页搜索框的优雅滑动隐藏和显示效果。 目标效果:上滑时搜索框平滑隐藏或显示,下滑时搜索框保持隐藏状态。

实现思路:

核心在于监听页面滚动事件,并根据搜索框高度和滚动偏移量动态控制其显示状态。 具体来说:

  1. 获取关键值: 获取搜索框高度 (offsetHeight) 和页面滚动距离 (scrollTop)。
  2. 判断隐藏或显示: 如果搜索框被遮挡的高度小于其自身高度的一半,则显示搜索框;否则,隐藏搜索框。
  3. 处理滚动停止: 使用 setTimeout 或其他方式检测滚动停止,确保搜索框状态稳定。

代码示例 (改进版):

<code class="javascript">function handleScroll() {
  const searchBox = document.querySelector('.search-box');
  const offsetHeight = searchBox.offsetHeight;
  const scrollTop = document.documentElement.scrollTop;
  let isScrolling = false;

  if (offsetHeight / 2 > scrollTop) {
    searchBox.classList.remove('hidden');
  } else {
    searchBox.classList.add('hidden');
  }

  clearTimeout(scrollTimer); // 清除之前的定时器
  isScrolling = true; // 设置滚动状态
  scrollTimer = setTimeout(() => {
    isScrolling = false; // 滚动停止
  }, 100); // 100毫秒后判断滚动是否停止
}


let scrollTimer; // 定时器变量
window.addEventListener('scroll', handleScroll);</code>
登录后复制

CSS样式 (示例):

纳米搜索
纳米搜索

纳米搜索:360推出的新一代AI搜索引擎

纳米搜索 30
查看详情 纳米搜索
<code class="css">.search-box {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  transition: transform 0.3s ease-in-out; /* 添加平滑过渡 */
}

.search-box.hidden {
  transform: translateY(-100%); /* 完全隐藏 */
}</code>
登录后复制

改进说明:

  • 平滑过渡: 添加 CSS transition 属性,使搜索框隐藏和显示过程更加平滑。
  • 滚动停止检测: 使用 setTimeoutisScrolling 变量更准确地判断滚动停止,避免频繁切换状态。
  • 代码优化: 代码结构更清晰,可读性更好。

效果演示:

页面demo (请替换为实际demo链接)

通过以上步骤和改进后的代码,您可以轻松实现一个优雅的移动端搜索框滑动隐藏和显示效果,提升用户体验。 记住根据实际需求调整 CSS 样式和 JavaScript 代码。

以上就是移动端搜索框如何实现微信首页般优雅的滑动隐藏和显示效果?的详细内容,更多请关注php中文网其它相关文章!

微信app下载
微信app下载

微信是一款手机通信软件,支持通过手机网络发送语音短信、视频、图片和文字。微信可以单聊及群聊,还能根据地理位置找到附近的人,带给大家全新的移动沟通体验,有需要的小伙伴快来保存下载体验吧!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号