js,jquery滾動(dòng)/跳轉(zhuǎn)頁面到指定位置的實(shí)現(xiàn)思路
要解決兩個(gè)需求:
一個(gè)是從A頁面跳到B頁面,滾動(dòng)到頁面的任何地方;
第二個(gè)是在B頁面內(nèi)部點(diǎn)擊某個(gè)元素,滾動(dòng)到頁面的任何地方;
怎么解決啊?很簡(jiǎn)單,當(dāng)然是用錨點(diǎn)。
首先在A頁面創(chuàng)建一個(gè)錨點(diǎn)
<body>
<a href="b.html#pos" target="_blank">點(diǎn)擊跳轉(zhuǎn)</a>
<body>
然后在B頁面定義這個(gè)錨點(diǎn)
<body>
...
這里是很多文字,把頁面撐開,撐出滾動(dòng)條
...
<a name="pos">滾動(dòng)到這里</a>
...
再加點(diǎn)文字
...
</body>
好,測(cè)試,OK!點(diǎn)過去之后是不是“滾動(dòng)到這里”出現(xiàn)在了瀏覽器的最上方。
實(shí)際的情況經(jīng)常是制作人員切好的頁面,產(chǎn)品突然說要加個(gè)功能,需要滾動(dòng)到某個(gè)地方,但是那個(gè)地方是個(gè)div,并沒有a錨點(diǎn),
創(chuàng)建一個(gè)錨點(diǎn)的話又會(huì)占據(jù)網(wǎng)頁的空間,影響到網(wǎng)頁的版式,這怎么辦呢?我們創(chuàng)建一個(gè)隱藏的錨點(diǎn)試試,隱藏的錨點(diǎn)不占用空間。
繼續(xù):如果我讓B頁面里的 <a name="pos">滾動(dòng)到這里</a> 不顯示,就是設(shè)定display:none; 那么還能滾動(dòng)到這里嗎? 試試
<body>
...
這里是很多文字,把頁面撐開,撐出滾動(dòng)條
...
<a name="pos" style="display:none;">滾動(dòng)到這里</a>
隱藏之后滾動(dòng)到這里
...
再加點(diǎn)文字
...
</body>
不妙,IE可以工作,火狐有點(diǎn)不給面子。
只能換一種思路,給錨點(diǎn)指定一個(gè)id能滾動(dòng)到這里嗎? 試試
<body>
...
這里是很多文字,把頁面撐開,撐出滾動(dòng)條
...
<a id="pos">滾動(dòng)到這里</a>
隱藏之后滾動(dòng)到這里
...
再加點(diǎn)文字
...
</body>
OK,成功!看來換成id是個(gè)好辦法,現(xiàn)在把錨點(diǎn)換成div試試
<body>
...
這里是很多文字,把頁面撐開,撐出滾動(dòng)條
...
<div id="pos">滾動(dòng)到這里</div>
隱藏之后滾動(dòng)到這里
...
再加點(diǎn)文字
...
</body>
OK,成功! 這樣就解決了問題,不需要插入一個(gè)<a></a>錨點(diǎn),只需要給div加一個(gè)id就行了。
接下來解決第二個(gè)需求,在B頁面內(nèi)部點(diǎn)擊某個(gè)元素,滾動(dòng)到指定位置。
首先,在B.html頂部創(chuàng)建一個(gè)錨點(diǎn),指向要滾動(dòng)的那個(gè)div
<body>
<a href="#pos">點(diǎn)擊這里本頁跳轉(zhuǎn)</a>
...
這里是很多文字,把頁面撐開,撐出滾動(dòng)條
...
<div id="pos">滾動(dòng)到這里</div>
隱藏之后滾動(dòng)到這里
...
再加點(diǎn)文字
...
</body>
OK,成功!那如果要點(diǎn)擊一個(gè)button按鈕滾動(dòng)到指定位置呢? button按鈕不能添加href, 只能曲折解決。
先建立一個(gè)隱藏的錨點(diǎn),然后點(diǎn)擊button按鈕的時(shí)候加一個(gè)onclick事件,然后通過js來調(diào)用錨點(diǎn)的click事件,曲線救國(guó)。
<body>
<script type="text/javascript">
function click_scroll() {
document.getElementById("anchor_scroll").click();
}
</script>
<input type="button" value="點(diǎn)擊button跳轉(zhuǎn)" onclick="click_scroll();" />
<a id="anchor_scroll" href="#pos" style="display:none">點(diǎn)擊這里本頁跳轉(zhuǎn)</a>
...
這里是很多文字,把頁面撐開,撐出滾動(dòng)條
...
<div id="pos">滾動(dòng)到這里</div>
隱藏之后滾動(dòng)到這里
...
再加點(diǎn)文字
...
</body>
OK,成功!既然button能夠成功,那其他的也就好辦了,img,div都可以這么做。
還有一個(gè)方法通過jQuery的aminate動(dòng)畫方法也可以做,我貼出代碼
<body>
<script type="text/javascript">
function click_scroll() {
var scroll_offset = $("#pos").offset(); //得到pos這個(gè)div層的offset,包含兩個(gè)值,top和left
$("body,html").animate({
scrollTop:scroll_offset.top //讓body的scrollTop等于pos的top,就實(shí)現(xiàn)了滾動(dòng)
},0);
}
</script>
<input type="button" value="點(diǎn)擊button跳轉(zhuǎn)" onclick="click_scroll();" />...
這里是很多文字,把頁面撐開,撐出滾動(dòng)條
...
<div id="pos">滾動(dòng)到這里</div>
隱藏之后滾動(dòng)到這里
...
再加點(diǎn)文字
...
</body>
OK,成功!這個(gè)方法有個(gè)好處,就是控制滾動(dòng)的速度,上面的藍(lán)色的0就是控制速度的,0是立即的意思,那設(shè)為1000試試,
可以看到是慢慢的滾動(dòng)到了pos,如果設(shè)為5000呢,就會(huì)更慢了。
為什么會(huì)這樣呢?因?yàn)閖Query的animate本來就是做動(dòng)畫用的,更多功能可以詳細(xì)研究了。
- JS實(shí)現(xiàn)判斷滾動(dòng)條滾到頁面底部并執(zhí)行事件的方法
- js監(jiān)聽html頁面的上下滾動(dòng)事件方法
- 當(dāng)滾動(dòng)條滾動(dòng)到頁面底部自動(dòng)加載增加內(nèi)容的js代碼
- js實(shí)現(xiàn)滾動(dòng)條滾動(dòng)到頁面底部繼續(xù)加載
- js判斷滾動(dòng)條是否已到頁面最底部或頂部實(shí)例
- JS和JQUERY獲取頁面大小,滾動(dòng)條位置,元素位置(示例代碼)
- js阻止移動(dòng)端頁面滾動(dòng)的兩種方法
- JS實(shí)現(xiàn)的頁面自定義滾動(dòng)條效果
- js實(shí)現(xiàn)刷新頁面后回到記錄時(shí)滾動(dòng)條的位置【兩種方案可選】
- JavaScript實(shí)現(xiàn)頁面無縫滾動(dòng)效果
相關(guān)文章
淺談js圖片前端預(yù)覽之filereader和window.URL.createObjectURL
下面小編就為大家?guī)硪黄獪\談js圖片前端預(yù)覽之filereader和window.URL.createObjectURL。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06
利用weixin-java-miniapp生成小程序碼并直接返回圖片文件流的方法
這篇文章主要介紹了利用weixin-java-miniapp生成小程序碼并直接返回圖片文件流的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
xmlplus組件設(shè)計(jì)系列之分隔框(DividedBox)(8)
xmlplus 是一個(gè)JavaScript框架,用于快速開發(fā)前后端項(xiàng)目。這篇文章主要介紹了xmlplus布局類組件之分隔框,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05
js 實(shí)現(xiàn)無干擾陰影效果 簡(jiǎn)單好用(附文件下載)
js實(shí)現(xiàn)無干擾陰影效果,簡(jiǎn)單好用,需要的朋友可以參考下。2009-12-12
p5.js 畢達(dá)哥拉斯樹的實(shí)現(xiàn)代碼
這篇文章主要介紹了p5.js 畢達(dá)哥拉斯樹的實(shí)現(xiàn)代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03

