js錨點(diǎn)、操作滾動(dòng)條滑動(dòng)scroll代碼演示
一、前提說明
錨點(diǎn)作用:在長文檔中常見,點(diǎn)擊錨點(diǎn),讓頁面上下滑動(dòng)定位到某個(gè)想定位的位置,這個(gè)想定位的位置就被稱為錨點(diǎn)。
適用場(chǎng)景:長文檔。例如目錄(差不多這個(gè)意思,好理解),點(diǎn)擊對(duì)應(yīng)目錄,該目錄下面的內(nèi)容展示在文檔可視范圍。
目的:觸發(fā)點(diǎn)擊等事件時(shí),頁面可視區(qū)域能夠展示我想看到的內(nèi)容,以下代碼就是為了解決這個(gè)問題??
辦法:
a.<a>標(biāo)簽定義錨點(diǎn);
b. element.documentElement.scrollTop = number,設(shè)置元素的滾動(dòng)距離使得頁面處于某個(gè)位置;
c. window.scrollTo({}),直接操作頁面滾動(dòng);
d. element.scrollIntoView({}),讓element展示在頁面可視區(qū)域。
二、代碼演示
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>043-滾動(dòng)條滑倒最頂端</title>
<style>
* {
scroll-behavior: smooth;
}
.box {
background: rgb(171, 214, 200);
width: 300px;
height: 3000px;
}
.box1 {
background: rgb(243, 161, 179);
}
</style>
</head>
<body>
<div id="app">
<div class="box box1"></div>
<a href="#btn-to-top" rel="external nofollow" >超鏈接至下面??</a>
<button id="btn-to-bottom" type="button">去下面??</button>
<div class="box"></div>
<button id="btn-to-top" type="button">去上面??</button>
<a href="#btn-to-bottom" rel="external nofollow" >超鏈接至上面??</a>
</div>
<script type="text/javascript">
// 獲取元素
const btnToBottom = document.getElementById('btn-to-bottom')
const btnToTop = document.getElementById('btn-to-top')
// 方式1:html頁面中的<a>元素已經(jīng)設(shè)置了錨點(diǎn),點(diǎn)擊a元素可以平滑的滾動(dòng)到對(duì)應(yīng)的href中
// 例如:【超鏈接至下面??】點(diǎn)擊超鏈接,就會(huì)平滑的滑動(dòng)到【去上面??】button展示在可視區(qū)域的最頂端(由于頁面高度和滾動(dòng)條長度原因,只能展示在頁面底端)
// 讓滾動(dòng)條回到最底端??
btnToBottom.addEventListener('click', function () {
// 方式2:滾動(dòng)到頁面最底端、配合上面的*css可以有動(dòng)畫,否則無動(dòng)畫
document.documentElement.scrollTop = document.body.scrollHeight
// 方式3:滾動(dòng)到頁面最底端、有動(dòng)畫
// 'smooth'平滑滾動(dòng)、'instant'瞬息、'auto'有css則按照css來(例如上面的*css樣式),否則就是instant
window.scrollTo({
top: document.body.scrollHeight,
behavior: 'auto',
})
// 方式4:讓btn2滾動(dòng)到可視頁面最頂端、無動(dòng)畫
// 'smooth'平滑滾動(dòng)、'instant'瞬息、'auto'有css則按照css來,否則就是instant
// 'start'表示btn2展示在可視區(qū)域最頂端、'end'表示btn2展示在可是區(qū)域最底端
btnToTop.scrollIntoView({ behavior: 'instant', block: 'end' })
})
// 讓滾動(dòng)條回到最頂端??
btnToTop.addEventListener('click', function () {
// 方式2
document.documentElement.scrollTop = 0
// 方式3
window.scrollTo({
top: 0,
behavior: 'smooth',
})
// 方式4
btnToBottom.scrollIntoView({ behavior: 'instant', block: 'end' })
})
</script>
</body>
</html>
三、gif動(dòng)圖演示
自己可cv代碼去瀏覽器演示,點(diǎn)擊回到最頂端,同理可得:

總結(jié)
到此這篇關(guān)于js錨點(diǎn)、操作滾動(dòng)條滑動(dòng)scroll的文章就介紹到這了,更多相關(guān)js錨點(diǎn)、操作滾動(dòng)條滑動(dòng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
一個(gè)簡(jiǎn)單的JS時(shí)間控件示例代碼(JS時(shí)分秒時(shí)間控件)
這篇文章主要介紹了一個(gè)簡(jiǎn)單的JS時(shí)間控件示例代碼(JS時(shí)分秒時(shí)間控件)。需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-11-11
js監(jiān)聽鍵盤事件的方法_原生和jquery的區(qū)別詳解
下面小編就為大家?guī)硪黄猨s監(jiān)聽鍵盤事件的方法_原生和jquery的區(qū)別詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10
利用谷歌地圖API獲取點(diǎn)與點(diǎn)的距離的js代碼
下面是一段利用谷歌地圖API獲取點(diǎn)點(diǎn)之間距離的代碼,采用V3版本中的DirectionsService()2012-10-10
微信小程序scroll-view實(shí)現(xiàn)左右聯(lián)動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了微信小程序scroll-view實(shí)現(xiàn)左右聯(lián)動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
js實(shí)現(xiàn)屏幕自適應(yīng)局部代碼分享
這篇文章主要介紹了js實(shí)現(xiàn)屏幕自適應(yīng)局部代碼分享,需要的朋友可以參考下2015-01-01

