当前位置:首页 > 科技  > 软件

CSS 滚动驱动动画实现圆弧滚动条

来源: 责编: 时间:2024-01-22 17:25:38 391观看
导读前不久看到这样一个很有趣的效果,它的滚动条是沿着圆角边缘滚动的,效果如下你可以查看原链接来体验一下https://codepen.io/jh3y/pen/gOEgxbd。
这是如何实现的呢?原效果中由于为了兼容不支持CSS滚动驱动的浏览器,特意用

ryQ28资讯网——每日最新资讯28at.com

前不久看到这样一个很有趣的效果,它的滚动条是沿着圆角边缘滚动的,效果如下ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

你可以查看原链接来体验一下ryQ28资讯网——每日最新资讯28at.com

https://codepen.io/jh3y/pen/gOEgxbd。ryQ28资讯网——每日最新资讯28at.com


ryQ28资讯网——每日最新资讯28at.com

这是如何实现的呢?ryQ28资讯网——每日最新资讯28at.com

原效果中由于为了兼容不支持CSS滚动驱动的浏览器,特意用 JS做了兼容,所以看着比较复杂,其实核心非常简单,下面我将用最简短的 CSS 来复刻这一效果,一起看看吧!ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

一、SVG 路径动画

从本质上来讲,其实是一个 SVG 路径动画。ryQ28资讯网——每日最新资讯28at.com

具体如何实现呢?ryQ28资讯网——每日最新资讯28at.com

首先,我们通过设计软件绘制一个这样的路径。ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

注意设置描边的大小还有端点的类型,比如下面是round效果。ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

然后导出SVG,可以得到这样一段代码。ryQ28资讯网——每日最新资讯28at.com

<svg viewBox="0 0 31 433" fill="none" xmlns="http://www.w3.org/2000/svg">  <path d="M4 4C9.96737 4 15.6903 6.37053 19.9099 10.5901C24.1295 14.8097 26.5 20.5326 26.5 26.5V406.5C26.5 412.467 24.1295 418.19 19.9099 422.41C15.6903 426.629 9.96737 429 4 429" stroke="black" stroke-width="8" stroke-linecap="round" stroke-linejoin="round"/></svg>

然后,如何让这段SVG动起来呢?ryQ28资讯网——每日最新资讯28at.com

很简单,现在SVG是一段实线,我们可以通过stroke-dasharray设置成虚线,比如:ryQ28资讯网——每日最新资讯28at.com

path{  stroke-dasharray: 80}

这样会得到一个实线和虚线间隔都是80的虚线。ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

如果希望虚线空白的地方更大一点,该怎么设置呢?很简单,继续往后加。ryQ28资讯网——每日最新资讯28at.com

path{  stroke-dasharray: 80 120}

效果如下:ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

所以,这种写法其实相当于把当前的值无限重复,示意如下:ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

当然,我们这里不需要设置的这么复杂,只需要一小段实线就够了,所以是实现加上一段足够长的虚线(超过路径本身就行),实现如下:ryQ28资讯网——每日最新资讯28at.com

path{  stroke-dasharray: 80 1000}

这样就得到了一小段实线。ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

那么,如何让他动起来呢?很简单,改变一下偏移就可以,这个可以用stroke-dashoffset来实现。ryQ28资讯网——每日最新资讯28at.com

比如:ryQ28资讯网——每日最新资讯28at.com

@keyframes scroll {  to {    stroke-dashoffset: -370	}}path{  stroke-dasharray: 80 1000;  animation: scroll 3s alternate-reverse infinite;}

效果如下:ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

是不是有点像呢?ryQ28资讯网——每日最新资讯28at.com

我们再调整一下起始偏移量,让它出去一点。ryQ28资讯网——每日最新资讯28at.com

@keyframes scroll {  0% { stroke-dashoffset: 75; }  100% { stroke-dashoffset: -445; }}

这样就更接近我们想要的效果了。ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

整个运动原理就是这样了,接着往下看ryQ28资讯网——每日最新资讯28at.com

二、CSS 滚动驱动动画

接下来需要通过滚动驱动动画将容器滚动与CSS动画「联动」起来。ryQ28资讯网——每日最新资讯28at.com

简单来讲,「CSS 滚动驱动动画」指的是将「动画的执行过程由页面滚动」进行接管,也就是这种情况下,「动画只会跟随页面滚动的变化而变化」,也就是滚动多少,动画就执行多少,「时间不再起作用」。ryQ28资讯网——每日最新资讯28at.com

先简单布局一下:ryQ28资讯网——每日最新资讯28at.com

<div class="list">  <div class="item" id="item_1">1</div>  <div class="item" id="item_2">2</div>  <div class="item" id="item_3">3</div>  <div class="item" id="item_4">4</div>  <div class="item" id="item_5">5</div>  <div class="item" id="item_6">6</div>  <div class="item" id="item_7">7</div></div>

美化一下:ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

然后,我们将默认的滚动条隐藏,用我们这个 SVG路径来代替,由于需要绝对定位,我们再套一层父级。ryQ28资讯网——每日最新资讯28at.com

<div class="wrap">  <div class="list">    <div class="item" id="item_1">1</div>    <div class="item" id="item_2">2</div>    <div class="item" id="item_3">3</div>    <div class="item" id="item_4">4</div>    <div class="item" id="item_5">5</div>    <div class="item" id="item_6">6</div>    <div class="item" id="item_7">7</div>    <!--滚动条-->    <svg class="scroller" viewBox="0 0 31 433" fill="none" xmlns="http://www.w3.org/2000/svg">      <path class="scroller_thumb" d="M4 4C9.96737 4 15.6903 6.37053 19.9099 10.5901C24.1295 14.8097 26.5 20.5326 26.5 26.5V406.5C26.5 412.467 24.1295 418.19 19.9099 422.41C15.6903 426.629 9.96737 429 4 429" stroke="black" stroke-width="8" stroke-linecap="round" stroke-linejoin="round"/>    </svg>  </div></div>

相关CSS如下:ryQ28资讯网——每日最新资讯28at.com

.wrap{  position: relative;}.scroller {  position: absolute;  top: 0;  bottom: 0;  right: 0;  pointer-events: none;  height: -webkit-fill-available;  margin: 5px;}.scroller_thumb{  stroke: hsl(0 0% 100% / 0.5);  stroke-dasharray: 80 450;  stroke-width: 8px;  animation: scroll both 5s linear;}

这样结构就搭好了,只是滚动条会自动播放。ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

接下来就是最关键的一步,加上滚动驱动动画。ryQ28资讯网——每日最新资讯28at.com

.scroller_thumb{  animation: scroll both 5s linear;  animation-timeline: scroll();}

但是这样是不起作用的,直接使用scroll()会自动寻找它的相对父级,也就是.wrap,但实际滚动的其实是.list,所以这种情况下我们需要具名的滚动时间线,实现如下:ryQ28资讯网——每日最新资讯28at.com

.list{  scroll-timeline: --scroller;}.scroller_thumb{  animation: scroll both 5s linear;  animation-timeline: --scroller;}

这样SVG路径动画就能跟随容器滚动而运动了。ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

三、CSS 滚动吸附

原效果中还有一个滚动回弹的效果,当滚动到容器边缘时,会自动回弹到起始位置。ryQ28资讯网——每日最新资讯28at.com

其实只需要用到 CSS scroll snap 就可以了。ryQ28资讯网——每日最新资讯28at.com

https://developer.mozilla.org/zh-CN/docs/Web/CSS/scroll-snap-type。ryQ28资讯网——每日最新资讯28at.com

实现很简单,给滚动容器添加scroll-snap-type属性,表示这是个允许滚动吸附的容器。ryQ28资讯网——每日最新资讯28at.com

.list{  scroll-snap-type: y mandatory;}

然后就指定需要吸附的点了,由于需要回弹的效果,所以滚动容器的首尾需要一个空白的容器,这里直接用两个伪元素来生成ryQ28资讯网——每日最新资讯28at.com

.list::before,.list::after{  content: '';  height: 50px;  flex-shrink: 0;}

效果如下:ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

然后我们设置滚动吸附点就行了,设置第一个元素顶部和最后一个元素底部,其他元素居中就行了。ryQ28资讯网——每日最新资讯28at.com

.item{  scroll-snap-align: center;}.item:first-child{  scroll-snap-align: start;}/*最后一个元素是 SVG,所以这里用倒数第二个元素*/.item:nth-last-child(2){  scroll-snap-align: end;}

这样就实现了文章开头的效果了。ryQ28资讯网——每日最新资讯28at.com

ryQ28资讯网——每日最新资讯28at.com

完整代码可以查看以下链接(无任何 JS)ryQ28资讯网——每日最新资讯28at.com

  • CSS round scroll (juejin.cn)[1]
  • CSS round scroll (codepen.io)[2]

四、总结一下

总的来说,CSS滚动驱动在滚动交互上带来了无限可能,很多以前必须借助 JS来实现的都可以轻易实现,下面总结一下。ryQ28资讯网——每日最新资讯28at.com

  • 从本质上来讲,右侧的滚动条其实是一个 SVG 路径动画。
  • SVG路径可以通过stroke-dasharray设置虚实间隔。
  • 当虚线间隔足够长时,超过路径本身,就能得到一小块实线。
  • 通过改变stroke-dashoffset偏移能够实现路径描边动画。
  • 借助 CSS滚动驱动动画可以将SVG路径动画跟随容器滚动而运动。
  • 滚动回弹效果其实就是CSS scroll snap实现的。

[1]CSS round scroll (juejin.cn): https://code.juejin.cn/pen/7326425332964130856。ryQ28资讯网——每日最新资讯28at.com

[2]CSS round scroll (codepen.io): https://codepen.io/xboxyan/pen/WNmjZLo。ryQ28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-66203-0.htmlCSS 滚动驱动动画实现圆弧滚动条

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 厉害,美国人又搞了一个垄断的生态系统

下一篇: 【故障现场】多线程性能优化最大的坑,99%人都不自知

标签:
  • 热门焦点
  • K60 Pro官方停产 第三方瞬间涨价

    虽然没有官方宣布,但Redmi的一些高管也已经透露了,Redmi K60 Pro已经停产且不会补货,这一切都是为了即将到来的K60 Ultra铺路,属于厂家的正常操作。但有意思的是该机在停产之后
  • 5月iOS设备好评榜:iPhone 14仅排第43?

    来到新的一月,安兔兔的各个榜单又重新汇总了数据,像安卓阵营的榜单都有着比较大的变动,不过iOS由于设备的更新换代并没有那么快,所以相对来说变化并不大,特别是iOS好评榜,老款设
  • 轿车从天而降电动车主被撞身亡 超速抢道所致:现场视频让网友吵翻

    近日,上海青浦区法院判决轿车从天而降电动车主被撞身亡案,轿车车主被判有期徒刑一年。案件显示当时男子驾驶轿车在上海某路段行驶,前车忽然转弯提速超车,
  • 摸鱼心法第一章——和配置文件说拜拜

    为了能摸鱼我们团队做了容器化,但是带来的问题是服务配置文件很麻烦,然后大家在群里进行了“亲切友好”的沟通图片图片图片图片对比就对比,简单对比下独立配置中心和k8s作为配
  • 十个简单但很有用的Python装饰器

    装饰器(Decorators)是Python中一种强大而灵活的功能,用于修改或增强函数或类的行为。装饰器本质上是一个函数,它接受另一个函数或类作为参数,并返回一个新的函数或类。它们通常用
  • 梁柱接棒两年,腾讯音乐闯出新路子

    文丨田静 出品丨牛刀财经(niudaocaijing)7月5日,企鹅FM发布官方公告称由于业务调整,将于9月6日正式停止运营,这意味着腾讯音乐长音频业务走向消亡。腾讯在长音频领域还在摸索。为
  • 花7万退货退款无门:谁在纵容淘宝珠宝商家造假?

    来源:极点商业作者:杨铭在淘宝购买珠宝玉石后,因为保证金不够赔付,店铺关闭,退货退款难、维权无门的比比皆是。&ldquo;提供相关产品鉴定证书,支持全国复检,可以30天无理由退换货。&
  • 疑似小米14外观设计图曝光:后置相机模组变化不大

    下半年的大幕已经开启,而谁将成为下半年手机圈的主角就成为了大家关注的焦点,其中被传有望拿下新一代骁龙8 Gen3旗舰芯片的小米14系列更是备受大家瞩
  • 国行版三星Galaxy Z Fold5/Z Flip5发布 售价7499元起

    2023年8月3日,三星电子举行Galaxy新品中国发布会,正式在国内推出了新一代折叠屏智能手机三星Galaxy Z Fold5与Galaxy Z Flip5,以及三星Galaxy Tab S9
Top