html 滚动条滚动过快会留下边框线

滚动条滚动过快时,会留下边框线

但其实大部分时候是这样的,没有多出边框线的

滚动条滚动过快时留下边框线的问题通常与滚动条样式和滚动行为有关。这种问题可能出现在使用了自定义滚动条样式的情况下。

注意:使用方法 6 好使,其它只是做记录

1. 使用CSS的::-webkit-scrollbar伪元素

如果你使用的是WebKit浏览器(如Chrome, Safari等),可以通过CSS的::-webkit-scrollbar伪元素来定义滚动条的样式。确保在定义滚动条样式时包括了足够的宽度或高度,这样滚动时就不会因为样式缺失而留下边框线。

复制代码
::-webkit-scrollbar {
    width: 12px;
    height: 12px;
}

验证了 width 设置更大值管用,但我的 width 不能改,这个放弃

2. 确保滚动容器有适当的overflow属性

复制代码
.scroll-container {
    overflow-y: auto; /* 仅在必要时显示垂直滚动条 */
    overflow-x: hidden; /* 隐藏水平滚动条 */
    max-height: 200px; /* 设置最大高度以触发滚动 */
}

验证不管用。

3. 使用JavaScript动态调整滚动条宽度

没有必要增加负担

5. 使用CSS的scroll-behavior属性

如果你希望改善用户的滚动体验,可以使用scroll-behavior属性使滚动更加平滑:

复制代码
.scroll-container {
    scroll-behavior: smooth;
}

验证不管用。

6. 使用CSS的 transform 属性

对于动画和滚动效果,可以使用transformopacity等属性,这些属性可以触发GPU加速。

复制代码
.element {
  transform: translateZ(0);
}

验证好用。但是有一个问题就是 父元素使用transform会使子元素和伪元素的z-index失效

所以子元素里用 dialog 会出问题。

解决办法:可以将 dialog 单独拿出来别放在 transform 的子元素里。

相关推荐
BUG创建者3 小时前
html获取16个随机颜色并不重复
css·html·css3
BillKu5 小时前
Vue3 + Element-Plus 抽屉关闭按钮居中
前端·javascript·vue.js
DevilSeagull5 小时前
JavaScript WebAPI 指南
java·开发语言·javascript·html·ecmascript·html5
面向星辰5 小时前
html中css的四种定位方式
前端·css·html
Async Cipher6 小时前
CSS 权重(优先级规则)
前端·css
大怪v6 小时前
前端佬:机器学习?我也会啊!😎😎😎手“摸”手教你做个”自动驾驶“~
前端·javascript·机器学习
Liquad Li6 小时前
Angular 面试题及详细答案
前端·angular·angular.js
用户21411832636027 小时前
首发!即梦 4.0 接口开发全攻略:AI 辅助零代码实现,开源 + Docker 部署,小白也能上手
前端
gnip9 小时前
链式调用和延迟执行
前端·javascript
SoaringHeart9 小时前
Flutter组件封装:页面点击事件拦截
前端·flutter