js 原生判斷內(nèi)容區(qū)域是否滾動(dòng)到底部的實(shí)例代碼
邏輯
判斷內(nèi)容滾動(dòng)到底需要知道的信息
內(nèi)容區(qū)域的真實(shí)高度(也就是滾動(dòng)區(qū)域)
滾動(dòng)條距離頂部的位置
內(nèi)容區(qū)域的可見(jiàn)高度
分別對(duì)應(yīng)下面的三個(gè)API。
element.scrollHeight 獲取元素內(nèi)容高度,,,【只讀屬性】
element.scrollTop 可以獲取或者設(shè)置元素的偏移值,常用于,計(jì)算滾動(dòng)條的位置,當(dāng)一個(gè)元素的容器沒(méi)有產(chǎn)生垂直方向的滾動(dòng)條,那它的 scrollTop 的值默認(rèn)為0.
element.clientHeight 讀取元素的可見(jiàn)高度【只讀屬性】
下面直接引用MDN上面的一個(gè)經(jīng)典的公式
判定元素是否滾動(dòng)到底
如果元素滾動(dòng)到底,下面等式返回true,沒(méi)有則返回false.
element.scrollHeight - element.scrollTop === element.clientHeight
案例-用戶(hù)使用協(xié)議
只有等用戶(hù)閱讀完協(xié)議才可以點(diǎn)擊同意,也就是說(shuō)滾動(dòng)條到底部之后代表完成閱讀
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>tab</title>
<style>
textarea{height: 200px;width: 300px}
</style>
</head>
<body>
<p>
<textarea>
用戶(hù)咨詢(xún)條款
一、咨詢(xún)系統(tǒng)提供的服務(wù)
1、本網(wǎng)站咨詢(xún)系統(tǒng)(以下簡(jiǎn)稱(chēng)“本系統(tǒng)”)為用戶(hù)提供參與各種咨詢(xún)項(xiàng)目(以下簡(jiǎn)稱(chēng)“項(xiàng)目”)的機(jī)會(huì)。用戶(hù)在包之網(wǎng)上注冊(cè)成為會(huì)員,并可申請(qǐng)某一專(zhuān)家會(huì)員通過(guò)包之網(wǎng)平臺(tái)及電話(huà)等方式為其提供咨詢(xún)服務(wù)。
2、您應(yīng)按照您想要咨詢(xún)的專(zhuān)家其所對(duì)應(yīng)的專(zhuān)家收費(fèi)金額,根據(jù)您希望互動(dòng)/通話(huà)時(shí)間的長(zhǎng)短,預(yù)先存入咨詢(xún)費(fèi)用,方可進(jìn)行預(yù)約、咨詢(xún)。咨詢(xún)完成后,剩余的款項(xiàng)將在15個(gè)工作日內(nèi)直接退還給您。您應(yīng)提供詳細(xì)的收款信息,否則本網(wǎng)站不承擔(dān)任何責(zé)任。提請(qǐng)您注意,若預(yù)存金額過(guò)低,可能導(dǎo)致咨詢(xún)中斷。咨詢(xún)費(fèi)用根據(jù)本網(wǎng)站標(biāo)準(zhǔn)的專(zhuān)家收費(fèi)金額及實(shí)際通話(huà)時(shí)間進(jìn)行計(jì)算。您同意因銀行處理本網(wǎng)站對(duì)您的每一筆付款所產(chǎn)生的全部費(fèi)用將由您自行承擔(dān)。
3、如果您對(duì)專(zhuān)家的工作內(nèi)容或提供咨詢(xún)服務(wù)質(zhì)量等有異議,則在此等爭(zhēng)議完全解決之前,本網(wǎng)站將扣留應(yīng)付給您的款項(xiàng)。
4、如果您需要發(fā)票,應(yīng)直接向提供咨詢(xún)的專(zhuān)家要求,本網(wǎng)站不提供任何發(fā)票。
5、專(zhuān)家收費(fèi)詳見(jiàn)本網(wǎng)站不時(shí)發(fā)布的專(zhuān)家收費(fèi)金額。專(zhuān)家收費(fèi)金額及其修改均為本條款不可分割的組成部分,請(qǐng)您申請(qǐng)前仔細(xì)查看。
6、本網(wǎng)站根據(jù)實(shí)際情況盡可能根據(jù)您的要求、申請(qǐng)與專(zhuān)家進(jìn)行匹配, 但專(zhuān)家有權(quán)不予提供服務(wù)。
</textarea>
</p>
<p>
<input type="checkbox" value="1" disabled="disabled"> 同意
</p>
<script>
//獲取checkbox元素
var checkbox=document.querySelector('input[type=checkbox]');
document.querySelector('textarea').addEventListener('scroll',function () {
//讀取內(nèi)容區(qū)域的真實(shí)高度(滾動(dòng)條高)
// console.log(this.scrollHeight);
//讀取滾動(dòng)條的位置
// console.log(this.scrollTop);
//設(shè)置滾動(dòng)到的位置
// this.scrollTop=800;
//讀取元素的高度
// console.log(this.clientHeight)
//意思就是內(nèi)容總體的高度 - 滾動(dòng)條的偏移值 === 元素的高度(包含內(nèi)邊)但不包含外邊距,邊框,以及滾動(dòng)條
if(this.scrollHeight-this.scrollTop===this.clientHeight){
console.log("到達(dá)底部");
//移除disabled屬性
checkbox.removeAttribute('disabled')
}
})
</script>
</body>
</html>
好吧,今天突然 看到mdn上面的這個(gè)API。腦補(bǔ)了一下
Element.scrollTop
以上這篇js 原生判斷內(nèi)容區(qū)域是否滾動(dòng)到底部的實(shí)例代碼就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
extjs中form與grid交互數(shù)據(jù)(record)的方法
這篇文章介紹了extjs中form與grid交互數(shù)據(jù)(record)的方法,有需要的朋友可以參考一下2013-08-08
js面向?qū)ο缶幊讨绾螌?shí)現(xiàn)方法重載
如何實(shí)現(xiàn)方法重載,涉及到三個(gè)問(wèn)題:同名函數(shù)的調(diào)用、函數(shù)中特殊的參數(shù)arguments、如何利用arguments實(shí)現(xiàn)方法重載,需要的朋友可以參考下2014-07-07
Javascript表達(dá)式中連續(xù)的 && 和 || 之賦值區(qū)別
了區(qū)分賦值表達(dá)式中出現(xiàn)的連續(xù)的 ‘&&’和 ‘||’的不同的賦值含義,做了一個(gè)小測(cè)試.2010-10-10
JS?簡(jiǎn)單實(shí)現(xiàn)拖拽評(píng)星的示例代碼
本文主要介紹了JS?簡(jiǎn)單實(shí)現(xiàn)拖拽評(píng)星,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
Perl Substr()函數(shù)及函數(shù)的應(yīng)用
這篇文章主要介紹了Perl Substr()函數(shù)及函數(shù)的應(yīng)用,需要的朋友可以參考下2015-12-12
javascript add event remove event
javascript事件綁定和刪除功能代碼2008-04-04

