CSS Overscroll Behavior Module Level 1

栏目: CSS · 发布时间: 5年前

内容简介:编者按:本文作者奇舞团前端开发工程师何文力,同时也是 W3C CSS 工作组成员。6 月 6 日,W3C 发布了第一份滚动溢出行为工作组草案 CSS Overscroll Behavior Module Level 1。该草案定义在日常开发过程中,大家应该都见到过这么一个行为:子容器滚动条滚动到底,会带动父容器一起滚动。要解决这个问题,通常我们可以通过监听子容器的事件,然后调用

编者按:本文作者奇舞团前端开发工程师何文力,同时也是 W3C CSS 工作组成员。

6 月 6 日,W3C 发布了第一份滚动溢出行为工作组草案 CSS Overscroll Behavior Module Level 1。该草案定义 overscroll-behavior 去控制滚动视图滚动到边缘时的行为和效果

简介

在日常开发过程中,大家应该都见到过这么一个行为:子容器滚动条滚动到底,会带动父容器一起滚动。要解决这个问题,通常我们可以通过监听子容器的事件,然后调用 preventDefault 或是将父容器的 overflow 临时设置为 hidden 。这种行为又称为连锁滚动(scroll chaining)。

在 CSS Overscroll Behavior 中,将使用 overflow-behavior 去完成相同的事情。

overscroll-behavior 属性

contain

contain 属性值指定浏览器在任何层级的滚动中都可以出现连锁滚动的行为,但仍会出现溢出效果。

例如左侧的导航栏,想让用户在将导航栏滚动到底部时不滚动父容器,则可以设置:

.sidebar {

overscroll-behavior : contain ;

}

CSS Overscroll Behavior Module Level 1

none

none 属性值的行为与 contain 行为相同,除此之外,使用该属性值将不会使用溢出滚动效果(如 iOS 上的滚动溢出效果)。

auto

autooverscroll-behavior 的默认值,使用链式滚动行为,并且使用滚动溢出效果。

CSS Overscroll Behavior Module Level 1

overscroll-behavior 的长写法

overscroll-behavior: contain 会设定 x 与 y 方向为 contain ,如果需要设定某一边的行为,可以使用 overscroll-behavior-x 以及 overscroll-behavior-y

文档流方向相关的长写法

overscroll-behavior-inlineoverscroll-behavior-block 分别表示了 inline 和 block 方向上的设定,分别与 overscroll-behavior-xoverscroll-behavior-y 相对应,实际的对应关系与文档所设定的书写模式 writing-mode 有关。

参考资料

https://www.w3.org/blog/news/archives/7779

https://www.w3.org/TR/2019/WD-css-overscroll-1-20190606/

关于奇舞周刊

《奇舞周刊》是360公司专业前端团队「 奇舞团 」运营的前端技术社区。关注公众号后,直接发送链接到后台即可给我们投稿。

CSS Overscroll Behavior Module Level 1


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

六度分隔

六度分隔

邓肯·J·瓦茨 / 陈禹 / 中国人民大学出版社 / 2011-3 / 46.00元

正如副标题所表明的,《六度分隔:一个相互连接的时代的科学》的基本内容是介绍一门正在形成中的新科学——关于网络的一般规律的科学。有这样一门科学吗?它的内容和方法是什么?近年来,这门学科有什么实质性的进展吗?在《六度分隔:一个相互连接的时代的科学》中,作者根据自己的亲身经历娓娓道来,用讲故事的方式,对于这些问题给出了令人信服的回答 除了简要的背景和总结以外,《六度分隔:一个相互连接的时代的科学》......一起来看看 《六度分隔》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试