Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >修复一个因为 scrollbar 占据空间导致的 bug

修复一个因为 scrollbar 占据空间导致的 bug

作者头像
皮小蛋
发布于 2020-06-09 04:06:11
发布于 2020-06-09 04:06:11
3.4K00
代码可运行
举报
文章被收录于专栏:前端皮小蛋前端皮小蛋
运行总次数:0
代码可运行

背景

这一个因为滚动条占据空间引起的bug, 查了一下资料, 最后也解决了,顺便研究一下这个属性, 做一下总结,分享给大家看看。

正文

昨天, 测试提了个问题, 现象是一个输入框的聚焦提示偏了, 让我修一下, 如下图:

起初认为是红框提示位置不对, 就去找代码看:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<Input
  // ...
  onFocus={() => setFocusedInputName('guidePrice')}
  onBlur={() => setFocusedInputName('')}
/>

<Table
  data-focused-column={focusedInputName}
  // ...
/>

代码上没有什么问题, 不是手动设置的,而且, 在我和另一个同事, 还有PM的PC上都是OK的:

初步判断是,红框位置结算有差异, 差异大小大概是17px, 但是这个差异是怎么产生的呢?

就去测试小哥的PC上看, 注意到一个细节, 在我PC上, 滚动条是悬浮的:

在他PC上, 滚动条是占空间的:

在他电脑上, 手动把原本的 overscroll-y: scroll 改成 overscroll-y: overlay 问题就结局了。

由此判定是: 滚动条占据空间 引起的bug。

overscroll-y: overlay

CSS属性 overflow, 定义当一个元素的内容太大而无法适应块级格式化上下文的时候该做什么。它是 overflow-x 和overflow-y的 简写属性 。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/* 默认值。内容不会被修剪,会呈现在元素框之外 */
overflow: visible;

/* 内容会被修剪,并且其余内容不可见 */
overflow: hidden;

/* 内容会被修剪,浏览器会显示滚动条以便查看其余内容 */
overflow: scroll;

/* 由浏览器定夺,如果内容被修剪,就会显示滚动条 */
overflow: auto;

/* 规定从父元素继承overflow属性的值 */
overflow: inherit;

官方描述:

overlay 行为与 auto 相同,但滚动条绘制在内容之上而不是占用空间。仅在基于 WebKit(例如,Safari)和基于Blink的(例如,ChromeOpera)浏览器中受支持。

表现:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
html {
  overflow-y: overlay;
}

兼容性

没有在caniuse上找到这个属性的兼容性, 也有人提这个问题:

问题场景以及解决办法

1. 外部容器的滚动条

这里的外部容器指的是html, 直接加在最外层:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
html {
  overflow-y: scroll;
}

手动加上这个特性, 不论什么时候都有滚动宽度占据空间。

缺点:没有滚动的时候也会有个滚动条, 不太美观。

优点:方便, 没有兼容性的问题。

2. 外部容器绝对定位法

用绝对定位,保证了body的宽度一直保持完整空间:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
html {
  overflow-y: scroll; // 兼容ie8,不支持:root, vw
}

:root {
  overflow-y: auto;
  overflow-x: hidden;
}

:root body {
  position: absolute;
}

body {
  width: 100vw;
  overflow: hidden;
}

3. 内部容器做兼容

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制

.wrapper {
    overflow-y: scroll; // fallback
    overflow-y: overlay;
}

总结

个人推荐还是用 overlay, 然后使用scroll 做为兜底。

内容就这么多, 希望对大家有所启发。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-06-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端皮小蛋 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
css3系列-2.css中常见的样式属性和值
如果你是新手的话可能对盒子模型,外边距内边距都不熟悉,这一部分内容在学的时候相对来说比较吃力!如果有问题可以私聊或者留言评论给我,我帮你解决哦!
全栈学习笔记
2022/03/31
1.3K0
css基础教程之布局属性
collapse:主要用来隐藏表格的行或列。隐藏的行或列能够被其他内容使用。对于表格外的其他对象,其作用等同于hidden。
老雷PHP全栈开发
2020/07/02
5390
css属性详解
一、字体属性 字体   font-family可以把多个字体名称作为一个“回退”系统来保存。如果浏览器不支持第一个字体,则会尝试下一个。浏览器会使用它可识别的第一个值。 body { font-family: "Microsoft Yahei", "微软雅黑", "Arial", sans-serif } 大小   可以通过font-size来说设置字体大小的像素值,如果设置成inherit表示继承父元素的字体大小值。 p { font-size: 16px; } 字重(粗细)  
人生不如戏
2018/04/12
2K0
css属性详解
iframe 滚动条
在调用框架或者多级 iframe 的时候,经常会出现多个滚动条或者左右都有的情况,需要我们进行调整,现就设置方法记录如下。
zucchiniy
2019/10/30
4.5K0
CSS vw让overflow:auto页面滚动条出现时不跳动
当前web届,绝大多数的页面间布局都是水平居中布局,主体定个宽度,然后margin: 0 auto的节奏~
山河木马
2019/03/05
4.4K1
CSS vw让overflow:auto页面滚动条出现时不跳动
css基本知识框架图
2.样式表基本类型-----1.内嵌样式 2.内联样式3.链入外部样式表4.导入外部样式
yaohong
2019/09/11
7580
css基本知识框架图
css怎么隐藏滚动条「建议收藏」
法一: ①使用伪类隐藏滚动条(仅限Chrome与Safari) ②scrollbar-width: none;(仅限firefox) ③-ms-overflow-style: none;(仅限IE 10+)
全栈程序员站长
2022/11/01
4.8K0
《CSS世界》第六章 流的破坏与保护总结
《CSS世界》第六章 流的破坏与保护总结 author: @TiffanysBear float属性 float的本质与特性 1.包裹性(包含包裹和自适应) 2.块状化并格式化上下文 3.破坏文档流 4.没有任何margin合并 float的作用机制 float属性使父元素高度塌陷,为了实现文字环绕效果。高度塌陷是为了让跟随的内容可以和浮动元素在一个水平线上。(行框盒子在正常定位状态下只会跟随浮动元素,不会发生重叠) clear属性 clear属性让自身不能和前面的浮动
Tiffany_c4df
2019/11/28
8080
CSS 中 关于 Overflow ,你需要了解的这些知识点!
在CSS中,当一个元素的内容太大而无法容纳时,我们可以对其进行控制。该元素的属性是overflow,它是overflow-x和overflow-y属性的简写形式。
前端小智@大迁世界
2020/05/29
5.7K0
CSS 中 关于 Overflow ,你需要了解的这些知识点!
css笔记 - 张鑫旭css课程笔记之 overflow 篇
如果overflow-x、overflow-y的值相同,则等同于overflow设置了这个值。
xing.org1^
2018/09/20
3K0
Element scrollbar 使用封装
最近进行 Element UI 组件封装,在之前的项目中经常用到 el-scrollbar 这个内置组件,这次单独封装时遇到点写法上的小问题,做个记录和分享,希望能帮到相关的开发者。
草帽lufei
2022/07/29
9720
Element scrollbar 使用封装
前端课程——显示与隐藏
参考:https://developer.mozilla.org/zh-CN/docs/Web/CSS/display
Dreamy.TZK
2020/04/09
3K0
浮动清楚浮动及position的用法
static 默认值,无定位,不能当作绝对定位的参照物,并且设置标签对象的left、top等值是不起作用的的。
IT人一直在路上
2019/09/18
2.1K0
HTML- white-space 和 overflow 两个重要的 CSS 属性
CSS的作用是给 HTML 元素添加样式和布局,接下来利用CSS的 white-space 和 overflow 这两个属性让元素实现左右滑动,效果如下:
傅_hc
2020/03/20
2.7K0
css属性及定位操作
font-family可以把多个字体名称作为一个“回退”系统来保存。如果浏览器不支持第一个字体,则会尝试下一个。浏览器会使用它可识别的第一个值。
全栈程序员站长
2022/07/21
2.5K0
css属性及定位操作
wxss学习系列《一》定位(position),布局(Layout)
定位(position) 2017的微信公开课pro如期进行了,小程序将于2017年1月9日对个人开放,公司项目的demo版做了个大概,过程中花的时间最多的还是页面布局,所以后面将花一段时间将css的属性在小程序里过一篇,虽然小程序里面对于css支持,但没有说明支持到什么地步。今天就先来说说定位。 一.定位:position属性允许你对元素进行定位。 二.定位机制:有三种:普通流,浮动流,绝对定位。 三.定位属性值:static,relative,absolute,fixed,inherit,-ms-pag
极乐君
2018/02/05
2.6K0
wxss学习系列《一》定位(position),布局(Layout)
overflow的一些小细节笔记
最近在项目中遇到一个问题,同事在IE浏览器下测试时出现底部大块空白的问题。如下图:
德顺
2019/11/13
1.9K0
CSS深入理解学习笔记之overflow
1、Overflow基本属性   overflow:visible(默认)/hidden/scroll/auto/inherit;   visible:超出部分可见。   hidden:超出部分隐藏。   scroll:超出可滚动。   auto:若超出才出现滚动条。   inherit:继承。(IE8+)   注:overflow-x与overflow-y值不同,其中一个属性值被赋予visible,而另一个被赋值为hidden/scroll/auto,则visible会被重置为auto。 兼容性:   
就只是小茗
2018/03/07
4.3K0
CSS深入理解学习笔记之overflow
学前端到了CSS阶段,你一定要掌握这9大防御式开发技能
防御性编程是一种细致、谨慎的编程方法(习惯)。我们在写代码时常会有“以防万一”的心态,把以防万一有可能出现的情况提前考虑进去,规避以免以防万一出现带来的问题。
艾编程
2022/12/03
1.8K0
学前端到了CSS阶段,你一定要掌握这9大防御式开发技能
iframe关于滚动条的去除和保留(转载)
iframe嵌入页面后,我们有时需要调整滚动条,例如,去掉全部的滚动条,去掉右边的滚动条且保留底下的滚动条,去掉底下的滚动条且保留右边的滚动条。那么我们应该怎么做呢?
李维亮
2021/07/08
5.6K0
相关推荐
css3系列-2.css中常见的样式属性和值
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档