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

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

来源: 责编: 时间:2023-11-22 09:14:36 463观看
导读一、需求分析,问题描述1、需求一个可以滚动的菜单,为它添加一个可以下拉滚动的提示。要求滚动到菜单最底部时,隐藏下拉滚动的提示,否则让其一直显示。2、问题如何实现滚动条效果?如何判断是否滚动到底部?二、解决问题,答案速

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

一、需求分析,问题描述

1、需求

一个可以滚动的菜单,为它添加一个可以下拉滚动的提示。要求滚动到菜单最底部时,隐藏下拉滚动的提示,否则让其一直显示。XfK28资讯网——每日最新资讯28at.com

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

2、问题

  • 如何实现滚动条效果?
  • 如何判断是否滚动到底部?

二、解决问题,答案速览

实现代码如下,复制粘贴即可直接使用。XfK28资讯网——每日最新资讯28at.com

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

// 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;}

三、问题解析,知识总结

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

实现滚动条效果有两种实现方式:利用css的overflow: scroll属性、利用element的el-scrollbar组件。XfK28资讯网——每日最新资讯28at.com

overflow: scroll属性

在div元素上添加 overflow-y: scroll; css属性,就能显示出一个滚动条,如果不指定是x或y轴,则水平和垂直都会出现滚动条。XfK28资讯网——每日最新资讯28at.com

当然,前提是你需要指定div元素的高度或者最大高度。XfK28资讯网——每日最新资讯28at.com

el-scrollbar组件

一般在vue项目中,我们可直接使用element的el-scrollbar组件,因为官方为我们提供了许多API,以及各种适配优化。XfK28资讯网——每日最新资讯28at.com

el-scrollbar组件的属性如下:XfK28资讯网——每日最新资讯28at.com

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

el-scrollbar组件的事件如下:XfK28资讯网——每日最新资讯28at.com

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

el-scrollbar组件的实例属性如下:XfK28资讯网——每日最新资讯28at.com

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

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

这里判断是否滚动到底部的关键在于scrollTop+clientHeight是否等于scrollHeight的值。只有当滚动的距离+可视区域的高度,与scrollHeight相等时,才证明滚动条滚动到了底部。XfK28资讯网——每日最新资讯28at.com

同样的,如果scrollHeight与可视区域的高度直接就相等时,又说明元素不可以滚动,也就没有滚动条。这一点在有此需求时,可以进行实用。XfK28资讯网——每日最新资讯28at.com

元素的几个宽高属性释义如下:XfK28资讯网——每日最新资讯28at.com

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

本文链接:http://www.28at.com/showinfo-26-33355-0.htmlCSS问题:如何实现滚动条的下拉滚动提示效果?

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

上一篇: Go 命名规范:全面指南

下一篇: 12个优秀开源Web性能与用户行为分析工具

标签:
  • 热门焦点
  • 官方承诺:K60至尊版将会首批升级MIUI 15

    全新的MIUI 15今天也有了消息,在官宣了K60至尊版将会搭载天玑9200+处理器和独显芯片X7的同时,Redmi给出了官方承诺,K60至尊重大更新首批升级,会首批推送MIUI 15。也就是说虽然
  • 2023 年的 Node.js 生态系统

    随着技术的不断演进和创新,Node.js 在 2023 年达到了一个新的高度。Node.js 拥有一个庞大的生态系统,可以帮助开发人员更快地实现复杂的应用。本文就来看看 Node.js 最新的生
  • 量化指标是与非:挽救被量化指标扼杀的技术团队

    作者 | 刘新翠整理 | 徐杰承本文整理自快狗打车技术总监刘新翠在WOT2023大会上的主题分享,更多精彩内容及现场PPT,请关注51CTO技术栈公众号,发消息【WOT2023PPT】即可直接领取
  • 三言两语说透柯里化和反柯里化

    JavaScript中的柯里化(Currying)和反柯里化(Uncurrying)是两种很有用的技术,可以帮助我们写出更加优雅、泛用的函数。本文将首先介绍柯里化和反柯里化的概念、实现原理和应用
  • 一篇文章带你了解 CSS 属性选择器

    属性选择器对带有指定属性的 HTML 元素设置样式。可以为拥有指定属性的 HTML 元素设置样式,而不仅限于 class 和 id 属性。一、了解属性选择器CSS属性选择器提供了一种简单而
  • 猿辅导与新东方的两种“归途”

    作者|卓心月 出品|零态LT(ID:LingTai_LT)如何成为一家伟大企业?答案一定是对&ldquo;势&rdquo;的把握,这其中最关键的当属对企业战略的制定,且能够站在未来看现在,即使这其中的
  • 华为开发者大会2023日程公开:开设鸿蒙HarmonyOS 4体验区

    IT之家 7 月 31 日消息,华为今日公布了 HDC.Together 开发者大会 2023 的详细日程。整场大会将于 8 月 4 日-6 日之间举行,届时将发布最新一代鸿蒙 H
  • 2纳米决战2025

    集微网报道 从三强争霸到四雄逐鹿,2nm的厮杀声已然隐约传来。无论是老牌劲旅台积电、三星,还是誓言重回先进制程领先地位的英特尔,甚至初成立不久的新
  • Counterpoint :OPPO双旗舰战略全面落地 高端产品销量增长22%

    2023年6月30日,全球行业分析机构Counterpoint Research发布的《中国智能手机高端市场白皮书》显示,中国智能手机品牌正在寻求高质量发展,中国高端智能
Top