av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

vue頁(yè)面設(shè)置滾動(dòng)失敗的完美解決方案(scrollTop一直為0)

瀏覽:136日期:2022-06-09 17:29:30
目錄
  • vue頁(yè)面設(shè)置滾動(dòng)失敗的解決方案(scrollTop一直為0)
    • 背景
    • 誤區(qū):
    • 什么時(shí)候存在滾動(dòng)條?
    • Why scrollTop==0?
    • 如何判斷頁(yè)面的滾動(dòng)條是哪個(gè)div產(chǎn)生的?

vue頁(yè)面設(shè)置滾動(dòng)失敗的解決方案(scrollTop一直為0)

背景

希望頁(yè)面能跳轉(zhuǎn)到 某一位置用到了scrollTop屬性。可是發(fā)現(xiàn)給某個(gè)div設(shè)置該屬性后,一致為0。找了很多方案,但不都適合自己,或者說(shuō)不知道是否適合。

怎么看我這個(gè)方法適不適合你,你可以嘗試打印滾動(dòng)條的位置,頁(yè)面滾動(dòng)后,再次打印滾動(dòng)條的位置,如果一直為0的話,那我的的這個(gè)方法就可以解決你遇到的問題(說(shuō)明你可能一直在打印窗口的滾動(dòng),而不是你真正需要控制滾動(dòng)的那個(gè)元素).

誤區(qū):

并不是一股腦設(shè)置window.scrollTop就可以讓頁(yè)面滾動(dòng)的,scrollTop可以用來(lái)設(shè)置滾動(dòng)條位置,但是你得找對(duì)元素,在路由嵌套的vue頁(yè)面中,window可能始終是沒有滾動(dòng)的,而你頁(yè)面上顯示的滾動(dòng)條也只是頁(yè)面中的元素的滾動(dòng)條.

什么時(shí)候存在滾動(dòng)條?

頁(yè)面布局我們可以簡(jiǎn)單理解為 div盒子套div盒子。當(dāng)內(nèi)側(cè)div盒子的高度大于外部時(shí),外部的div就會(huì)出現(xiàn)滾動(dòng)條。此時(shí)外部的div才具備scrollTop屬性,否則你無(wú)論如何設(shè)置都為0. 這里隱藏了一些條件:

外部的div一定有高度,否則外部div將和內(nèi)部div高度一致,不滿足大于條件,所以不會(huì)出現(xiàn)滾動(dòng)條。 外部div的 overflow:auto。hidden的情況下超出的部分被隱藏,無(wú)法出現(xiàn)滾動(dòng)條。 如果想設(shè)置滾動(dòng)條屬性,一定要知道滾動(dòng)條是哪個(gè)div產(chǎn)生的。

Why scrollTop==0?

總而言之,所有情況都是因?yàn)槟憬o一個(gè)沒有滾動(dòng)條的元素設(shè)置滾動(dòng)條的位置。 這就涉及到一個(gè)知識(shí)點(diǎn)的誤區(qū): "讓頁(yè)面滾動(dòng)到指定位置這個(gè)需求,不一定是讓整個(gè)window滾動(dòng),在路由嵌套的vue頁(yè)面中,window可能始終是沒有滾動(dòng)的,產(chǎn)生滾動(dòng)條的是一個(gè)設(shè)置了固定高度,且子元素的高度超出了他本身的元素. 這時(shí)候,元素才會(huì)產(chǎn)生滾動(dòng)條,而你一股腦的給window設(shè)置滾動(dòng)條位置,window也蒙了"

如何判斷頁(yè)面的滾動(dòng)條是哪個(gè)div產(chǎn)生的?

滾動(dòng)滾輪,看是哪一塊元素在滾動(dòng)(具體到div上).設(shè)置他的父元素的滾動(dòng)條位置即可讓其滾動(dòng).

場(chǎng)景1:如何刪除body的滾動(dòng)條,保留某個(gè)div的滾動(dòng)條

body{overflow:hidden;}div{height:xxpx;    #小于子元素的高度overflow-y:auto;}

場(chǎng)景2:documentElement.scrollTop或者document.body.scrollTop 一直為0的情況

產(chǎn)生根本原因還是因?yàn)榻o沒有scrollTop的元素設(shè)定了該值,直接原因是因?yàn)闉g覽器兼容問題。

場(chǎng)景2:documentElement.scrollTop或者document.body.scrollTop 一直為0的情況 產(chǎn)生根本原因還是因?yàn)榻o沒有scrollTop的元素設(shè)定了該值,直接原因是因?yàn)闉g覽器兼容問題。

document.documentElement.scrollTop || document.body.scrollTop || window.pageYOffset

1 解決方法:在上面三個(gè)元素中逐一嘗試,總有一款可以設(shè)置上。

到此這篇關(guān)于vue頁(yè)面設(shè)置滾動(dòng)失敗的解決方案(scrollTop一直為0)的文章就介紹到這了,更多相關(guān)vue頁(yè)面滾動(dòng)失敗內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: JavaScript
主站蜘蛛池模板: 亚洲第1页 | 久久久精品网 | 二区在线视频 | 高清免费av | 日韩不卡一二区 | 精品久久电影 | 国产成人精品一区二区三区四区 | 99精品一区二区 | 激情av网站| 精品精品 | 国产成人精品久久二区二区91 | 91精品国产色综合久久不卡98 | 久久人人爽人人爽 | 免费观看黄色片视频 | av永久 | 久草视频观看 | 国产精品成人在线 | 日韩视频一区二区在线 | 91精品国产综合久久久久久丝袜 | 在线播放中文字幕 | 国产精久久久 | 成人av电影免费在线观看 | 免费亚洲成人 | 成人妇女免费播放久久久 | 亚洲天堂av网 | 免费黄色成人 | 亚洲精品一区二区三区蜜桃久 | 亚洲精品视频播放 | 欧美一级片中文字幕 | 91精品国产综合久久久久蜜臀 | 99re在线视频 | 一区二区三区久久久 | 亚洲超碰在线观看 | 视频一区 国产精品 | 国产成人免费观看 | 中文字幕电影在线观看 | 国产一级片一区二区 | 日本一区二区三区精品视频 | 欧美一级在线 | 亚洲欧美在线视频 | 久久久精品视频一区二区三区 |