首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【干货】使用 CSS Scroll Snap 优化滚动,提升用户体验!

在触摸屏上滑动手势的主要好处是,我们可以用一根手指水平或垂直滚动。 image.png 实际上需要将每个项目移动到它自己的位置。...首先,我们需要将scroll-snap-type添加到滚动容器中。 在我们的示例中,是.section元素。...Scroll Snap Type 根据CSS规范,scroll-snap-type 属性定义在滚动容器中的一个临时点(snap point)如何被严格的执行。...意思是当滚动动作结束,如果可能,它会临时在那个点上。如果内容被添加、移动、删除或者重置大小,滚动偏移将被调整为保持静止在临时点上。 mandatory关键字意味着浏览器必须捕捉到每个滚动点。...在向元素添加边距时,滚动将根据边距对齐。 参见下图: ? .item-2具有scroll-margin-left: 20px。 结果,滚动容器将在该项目之前对齐到20px。

2.1K30

使用 CSS Scroll Snap 优化滚动,提升用户体验!

然而,这还不够,这不是一个可用的滚动容器。 滚动容器有什么问题 问题是,与滑动相比,它们并不能提供良好的体验。在触摸屏上滑动手势的主要好处是,我们可以用一根手指水平或垂直滚动。...实际上需要将每个项目移动到它自己的位置。...首先,我们需要将scroll-snap-type添加到滚动容器中。 在我们的示例中,是.section元素。...意思是当滚动动作结束,如果可能,它会临时在那个点上。如果内容被添加、移动、删除或者重置大小,滚动偏移将被调整为保持静止在临时点上。 mandatory关键字意味着浏览器必须捕捉到每个滚动点。...在向元素添加边距时,滚动将根据边距对齐。 参见下图: .item-2具有scroll-margin-left: 20px。 结果,滚动容器将在该项目之前对齐到20px。

2.9K41
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【Web前端】“CSS 定位”如何工作?(补充)

    定位允许你从正常的文档流布局中取出元素,并使它们具有不同的行为,例如放在另一个元素的上面,或者始终保持在浏览器视窗内的同一位置。 一、文档流 在讨论CSS定位之前,我们首先需要理解“文档流”这一概念。...文档流是网页上所有元素的默认布局方式。元素按照它们在HTML中出现的顺序,从上到下、从左到右进行排列。理解文档流对于掌握CSS定位至关重要,因为定位属性可以改变元素在文档流中的行为。...块级元素会垂直排列,每个元素占据一整行,而行内元素则在同一行内水平排列。 二、定位基础 CSS定位属性允许我们改变元素在文档流中的位置,从而实现更复杂的布局效果。...即使元素视觉上移动了,文档流中的位置不变。 绝对定位 绝对定位使元素脱离文档流,完全按照我们指定的位置进行排列。...粘性定位 粘性定位是一种相对定位和固定定位的结合。通过设置 ​​position: sticky;​​,元素在滚动时会在某个阈值内相对位置固定,一旦滚动超过阈值,元素会跟随滚动继续移动。​​

    9410

    JS事件篇

    只读 元素.offsetLeft和offsetTop: 返回相对于父元素的水平和垂直偏移量---只读 元素.scrollWidth和scrollHeight获取元素整个滚动区域的宽和高 元素.scrollLeft...和scrollTop获取水平和垂直滚动条滚动滚动距离 当满足scrollHeight - scrollTop == clientHeight时,表明垂直滚动条滚动到底了 阅读知情同意书的小案例 onmousemove...事件和事件对象 获取鼠标的坐标 页面滚动条的归属者 解决浏览器兼容性常使用以下写法 div跟随鼠标移动 事件的冒泡和事件对象event 事件的委派 事件的绑定----为另一个元素绑定多个事件 addEventListener...–只读 开启定位:只要position值不是static即为开启定位 ---- 元素.offsetLeft和offsetTop: 返回相对于父元素的水平和垂直偏移量—只读 ---- 元素....alert(d1.scrollHeight); ---- 元素.scrollLeft和scrollTop获取水平和垂直滚动条滚动滚动距离

    12.6K10

    CSS | 视差滚动 | 笔记

    引言 视差滚动(Parallax Scrolling)是一种效果, 能够使不同层次的元素以不同的速度进行滚动, 从而产生了视觉上的深度感和动态效果。...通过设置transform-style和 perspective,使该容器的子元素处在3D空间中, 然后设置transform: translateZ使物体在滚动的时候在Y轴移动位移不同,产生视觉差。...例如,较远的东西(即 z 轴上的负平移)会移动得更慢。相反,距离较近的东西(即 z 轴上的正平移)会移动得更快。 另一个物理效应是规模。 如果我们把一些东西移得更远,它就会显得更小。...它定义了 观察者(即浏览器窗口)与 3D 元素之间的距离,从而影响到元素的透视效果。 透视效果是指当元素在 3D 空间中移动时,根据其与观察者的距离,产生的远近感和大小变化。...遗憾的是,仍然没有一种简单的方法可以让一个元素在不依赖javascript的情况下占据整个视口高度。 height: 100vh 是如此接近伟大,但考虑到它在移动设备上的局限性,最好避免它。

    81521

    一文带你响应式网页设计入门

    媒体查询使您可以根据当前设备尺寸来设置元素的样式。现在流行的CSS策略是首先编写移动样式,然后在其上构建更复杂的桌面版网页样式。...适用于桌面设备的样式,我们利用与上一节中的示例类似的媒体查询将容器main元素设置为flex-wrap: nowrap,这样可以确保子元素不会换行,通过在媒体查询中设置div为flex-basis: 33%...在这种情况下,我们可以使用另一种技术-水平滚动。 使用内容溢出滚动条进行水平滚动 可能会有这样一种情况:您的内容会溢出界面,而没有一种优雅的处理方式去解决。.../span> another item overflow-y: scroll 这个CSS是关键,通过设置overflow,子元素将通过水平轴溢出并出现横向滚动条...position: relative 容器元素上的子元素允许子元素利用相对于其的绝对位置。

    4.8K20

    CSS 中 关于 Overflow ,你需要了解的这些知识点!

    MDN 上这样说到: 注意: 设置一个轴为visible(默认值),同时设置另一个轴为不同的值,会导致设置visible的轴的行为会变成auto`。...Overflow的常见问题:在手机上滚动 例如,当我们有一个滑动条时,仅仅添加overflow-x是不够的。在Chrome iOS上,我们需要手动滚动和移动内容。看下面的动图: ?...根据MDN: -webkit-overflow-scrolling 属性控制元素在移动设备上是否使用滚动回弹效果。它有两个值: auto: 使用普通滚动, 当手指从触摸屏上移开,滚动会立即停止。...下图是使用基于动量的滚动的效果。 ? 内联块元素 根据CSS规范: 将对象呈递为内联对象,但是对象的内容作为块对象呈递。旁边的内联对象会被呈在同一行内,允许空格。...水平滚动问题 通常,我们会遇到水平滚动的问题,当原因未知时,滚动滚动会变得更加困难。 在本节中,我将列出水平滚动的一些常见原因,以便大家以后在构建布局时可以想到到它们。

    5.2K20

    CSS 中你需要知道 auto 的一切!

    手机和 PC 之间的宽度不同 ? 我们有一组按钮。在移动设备上,我们希望它们彼此相邻(每个按钮包装器占据其父元素的50%),而在桌面设备上,每个按钮都应该占据其父元素的全部宽度。该怎么做?...这使元素相对于包含块的边缘水平居中。 ? 具有绝对定位元素的 margin:auto ? 另一个不太常见的将绝对定位元素居中的用例是margin: auto。...在 Chrome 窗口中,滚动条总是显示出来,这是不正确和令人困惑的行为。 通过使用auto关键字,我们可以确保滚动条不会显示,除非内容高度大于它的容器。 根据MDN: 取决于用户代理。...根据 MDN: 如果元素是静态元素,则将定位在它应该水平定位的位置 这意味着,它会尊重padding,而不会将子条目粘贴到其父条目的边缘。...如果我们正在设计系统上,则应该考虑多个状态。 例如,提示的箭头指向左侧,另一个箭头指向右侧。 ?

    5.5K30

    CSS-定位(position)

    fixed(认死理型) 叠放次序(z-index) 四种定位总结 如果说浮动, 关键在一个 “浮” 字上面, 那么,定位关键在于一个 “位” 上。...所谓静态位置就是各个元素在HTML文档流中默认的位置。 在静态定位状态下,无法通过边偏移属性(top、bottom、left或right)来改变元素的位置。...class="son3">son3div> div> 结果 # 定位的扩展 # 绝对定位的盒子水平/垂直居中 普通的盒子是左右margin 改为 auto...不管浏览器滚动条如何滚动也不管浏览器窗口的大小如何变化,该元素都会始终显示在浏览器窗口的固定位置。 固定定位有两点: 固定定位的元素跟父亲没有任何关系,只认浏览器。...注意: z-index的默认属性值是0,取值越大,定位元素在层叠元素中越居上。 如果取值相同,则根据书写顺序,后来居上。 后面数字一定不能加单位。

    1.5K10

    浏览器滚动条的自定义和隐藏

    ---- 我们在处理业务的时候,偶尔会因为某些非抵抗力因素,需要对浏览器的滚动条进行处理,以提升产品的体验。...scrollbar-button 滚动条的上下按钮 mac 上俺试了没效果,读者可以在 window 上尝试下 scrollbar-thumb 滚动条上的滑块 scrollbar-track-piece...读者通过更改对应的代码熟悉下: 代码片段 鼠标移动到容器右下角的滑块,并点击拖动可以伸缩容器大小 好了,至此我们就可以根据自己业务实际的需求,运用不同的选择器,对滚动条进行自定义样式了。...*/ } .div3 { overflow-x: hidden; /* 隐藏 x 轴,即水平滚动条 */ } 但是,这个方法有一个劣势:所在的容器是不可滚动了,但是超出的部分不可见。...,查看滚动的距离 读者可以根据业务场景使用不同的方案。

    2.3K30

    css属性及定位操作

    ,然后根据位置去显示图片。... 圆形头像示例 背景重复 repeat(默认):背景图片平铺排满整个网页 repeat-x:背景图片只在水平方向上平铺 repeat-y:背景图片只在垂直方向上平铺 no-repeat...浮动元素会生成一个块级框,而不论它本身是何种元素。 关于浮动的两个特点: 浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。...注意点: 一个元素若设置了 position:absolute | fixed; 则该元素就不能设置float。这 是一个常识性的知识点,因为这是两个不同的流,一个是浮动流,另一个是“定位流”。...因为它原本所占的空间仍然占据文档流。 在理论上,被设置为fixed的元素会被定位于浏览器窗口的一个指定坐标,不论窗口是否滚动,它都会固定在这个位置。 <!

    2.5K50

    手势魅力-设置一个触摸菜单

    触摸属性列出当前在屏幕上的所有手指: PageX:返回手指放置在DOM中的x坐标。从左边开始计算,如果适用,则考虑水平滚动 PageY:返回手指放置在DOM中的y坐标。...所以,当你玩手机触摸手势,想想: 限制:你想要什么元素停止?您希望它在每次拖动时移动多远? 这个手势的方向:你想只能水平移动,或者还是垂直移动?也许是两个? 拖动完成后你想要发生什么?...在我的情况下,我只希望手势的方向是水平的,因为我希望滚动功能正常。我有限制,并且我希望它回到开始或结束。...轴上移动distance moved in the x axis const translateY = currentY - startY; // 距离在y轴上移动distance moved...五个像素移动?那么这个菜单可以根据距离打开或关闭。

    1.9K40

    详解DOM对象中clientWidth、offsetWidth等属性

    我们有时需要获得鼠标在某盒子中的位置,或者是随意移动某盒子的位置,在这些场景中我们可能经常需要用到clientWidth、offsetWidth、offsetTop啊等等。...offsetParent属性返回一个对象的引用,这个对象是距离调用offsetParent的元素最近的(在包含层次中最靠近的),并且是已进行过CSS定位的容器元素。...指的是offsetLeft只读属性返回当前元素左上角在offsetParent节点内向左偏移的像素数。...当不存在水平或垂直滚动条时,scrollWidth和scrollHeight等于clientWidth和clientHeight, 当存在水平或垂直滚动条时,请看下面演示(将div#sub-contetn...,scrollWidth和scrollHeight还得在clientWidth和clientHeight的基础上加上内容层增加高度以及减去相应的滚动条宽度。

    4K20

    我做了一个在线白板!!!

    其实我们鼠标是在另一个世界,这个世界的坐标原点在左上角,而前面我们把画布世界的原点移动到中心位置了,所以它们虽然是平行世界,但是奈何坐标系不一样,所以需要把我们鼠标的位置转换成画布的位置: const...,即鼠标按下的位置到鼠标当前移动到的位置经过的角度,两个点本身并不存在啥角度,只有相对一个中心点会形成角度: 这个中心点其实就是矩形的中心点,上图夹角的计算可以根据这两个点与中心点组成的线段和水平x轴形成的角度之差进行计算...我们新增两个状态变量:scrollX、scrollY,记录画布水平和垂直方向的滚动偏移量,以垂直方向的偏移量来介绍,当鼠标滚动时,增加或减少scrollY,但是这个滚动值我们不直接应用到画布上,而是在绘制矩形的时候加上去...而当发生滚动后,比如向下滚动,那么上方的水平线没了,那我们只要补画一下上方的水平线,水平线我们是从-height/2开始向下画到height/2,那么我们就从-height/2开始再向上补画: const.../ 2); // 将滚动值恢复成0,因为在新画布上并不涉及到滚动,所有元素距离有多远我们就会创建一个有多大的画布 scrollY = 0; // 渲染所有元素 allElements.forEach

    3.6K31

    scrollwidth和clientwidth_vue监听页面滚动

    另外:我们这里所说的是指 HTML 控件的属性值,并不是 document.body,document.body 的值在不同浏览器中有不同解释(实际上大多数环境是由于对 document.body 解释不同造成的...新版本的浏览器大多支持根据页面指定的 DOCTYPE 来启用不同的解释器 scrollTop 是“卷”起来的高度值,示例: div style=”width:100px;height:100px;background-color...1.clientHeight, clientWidth: 这两个属性大体上显示了元素内容的象素高度和宽度.理论上说这些测量不考虑任何通过样式表加入 元素中的页边距,边框等. 2.clientLeft...,clientTop: 这两个返回的是元素周围边框的厚度,如果不指定一个边框或者不定位改元素,他的值就是0. 3.scrollLeft,scrollTop: 如果元素是可以滚动的,可以通过这俩个属性得到元素在水平和垂直方向上滚动了多远...对于不可以滚动的元素,这些值总是0. 4.scrollHeight,scrollWidth: 不管有多少对象在页面上可见,他们得到的是整体. 5.style.left: 定位元素与包含它的矩形左边界的偏移量

    1.8K10

    从 antDesign 来窥探移动端“滚动穿透”行为

    比如上方图片中有两个元素,一个为红色边框存在滚动条的父元素,另一个则为蓝色边框黑色背景不存在滚动条的子元素。 当我们拖动不可滚动的子元素时,实际会意外造成父元素会跟随滚动。...我们在子元素区域内进行拖拽时,当子元素滚动到底部(顶部)时,仍然继续往下(上)进行拖动。 原理 上述两种情况相信大家也日常业务开发中碰到过不少次。...在移动端,我们完全可以使用一种通用的解决方案来解决上述造成“滚动穿透”意外行为: 无论元素是否可以滚动时,每次元素的拖拽事件触发时我们只需要进行判断: 寻找当前触发 touchMove 事件 event.target...move 方法中同样接受 TouchEvent 对象作为入参,根据 TouchEvent 上的位置属性分别计算: deltaX、deltaY 两个值,表示移动时相较初始值的距离,不同方向可为负数。...上述的代码仍然是按照我们在文章开头讲述的解决思路来解决移动端滚动链接的意外行为。

    58720
    领券