WHAT - 滚动条 css scrollbar-* 属性

目录

学习 CSS 的 scrollbar-* 属性可以帮助你直接通过原生样式自定义浏览器的滚动条外观,无需依赖第三方库。以下是详细的属性说明和示例:

1. 基础属性

scrollbar-width

  • 作用: 设置滚动条的宽度。

  • : auto(默认)、thin(细滚动条)、none(隐藏滚动条)。

  • 示例 :

    css 复制代码
    /* 隐藏滚动条但保留滚动功能 */
    .container {
      scrollbar-width: none;
    }
    
    /* 显示细滚动条 */
    .container {
      scrollbar-width: thin;
    }

scrollbar-color

  • 作用: 设置滚动条滑块(thumb)和轨道(track)的颜色。

  • : rgb() | rgba() | hex | hsl() | keyword

  • 示例 :

    css 复制代码
    .container {
      scrollbar-color: #d3d3d3 #f5f5f5; /* 滑块颜色  轨道颜色 */
    }

2. WebKit 浏览器专用属性(Chrome/Safari)

WebKit 使用伪元素 ::-webkit-scrollbar 来定制滚动条样式:

结构说明

css 复制代码
/* 整个滚动条容器 */
::-webkit-scrollbar {
  width: 8px;         /* 横向滚动条宽度,纵向滚动条高度 */
  height: 12px;        /* 纵向滚动条高度 */
}

/* 滚动条轨道 */
::-webkit-scrollbar-track {
  background: #f5f5f5;
  border-radius: 6px;
}

/* 滚动条滑块 */
::-webkit-scrollbar-thumb {
  background: #d3d3d3;
  border-radius: 6px;
  transition: background 0.2s ease;
}

/* 滚动条滑块悬停状态 */
::-webkit-scrollbar-thumb:hover {
  background: #a0a0a0;
}

完整示例

css 复制代码
/* 针对纵向滚动条 */
.container {
  overflow-y: auto;
  height: 300px;
}

/* WebKit 自定义滚动条 */
.container::-webkit-scrollbar {
  width: 8px;
}

.container::-webkit-scrollbar-track {
  background: #f5f5f5;
  border-radius: 6px;
}

.container::-webkit-scrollbar-thumb {
  background: #d3d3d3;
  border-radius: 6px;
}

.container::-webkit-scrollbar-thumb:hover {
  background: #a0a0a0;
}

3. 跨浏览器兼容方案

由于不同浏览器对 scrollbar-* 属性的支持不一致,建议结合以下方法:

统一写法(现代浏览器)

css 复制代码
/* 隐藏滚动条但保留滚动功能 */
.hide-scrollbar {
  scrollbar-width: none;  /* Firefox */
  scrollbar-color: transparent transparent; /* Firefox */
  -ms-overflow-style: none; /* IE/Edge */
  overflow: -moz-scrollbars-none; /* Firefox */
}

/* WebKit 浏览器隐藏滚动条 */
.hide-scrollbar::-webkit-scrollbar {
  display: none;
}

4. 高级技巧

自定义滚动条形状

通过 border-radius 实现圆形滚动条:

css 复制代码
::-webkit-scrollbar-thumb {
  border-radius: 50%; /* 圆形滑块 */
}

滚动条动画

为滑块添加过渡效果:

css 复制代码
::-webkit-scrollbar-thumb {
  transition: background 0.3s ease;
}

为特定元素单独设置

只针对某个容器生效:

css 复制代码
#my-list {
  overflow-y: auto;
  /* 自定义滚动条样式... */
}

5. 实现 macOS 风格滚动条

结合上述属性,模拟 macOS 的细长滚动条和悬停效果:

css 复制代码
/* 容器样式 */
.macos-scrollbar {
  overflow-y: auto;
  height: 400px;
}

/* WebKit 自定义 */
.macos-scrollbar::-webkit-scrollbar {
  width: 12px;
}

.macos-scrollbar::-webkit-scrollbar-track {
  background: #f5f5f5;
  border-radius: 6px;
}

.macos-scrollbar::-webkit-scrollbar-thumb {
  background: #d3d3d3;
  border-radius: 6px;
  transition: background 0.2s ease;
}

.macos-scrollbar::-webkit-scrollbar-thumb:hover {
  background: #a0a0a0;
}

/* Firefox 兼容 */
.macos-scrollbar {
  scrollbar-width: thin;
  scrollbar-color: #d3d3d3 #f5f5f5;
}

HOW - 在Windows浏览器中模拟MacOS的滚动条 中我们也介绍过。

6. 注意事项

  1. 浏览器兼容性:

    • 注意浏览器是否支持 scrollbar-widthscrollbar-color
    • Chrome/Safari 可通过 ::-webkit-scrollbar 伪元素。
    • Edge/IE 不推荐使用原生滚动条样式,建议通过第三方库统一处理。
  2. 隐藏滚动条:

    • 使用 overflow: hidden 会禁用滚动,需谨慎!

通过以上方法,你可以完全掌控滚动条的外观和行为,适配现代浏览器的需求。假如希望引入一些第三方库来实现,可以阅读 HOW - 在Windows浏览器中模拟MacOS的滚动条

相关推荐
Mintopia几秒前
一个月速成 AI 工程师:从代码小白到智能工匠的修炼手册
前端·javascript·aigc
Mintopia3 分钟前
Next.js 全栈:接收和处理请求
前端·javascript·next.js
袁煦丞37 分钟前
2025.8.18实验室【代码跑酷指南】Jupyter Notebook程序员的魔法本:cpolar内网穿透实验室第622个成功挑战
前端·程序员·远程工作
Joker Zxc42 分钟前
【前端基础】flex布局中使用`justify-content`后,最后一行的布局问题
前端·css
无奈何杨1 小时前
风控系统事件分析中心,关联关系、排行、时间分布
前端·后端
Moment1 小时前
nginx 如何配置防止慢速攻击 🤔🤔🤔
前端·后端·nginx
晓得迷路了1 小时前
栗子前端技术周刊第 94 期 - React Native 0.81、jQuery 4.0.0 RC1、Bun v1.2.20...
前端·javascript·react.js
前端小巷子1 小时前
Vue 自定义指令
前端·vue.js·面试
玲小珑1 小时前
Next.js 教程系列(二十七)React Server Components (RSC) 与未来趋势
前端·next.js