亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

JS滾動到頂部踩坑解決記錄

瀏覽:126日期:2022-06-09 14:30:25

正文

一般在比較長的頁面中會有一個滾動到頂部的按鈕,用戶點擊一下 300ms 內,會滾動到頂部,有動畫效果。

一開始我想,這不是很簡單,一行代碼完美解決

$(document.documentElement).animate({scrollTop: 0}, 300);

使用這個可以到頂部,但是沒有動畫,沒有采用

$(document.documentElement).scrollTop(0)

等到了手機上才發現,點擊居然沒有反應,才發現原來是我想的太簡單,一個滾動到頂部的按鈕竟然有這么多兼容問題。

document.body在 手機上能用,pc 上不能用

$(document.body).animate({scrollTop: 0}, 300);
console.log(document.body.scrollTop)   // 移動端有值,pc 為0

document.documentElement在 PC 上能用,但手機上不能用

$(document.documentElement).animate({scrollTop: 0}, 300);
console.log(document.documentElement.scrollTop)   // pc端有值,移動端為0

也就是說 PC 端滾動的是document.documentElement,在移動端滾動的是 document.body

如果沒有一個更好的 api,那么就需要在分環境處理滾動元素,這樣顯的就有點麻煩。

這時候 document.scrollingElement 就出現,這個 api 就是為解決這個問題誕生的,通過 document.scrollingElement.tagName 可以看到在 PC 端是 html 在移動端是 body 。

在做解決問題的時候,搜索到一個 api

window.scrollTo({top: 0, behavior: "smooth"})

以為 js 良心發現,提供了一個這么好用的 api,可以滾動到頂部,還有動畫,查看兼容性的時候, ios 居然不支持,害,果然就沒有好事情。

所以在遇到滾動到頂部時,document.scrollingElement 除了 IE 和 opera 和部分低版本瀏覽器不支持外,可以基本滿足需求。

以上就是JS滾動到頂部踩坑解決記錄的詳細內容,更多關于JS滾動到頂部的資料請關注其它相關文章!

標簽: JavaScript
主站蜘蛛池模板: jizz国产精品 | 老年人一级特黄aa大片 | 免费鲁丝片一级观看 | 性生活视频黄色 | 午夜精品视频在线观看 | 欧美日韩国产成人综合在线影院 | 精品视频在线免费播放 | 国内精品免费 | 99视频在线精品免费观看18 | 欧美日韩国产一区三区 | 欧美护士激情第一欧美精品 | 一区二区三区四区日韩 | 免费xxxxx大片观看 | 成年人在线观看视频网站 | 欧美成人亚洲综合精品欧美激情 | 善良的翁熄日本中文字幕1 上海麻豆文化传媒网站入口 | 99riav国产精品 | 国产乱人乱精一区二区视频密 | 女视频www女中国 | 午夜在线观看视频免费 成人 | 国产成人在线播放 | 国产又污又爽又色的网站 | 日本一区精品 | 亚洲深夜 | 国产一区亚洲一区 | 日韩在线视频网址 | 国产福利视频在线观看 | 亚洲一欧洲中文字幕在线 | 日本在线一区二区 | 鲁丝丝国产一区二区 | 亚洲精品美女在线观看播放 | 日本一区二区三区久久 | 99精品国产成人一区二区在线 | 91久久精品一区二区 | 欧美视屏在线观看 | 亚洲精品福利一区二区三区 | 综合九九| 免费香蕉视频 | 色系视频在线观看免费观看 | 国产欧美二区三区 | 2048国产精品原创综合在线 |