CSS问题:如何实现滚动条的下拉滚动提示效果?

CSS问题:如何实现滚动条的下拉滚动提示效果?笔者 大澈大家好 我是大澈 又是好久没更文了 前阵子驾着新车回了趟老家 很 幸运 的经历了平原县地震的余波 回想当时 半夜凌晨 房屋晃动 如同身处过山车 一切都很不真实 虽然震感时间很短暂 但是现在依旧让我记忆犹新 人类在大自然面前真的

大家好,欢迎来到IT知识分享网。

CSS问题:如何实现滚动条的下拉滚动提示效果?

笔者 | 大澈

大家好,我是大澈!

又是好久没更文了,前阵子驾着新车回了趟老家,很“幸运”的经历了平原县地震的余波。

回想当时,半夜凌晨,房屋晃动,如同身处过山车,一切都很不真实。虽然震感时间很短暂,但是现在依旧让我记忆犹新,人类在大自然面前真的是太渺小了,很多时候真的是力不从心。

所以,真心想和大家说一句,生活不易,及时行乐,珍惜身边人,且行且珍惜。

ONE

需求分析,问题描述

一、需求

一个可以滚动的菜单,为它添加一个可以下拉滚动的提示。要求滚动到菜单最底部时,隐藏下拉滚动的提示,否则让其一直显示。

CSS问题:如何实现滚动条的下拉滚动提示效果?

二、问题

1、如何实现滚动条效果?

2、如何判断是否滚动到底部?

TWO

解决问题,答案速览

实现代码如下,复制粘贴即可直接使用。

代码中滚动条的实现使用了element的el-scrollbar组件。组件中包裹的第一个div,指的是需要滚动的视图。组件中包裹的第二个div,指的是下拉滚动提示的图标,这里根据需求进行设置,可以更换静态的或者那种闪烁跳跃的动态提示图标。

// 1、模版 <el-scrollbar max-height="calc(100vh - 84px)" @scroll="handleScroll" ref="myScrollbar"> <div class="sideBarIn"></div> <div class="pcSign pcIcon" v-if="isShowIcon"> <img class="iconImg" src="../assets/images/common/xiaGery.png"></div> </el-scrollbar> // 2、逻辑 // 滚动条事件 const handleScroll = (val) => { // 防止Scrollbar实例为空 if (!myScrollbar.value) { return } // 判断是否滚动到底部 let isScrollToEnd = Number(myScrollbar.value.wrapRef.scrollTop.toFixed(0)) + Number(myScrollbar.value.wrapRef.clientHeight.toFixed(0)) === Number(myScrollbar.value.wrapRef.scrollHeight.toFixed(0)); if (isScrollToEnd) { // 滚动到底部的处理逻辑 isShowIcon.value = false } else { // 非滚动到底部的处理逻辑 isShowIcon.value = true } } // 3、样式 .pcIcon { width:100%; height: 100px; position: absolute; bottom: -4px; left: 0; text-align: center; line-height: 130px; background: linear-gradient(to bottom, rgba(234, 234, 234, 0.5), rgba(234, 234, 234, 1)); .iconImg { width: 20px; height: 20px; } } .pcSign{ display: block; }

THREE

问题解析,知识总结

一、如何实现滚动条效果?

实现滚动条效果有两种实现方式:利用css的overflow: scroll属性、利用element的el-scrollbar组件。

1、overflow: scroll属性

在div元素上添加 overflow-y: scroll; css属性,就能显示出一个滚动条,如果不指定是x或y轴,则水平和垂直都会出现滚动条。

当然,前提是你需要指定div元素的高度或者最大高度。

2、el-scrollbar组件

一般在vue项目中,我们可直接使用element的el-scrollbar组件,因为官方为我们提供了许多API,以及各种适配优化。

el-scrollbar组件的属性如下:

CSS问题:如何实现滚动条的下拉滚动提示效果?

el-scrollbar组件的事件如下:

CSS问题:如何实现滚动条的下拉滚动提示效果?

el-scrollbar组件的实例属性如下:

CSS问题:如何实现滚动条的下拉滚动提示效果?

二、如何判断是否滚动到底部?

这里判断是否滚动到底部的关键在于scrollTop+clientHeight是否等于scrollHeight的值。只有当滚动的距离+可视区域的高度,与scrollHeight相等时,才证明滚动条滚动到了底部。

同样的,如果scrollHeight与可视区域的高度直接就相等时,又说明元素不可以滚动,也就没有滚动条。这一点在有此需求时,可以进行实用。

元素的几个宽高属性释义如下:

CSS问题:如何实现滚动条的下拉滚动提示效果?

– END –

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/108133.html

(0)
上一篇 2024-11-05 07:15
下一篇 2024-11-12 20:33

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信