自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

CSS問題:如何實現(xiàn)滾動條的下拉滾動提示效果?

開發(fā) 前端
代碼中滾動條的實現(xiàn)使用了Element的El-scrollbar組件。組件中包裹的第一個Div,指的是需要滾動的視圖。組件中包裹的第二個Div,指的是下拉滾動提示的圖標(biāo),這里根據(jù)需求進(jìn)行設(shè)置,可以更換靜態(tài)的或者那種閃爍跳躍的動態(tài)提示圖標(biāo)。

一、需求分析,問題描述

1、需求

一個可以滾動的菜單,為它添加一個可以下拉滾動的提示。要求滾動到菜單最底部時,隱藏下拉滾動的提示,否則讓其一直顯示。

2、問題

  • 如何實現(xiàn)滾動條效果?
  • 如何判斷是否滾動到底部?

二、解決問題,答案速覽

實現(xiàn)代碼如下,復(fù)制粘貼即可直接使用。

代碼中滾動條的實現(xiàn)使用了element的el-scrollbar組件。組件中包裹的第一個div,指的是需要滾動的視圖。組件中包裹的第二個div,指的是下拉滾動提示的圖標(biāo),這里根據(jù)需求進(jìn)行設(shè)置,可以更換靜態(tài)的或者那種閃爍跳躍的動態(tài)提示圖標(biāo)。

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

三、問題解析,知識總結(jié)

1、如何實現(xiàn)滾動條效果?

實現(xiàn)滾動條效果有兩種實現(xiàn)方式:利用css的overflow: scroll屬性、利用element的el-scrollbar組件。

overflow: scroll屬性

在div元素上添加 overflow-y: scroll; css屬性,就能顯示出一個滾動條,如果不指定是x或y軸,則水平和垂直都會出現(xiàn)滾動條。

當(dāng)然,前提是你需要指定div元素的高度或者最大高度。

el-scrollbar組件

一般在vue項目中,我們可直接使用element的el-scrollbar組件,因為官方為我們提供了許多API,以及各種適配優(yōu)化。

el-scrollbar組件的屬性如下:

el-scrollbar組件的事件如下:

el-scrollbar組件的實例屬性如下:

2、如何判斷是否滾動到底部?

這里判斷是否滾動到底部的關(guān)鍵在于scrollTop+clientHeight是否等于scrollHeight的值。只有當(dāng)滾動的距離+可視區(qū)域的高度,與scrollHeight相等時,才證明滾動條滾動到了底部。

同樣的,如果scrollHeight與可視區(qū)域的高度直接就相等時,又說明元素不可以滾動,也就沒有滾動條。這一點在有此需求時,可以進(jìn)行實用。

元素的幾個寬高屬性釋義如下:

責(zé)任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2024-01-22 09:28:23

CSS前端滾動驅(qū)動

2010-09-09 11:25:55

滾動條CSS

2011-09-02 10:03:40

jQuery滾動圖片

2011-05-12 16:30:44

自定義滾動條

2011-09-01 13:17:46

JQuery滾動

2022-08-15 19:23:24

macOS?Windows容器

2010-07-28 11:25:08

Flex滾動條

2010-09-14 10:13:53

DIV滾動條

2023-09-11 09:07:58

CSS隱藏滾動條

2010-09-30 15:24:31

滾動條Javascript

2014-07-29 11:10:26

Ubuntu14.04小技巧

2010-09-09 09:47:02

DIV滾動條

2024-05-28 09:21:25

2010-09-30 15:37:29

ScrollBarJavascrip

2010-08-09 15:19:29

Flex滾動條

2011-03-04 14:46:40

Ubuntu Unit

2022-10-31 19:10:39

CSS元素focus

2011-09-02 10:14:10

JQuery滾動Xslider

2021-07-05 07:49:14

CSS自定義滾動條CSS技巧

2023-11-01 10:14:02

前端CSS屬性
點贊
收藏

51CTO技術(shù)棧公眾號