CSS:隐藏移动端的滚动条的方式

目录

移动端开发中,有一个横向滚动元素,产品告诉我不需要滚动条,我说这个简单,隐藏一下不就行了,没想到还有安卓和ios不兼容的问题。

代码

html 复制代码
<style>
  .list {
    display: flex;
    overflow: auto;
    gap: 10px;
    padding: 10px;
  }

  .item {
    width: 100px;
    height: 100px;
    background: royalblue;
    border-radius: 8px;
    flex-shrink: 0;
  }
</style>

<div class="list">
  <div class="item"></div>
  <div class="item"></div>
  <div class="item"></div>
  <div class="item"></div>
  <div class="item"></div>
  <div class="item"></div>
  <div class="item"></div>
</div>

方式一:-webkit-scrollbar

css 复制代码
.list::-webkit-scrollbar {
    display: none;
  }

兼容性有问题,部分机器上还是会显示滚动条

方式二:overflow

外层添加一个父级元素

html 复制代码
<div class="wrap">
  <div class="list">
    
  </div>
</div>

css

css 复制代码
.wrap {
    overflow: hidden;
}

.list {
    padding-bottom: 20px;
    margin-bottom: -10px;
}

原理示意如下

方式三:clip-path

clip-path文档

把下方滚动条位置裁剪掉

css 复制代码
.list {
  clip-path: inset(0 0 10px);
}

方式四:mask 遮罩

原理:显示遮罩图片不透明的部分,透明的则会被裁剪

css 复制代码
.list {
  -webkit-mask: linear-gradient(red, red) 0 0/100% calc(100% - 10px) no-repeat;
}

总结

  • -webkit-scrollbar 存在兼容性问题

  • overflow兼容性最好,也最直观,符合大多数人思路,缺点是需要单独嵌套一层父级

  • clip实现最简洁,也比较好理解,在本案例中最为推荐

  • mask 思路和clip一致,实现起来稍微复杂一点,还可以实现更为复杂的渐隐效果,能够掌握更好

参考

裁剪的3种方式,CSS 如何隐藏移动端的滚动条?

相关推荐
yuanyxh1 小时前
Mac 软件推荐
前端·javascript·程序员
万少1 小时前
AtomCode开发微信小程序《谁去呀》 全流程
前端·javascript·后端
某人辛木2 小时前
Web自动化测试
前端·python·pycharm·pytest
Kagol2 小时前
Superpowers GSD gstack AgentSkills深度测评
前端·人工智能
excel3 小时前
JavaScript 字符串与模板字面量:从表象到本质理解
前端
京东云开发者4 小时前
当AI成为导演-如何用AI创作动漫短剧
前端
李白的天不白4 小时前
使用 SmartAdmin 进行前后端开发
java·前端
乘风gg4 小时前
🤡PUA AI Coding 工具 的 10 条终极语录
前端·ai编程·claude
学Linux的语莫4 小时前
Vue 3 入门教程
前端·javascript·vue.js
怕浪猫5 小时前
第一章、Chrome DevTools Protocol (CDP) 详解
前端·javascript·chrome