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

控制页面的滚动:自定义下拉到刷新和溢出效果

前言 通过阅读本文,你可以通过css 中overcroll-behavior属性值的设置,处理浏览器溢出滚动,以及禁用移动设备上刷新,下拉滚动时的发光和橡皮圈回弹效果,当然也可以看到css中 Houndini...使用该案例包括禁用移动设备上的“拉动到刷新”功能,消除过度滚动发光和橡皮筋效果,并防止页面内容在模态/叠加层下滚动 背景 滚动边界和滚动链接 滚动是与页面交互的最基本的方式之一,但是由于浏览器的诡异默认行为...最终的结果是当用户到达聊天记录的顶部/底部时,主页面保持放置状态。在聊天框中开始的滚动不会传播出去 ?.... */ overscroll-behavior-y: contain; } 通过这个简单的添加,我们修复了聊天框演示中的双拉到更新动画,并且可以实现使用整洁加载动画的自定义效果。...(示例效果) 总结 本文主要是针对页面上的滚动,自定义下拉刷新与溢出效果,通过css中的overscroll-behavior:container阻止滚动链接,也就是在触发子元素的事件操作时,不会传递给父级元素

3.5K20

点击按钮,回到页面顶部的5种写法

如果为true,表示元素的顶部与当前区域的可见部分的顶部对齐(前提是当前区域可滚动);如果为false,表示元素的底部与当前区域的可见部分的尾部对齐(前提是当前区域可滚动)。...如果没有提供该参数,默认为true,使用该方法的原理与使用锚点的原理类似,在页面最上方设置目标元素,当页面滚动时,目标元素被滚动到页面区域以外,点击回到顶部按钮,使目标元素重新回到原来位置,则达到预期效果...则用图片代替) 使用CSS伪元素及伪类hover效果,当鼠标移动到该元素上时,显示回到顶部的文字,移出时不显示   .box{ position:fixed; right:10px...id=“box” class=“box”> div class=“box-in”>div> div> 【2】动画增强 为回到顶部增加动画效果,滚动条以一定的速度回滚到顶部...将scrollBy(x,y)中的y参数设置为-50,直到scrollTop为0,则回滚停止 var timer = null; box.onclick = function

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

    基于JS实现回到页面顶部的五种写法(从实现到增强)

    如果没有提供该参数,默认为true   使用该方法的原理与使用锚点的原理类似,在页面最上方设置目标元素,当页面滚动时,目标元素被滚动到页面区域以外,点击回到顶部按钮,使目标元素重新回到原来位置,则达到预期效果...,则用图片代替)   使用CSS伪元素及伪类hover效果,当鼠标移动到该元素上时,显示回到顶部的文字,移出时不显示   .box{ position:fixed; right...id="box" class="box"> div class="box-in">div> div> 2】动画增强   为回到顶部增加动画效果,滚动条以一定的速度回滚到顶部...  将scrollBy(x,y)中的y参数设置为-50,直到scrollTop为0,则回滚停止 var timer = null; box.onclick = function()...最终,以最常用的scrollTop属性实现动画增强效果   当然,如果觉得500ms的时间不合适,可以根据实际情况进行调整 <!

    6K21

    rAF实现表格内容自动滚动

    目标: 让表格的内容会自动滚动 鼠标悬浮,动画停止 到底后会自动回到顶部,继续滚动 element表格自带滚动 首先呢,element的表格是自带了滚动效果的,但是需要小小的设置一下。...然后,我们使用Devtools工具看一下: 图片 发现上面红框框的元素高是100%,但是它们的父元素的高不是100%,所以外层的高并没有传过来。...,所以使用bind方法来携带参数 } 图片 到底后会自动回到顶部,继续滚动 这里我们需要判断是否到底了,所以需要使用可视高度+距离顶部 >= 整个高度的方式,即el.clientHeight + el.scrollTop...也就是说,scrollTo方法的参数添加 behavior: "smooth"来让它圆滑的回滚到顶部。 但是,我们添加了这个选项后,反而不回滚了。这是因为动画一直都还在,回滚速度又不够动画的。...所以我们回滚前还得把动画给停止掉。

    2.1K20

    H5C3第四节

    CSS3在布局方面做了非常大的改进,使得我们对块级元素的布局排列变得十分灵活,适应性非常强,其强大的伸缩性,在响应式开中可以发挥极大的作用。...justify-content(重点) justify-content主要用来设置主轴方向的对齐方式 ,可选的值有: 可选值: flex-start: 弹性盒子元素将向起始位置对齐 flex-end:...align-items(重点) align-items用于调整侧轴的对其方式 ,可选的值有: flex-start:元素在侧轴的起始位置对其。 flex-end:元素在侧轴的结束位置对其。...,默认true, scrollingSpeed 设置滚动的速度,默认700毫秒 easing 设置动画的方式,一般不修改, 默认是easeInOutCubic, 如果想要修改此参数,需要引入jquery.easing.js...loopTop 滚动到顶部后是否连续滚动到底部,默认false loopBottom 滚动到底部后是否连续滚动到顶部,默认false continuousVertical 是否循环滚动,默认为false

    5.3K30

    clientWidth,offsetWidth,scrollWidth你分的清吗

    + 溢出内容的尺寸,这个只针对dom的子元素出现溢出情况时,才有效果,不然它始终和clientHeight相等 scrollTop 代表在有滚动条时,滚动条向下滚动的距离也就是元素顶部被遮住部分的高度...注意:当元素溢出浏览器的视口,值会变成负数。...大概是这样 实现思路就是,去拿到选中元素的clientHeight和offsetTop,并和列表的高度区间做比较,计算出元素是在列表视口的内部,还是溢出的视口,如果溢出了视口,那么就回滚。...笔者用react写的,直接附上代码吧 dom div className='container'> div className='scroll' ref={(ref) => (this.scrollRef...就是元素底部距离滚动容器顶部的距离,再减去20像素,保证出现在视口中间 const needScroll = top - containerOffsetTop - 20; if (needScroll

    2.1K10

    Web前端实现锚点功能的三种方式

    一、hash 这种方式非常简单,给待跳转元素添加 id,之后修改 window.location 即可,用法如 div id="root">div> 当需要跳转时可调用 window.location...提供一些选项,允许开发者自定义滚动方式,选项包括 behavior,定义动画过渡效果, "auto"或 "smooth" 之一。...默认为 "start",元素顶部将滚动到视窗顶部; 取值 "end",元素底部将和视窗底部对齐; 取值 "center",元素中线将和视窗中间对齐; 取值 "nearest",元素将就近对齐。...用法如: window.scrollBy(xnum, ynum); 这种方式还需要实用 Element.getBoundingClientRect 来获取元素的大小及相对于当前视窗的位置。...以 HTML 根节点为滚动容器为例: div id="root">div> 当需要跳转时可调用 const {scrollTop: domScrollTop, scrollLeft: domScrollLeft

    3.7K31

    06-移动端开发教程-fullpage框架

    支持css3动画。 支持窗口缩放。 窗口缩放时自动调整。 可设置滚动宽度,背景颜色,滚动速度,循环选项,回调,文本对齐方式等。...函数 无 设置背景颜色 anchors 数组 无 定义锚链接 scrollingSpeed 整数 700 滚动速度,单位为毫秒 easing 字符串 easeInQuart 滚动动画方式 menu 布尔值...字符串 #fff 左右滑块的箭头的背景颜色 loopBottom 布尔值 false 滚动到最底部后是否滚回顶部 loopTop 布尔值 false 滚动到最顶部后是否滚底部 loopHorizontal...配合animate.css的问题,animate的动画添加上animated样式和具体的动画类型才会具有动画效果。如果一开始全设置好了那么只有第一屏有动画效果,不是我们想要的结果。...配合fullpage的onLeave事件,可以实现在上一屏离开的时候,给下一屏添加动画样式类,并把上一屏的动画样式类去掉。动画样式类可以提前记录在一个数组中或者是放到动画元素的自定义属性中。

    5.1K90

    06-移动端开发教程-fullpage框架

    支持css3动画。 支持窗口缩放。 窗口缩放时自动调整。 可设置滚动宽度,背景颜色,滚动速度,循环选项,回调,文本对齐方式等。...函数 无 设置背景颜色 anchors 数组 无 定义锚链接 scrollingSpeed 整数 700 滚动速度,单位为毫秒 easing 字符串 easeInQuart 滚动动画方式 menu 布尔值...字符串 #fff 左右滑块的箭头的背景颜色 loopBottom 布尔值 false 滚动到最底部后是否滚回顶部 loopTop 布尔值 false 滚动到最顶部后是否滚底部 loopHorizontal...配合animate.css的问题,animate的动画添加上animated样式和具体的动画类型才会具有动画效果。如果一开始全设置好了那么只有第一屏有动画效果,不是我们想要的结果。...配合fullpage的onLeave事件,可以实现在上一屏离开的时候,给下一屏添加动画样式类,并把上一屏的动画样式类去掉。动画样式类可以提前记录在一个数组中或者是放到动画元素的自定义属性中。

    5.1K50

    fullPage.js全屏滚动插件

    字体是否随着窗口缩放而缩放 slidesColor 设置背景颜色 anchors (array)定义锚链接 scrollingSpeed (int) 设置滚动速度,单位为毫秒 easing (striing)滚动动画方式...controlArrowColor (string) 左右滑块的箭头的背景颜色 loopBottom (true/false)滚动到最底部后是否滚回顶部 loopTop (true/false)...滚动到最顶部后是否滚底部 loopHorizontal (true/false)左右滑块是否循环滑动 autoScrolling (true/false) 是否使用插件的滚动方式,如果选择 false...() 添加或删除鼠标滚轮/触控板控制 setKeyboardScrolling() 添加或删除键盘方向键控制 setScrollingSpeed() 定义以毫秒为单位的滚动速度 6.回调函数 --...() 滚动前的回调函数,接收 index、nextIndex 和 direction 3个参数:index 是离开的“页面”的序号,从1开始计算;nextIndex 是滚动到的“页面”的序号,从1开始计算

    15K20

    gsap的ScrollTrigger让你的页面更炫酷

    xPercent 是一个相对移动的值,-100 (boxItems.length - 1) 意味着将所有的 boxItems 元素水平移动到最后一个元素的位置。...ease: 'none': 这里设置了动画的缓动效果为“无”,即动画将以线性方式进行,没有加速或减速。...pin: true: 将 boxContainer 固定在视口中,直到动画结束。start: 'top top': 定义动画开始的滚动位置,当 boxContainer 的顶部与视口顶部对齐时开始。...end: +=${boxContainer.offsetWidth || 0 - innerWidth}: 定义动画结束的滚动位置,计算方式是 boxContainer 的宽度减去视口的宽度。...当marker的start移动到scroller-start后则开始动画。当marker的end移动到scroller-end后则结束动画效果二:卡片效果滚动页面,卡片从右往左展示,类似卡片切换效果。

    36720

    2019-08-09 满屏切换vue项目中使用 vue-fullpage.js

    // loopTop: true, // //滚动到最底部后是否连续滚动到顶部 // loopBottom: true, // //横向slide幻灯片是否循环滚动...,但是浏览器滚动条默认行为也有效 // scrollBar: true, // //设置每个section顶部的padding,当我们要设置一个固定在顶部的菜单、导航、元素等时使用...paddingBottom: "100px", // //固定的元素,为jquery选择器;可用于顶部导航等 // fixedElements: ".nav", // //是否可以使用键盘方向键导航...,但是浏览器滚动条默认行为也有效 // scrollBar: true, // //设置每个section顶部的padding,当我们要设置一个固定在顶部的菜单、导航、元素等时使用...paddingBottom: "100px", // //固定的元素,为jquery选择器;可用于顶部导航等 // fixedElements: ".nav", // //是否可以使用键盘方向键导航

    11.9K30

    【Vue前端】字幕滚动设置

    在Web开发中,字幕滚动效果是一种常见的动效,常用于展示新闻头条、广告语等。Vue 3 是目前非常流行的前端框架,通过Vue 3,我们可以轻松实现字幕来回滚动的效果。...2.2样式部分 ():.header类用于固定页面顶部的容器,并设置背景色、阴影和内边距。.title类设置标题的颜色、字体大小和样式。....marquee类用于设置滚动区域的样式,包括隐藏溢出的内容和设置背景色。.marquee-text类用于设置滚动文本的颜色和动画效果。...的关键帧动画,使得文本从右向左滚动到尽头,再从左回到右侧,形成来回滚动的效果。...animation: marquee 10s linear infinite:设置动画的持续时间为10秒,并且无限循环。你可以根据需要调整时间以控制滚动速度。

    92110

    jQuery 尺寸、位置操作

    offset().top  用于获取距离文档顶部的距离,offset().left 用于获取距离文档左侧的距离。...③ 可以设置元素的偏移:offset({ top: 10, left: 30 });  2. position() 获取元素偏移 ① position() 方法用于返回被选元素相对于带有定位的父级偏移坐标...="back">返回顶部div> div class="container">div> $(function() {...案例:带有动画的返回顶部 1.核心原理: 使用animate动画返回顶部 2.animate动画函数里面有个scrollTop 属性,可以设置位置 3.但是是元素做动画,因此 $(“body,html...案例: 品优购电梯导航(上) 1.当我们滚动到 今日推荐 模块,就让电梯导航显示出来2.点击电梯导航页面可以滚动到相应内容区域3.核心算法:因为电梯导航模块和内容区模块一一对应的4.当我们点击电梯导航某个小模块

    1.1K20

    排行榜--实现点击视图自动滚动到当前用户所在位置.

    我们今天来实现一下,点击当前用户的div, 自动滚动到用户在排行榜中的位置. 效果 大家可以先看一下下面的GIF, 所实现的效果. 实现 1....简单来讲就是被调用的者的元素出现在用户的视线里面. scrollIntoView() 方法有三种调用形式: scrollIntoView():无参数调用,元素将滚动到可视区域顶部,如果它是第一个可见元素...scrollIntoView(alignToTop):接受一个布尔值参数,决定元素是与滚动区的顶部还是底部对齐。...scrollIntoView(scrollIntoViewOptions):接受一个对象作为参数,提供了更多的滚动选项。 参数 alignToTop(可选):布尔值,控制元素滚动到顶部还是底部对齐。...默认为 true(顶部对齐)。 scrollIntoViewOptions(可选实验性):对象,包含以下属性: behavior:定义滚动行为是平滑动画还是立即发生。

    18710

    ❤️创意网页:超简单好看的HTML5七夕情人节表白网页(表白直接拿去用) HTML+CSS+JS

    `@keyframes snowfall`:定义名为`snowfall`的关键帧动画。 `0%`:动画的起始状态,将元素向上移动到-100%的位置。...`100%`:动画的结束状态,将元素向下移动到视窗高度(100vh)的位置。 10. `.heart`:定义爱心元素的样式。...`position: absolute;`:将伪元素的定位方式设置为绝对定位。 `top: 0;`:将伪元素定位到顶部位置。 12. `#timeElapsed`:显示时间流逝的元素。...`function createSnowflake()`:定义创建雪花的函数。 创建一个`div>`元素作为雪花。 设置 雪花的样式,包括位置、动画持续时间、透明度、字体大小和背景颜色。...`function createSakura()`:定义创建樱花的函数。 创建一个`div>`元素作为樱花。 设置樱花的样式,包括位置和动画延迟时间。 将樱花添加到页面中。

    3.2K20

    CSS学习记录及整理

    CSS三大特性 继承性--给父元素设置的属性,后代元素都可以继承,但仅限于以(color/font-/text-/line)开头的属性。...基础选择器 .class--选中html中类名为class的所有元素 #id--选择id为某值的所有元素 *--通配符,选择所有元素 element--选择某元素,比如p/div/span等 div1,...div2--逗号,并列关系,选中所有列出的元素 div1 div2--空格,下属关系,选中div1内所有的div2元素 div1>div2--大于号,父子关系,选中所有父元素为div1的div2元素 div1...https"] 选择src属性以https开头的所有a元素 [attribute$=value]--以value结尾 [attribute*=value]--包含value 后三个是CSS3的新写法,使用正则表达式来匹配...direction--文本书写方向 letter-spacing--字符间距 line-height--行高,要想使一行文字在box中垂直居中,可以设置行高等于元素框高 text-align--水平对其方式

    6.9K80

    【CSS3】css开篇基础(4)

    注意: 实际开发中,一个页面基本都包含了这三种布局方式 3.浮动 loat 属性用于创建浮动框,将其移动到一边,直到左边缘或右边缘触及包含块或另一个浮动框的边缘。...浮动元素会脱离标准流(脱标) 浮动的元素会一行内显示并且元素顶部对齐 浮动的元素会具有行内块元素的特性 浮动元素会脱离标准流(脱标) 脱离标准普通流的控制(浮) 移动到指定位置(动),(俗称脱标) 浮动的盒子不再保留原先的位置...class="box1">浮动的盒子div> div class="box2">标准流的盒子div> 浮动的元素会一行内显示并且元素顶部对齐 如果多个盒子都设置了浮动...这些方法可以根据具体情况选择,以确保浮动元素不会破坏页面布局。...在设计中,粘性定位常用于创建导航栏在用户滚动时保持在屏幕顶部或侧边的效果,或者创建吸顶效果等。

    6710

    返回顶部的五种实现方法

    -- 很多内容 --> div>返回顶部div> 【2】href指定id 给页面顶部元素设置一个id值,将返回顶部a链接的href属性指向改id属性的元素 div>返回顶部div> 【4】使用简单的JavaScript脚本 设置scrollTo(x,y)中的x和y的坐标值来滚动到页面的具体位置...(jQuery实现) 上面几种方式实现起来比较简单,但是效果生硬,直接从底部切换到顶部,没有一个过渡的动画。...此方法能使页面动态滚动,同时将按钮换成一个箭头标志,判断页面滚动的距离,当页面滚动到一定的距离后再显示返回顶部箭头标志。这样的效果更佳生动。..." alt=""> 36 37 38 function gotoTop(minHeight){ 39 40 // 定义点击返回顶部图标后向上滚动的动画

    5.2K20

    Fabric.js 拖放元素进画布

    本文简介 学习 Fabric.js,我的建议是看文档不如看 demo。 本文实现的功能:将元素拖进到画布中并生成对应的图形或图片。...解4:移动画布我在 《Fabric.js 拖拽平移画布》 里讲解过。 解5:画布的左上角不一定在body的左上角,也就是鼠标当前位置可能和画布对应的坐标不一样,需要通过加减法计算一下。...这里的坐标是指画布在页面中的位置转换出来的坐标,而且还要计算画布拖拽和缩放过的情况。...我的做法是通过 canvas 元素的 getBoundingClientRect() 方法返回的对象中获取到 top 和 left 两个数据。...这两个数据就是 canvas 元素距离页面顶部和左侧的距离。 然后通过鼠标当前坐标减去 canvas 距离页面顶部或左侧的距离,计算出鼠标点击画布的真实坐标。

    3.3K30
    领券