下拉加载怎么实现

1、监听scroll事件

const containerDom:RefObject<HTMLDivElement> = useRef(null)

        //const myHref = useHref()

        const containerScroll = useCallback((event)=>{

                const scrollTop = (event.srcElement ? event.srcElement.documentElement.scrollTop : false)

                || window.pageYOffset

                || (event.srcElement ? event.srcElement.body.scrollTop : 0);

                 console.log('触发了滚动事件',scrollTop)

                if(scrollTop>60){

                        containerDom.current?.classList.remove('header_active')                         containerDom.current?.classList.add('header_hidden')

                 }else{

                        containerDom.current?.classList.remove('header_hidden')                         containerDom.current?.classList.add('header_active')

                 } },[])

                useEffect(()=>{

                        window.addEventListener('scroll',containerScroll)

                        return ()=>{

                                window.removeEventListener('scroll',containerScroll)

                        }

                 },[])

2、IntersectionObserver

// 获取要监测的元素

const boxes = this.oberservDom.current

//  

// 创建观察者,配置回调函数 // 通过 isIntersecting 属性判断元素与视口是否相交

const observer = new IntersectionObserver((entries, observer) => {

        if(!this.state.flag){

                this.append()

         }

        console.log(entries)

})

//  

observer.observe(boxes);

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值