ホームページ >ウェブフロントエンド >jsチュートリアル >スクロールバーがbottom_javascriptスキルに到達したかどうかを判断するJSコード
スクロール バーが一番下に達するかどうかを判断するには、DOM の 3 つの属性値、つまり、scrollTop、clientHeight、scrollHeight を使用する必要があります。
scrollTop は、Y 軸上のスクロール バーのスクロール距離です。
clientHeight は、コンテンツの表示領域の高さです。
ScrollHeight は、コンテンツの表示領域の高さにオーバーフロー (スクロール) 距離を加えたものです。
これら 3 つの属性の導入からわかるように、スクロール バーが一番下に到達する条件は、scrollTop clientHeight ==scrollHeight です。
早速、コードをアップロードしてみましょう (さまざまなブラウザーと互換性があります)。
関数 getScrollTop(){
varscrollTop = 0, bodyScrollTop = 0, documentScrollTop = 0;
if(document.body){
bodyScrollTop = document.body.scrollTop;
}
if(document.documentElement){
documentScrollTop = document.documentElement.scrollTop;
}
scrollTop = (bodyScrollTop - documentScrollTop > 0) : documentScrollTop;
returnscrollTop;
}
//ドキュメントの合計の高さ
関数 getScrollHeight(){
varscrollHeight = 0, bodyScrollHeight = 0, documentScrollHeight = 0;
if(document.body){
bodyScrollHeight = document.body.scrollHeight;
}
if(document.documentElement){
documentScrollHeight = document.documentElement.scrollHeight;
}
スクロールハイト = (bodyScrollHeight - documentScrollHeight > 0) : documentScrollHeight;
returnscrollHeight;
}
//ブラウザのビューポートの高さ
function getWindowHeight(){
var windowHeight = 0;
if(document.compatMode == "CSS1Compat"){
windowHeight = document.documentElement.clientHeight;
}else{
windowHeight = document.body.clientHeight;
}
return windowHeight;
}
window.onscroll = function(){
if(getScrollTop() getWindowHeight() == getScrollHeight()){
alert("あなたは最下位です!");
}
};