Rumah  >  Artikel  >  hujung hadapan web  >  javascript怎么实现置顶

javascript怎么实现置顶

藏色散人
藏色散人asal
2021-10-25 14:30:584826semak imbas

javascript实现置顶的方法:1、通过getBoundingClientRect获取元素到浏览器视窗顶部的距离;2、通过“$(document).scrollTop() for(...)”方法实现置顶功能即可。

javascript怎么实现置顶

本文操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

JavaScript实现置顶功能

JavaScript实现置顶功能的方式有很多,之前也用过一些, 感觉比较复杂吧,自己最近做的东西需要,因此也在网上找了些资料,最后找到一个方法 getBoundingClientRect() 可以获取页面元素到浏览器视窗顶部的距离。

最后代码如下:

let len = document.getElementById('flexbox').getBoundingClientRect().top;//获取元素到浏览器视窗顶部的距离
//$(document).scrollTop()为滚动条的高度
        for (let i = $(document).scrollTop(); i < len + $(document).scrollTop(); i++) {
            setTimeout(function () {
                window.scrollTo(0, i);
            }, 0)
        }

用循环的目的主要是使得元素置顶的时候不突兀,这个过程可以通过改变i++来实现,同时需要注意一点,如果for语句用的是var i 而不是let i,定时器则需要用立即执行函数包裹来保证i能立马生效。

用这种方式实现的置顶和锚点效果差不多,如果要实现悬浮置顶(某个部分固定在顶部),则可以考虑用position:fixed来实现。

就这样吧。。。。

【推荐学习:javascript基础教程

Atas ialah kandungan terperinci javascript怎么实现置顶. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn