2.7 Elements-- useWindowScroll

2.7 Elements-- useWindowScroll

https://vueuse.org/useWindowScroll

作用

响应式监听window的滚动距离

官方示例

import { useWindowScroll } from '@vueuse/core'

const { x, y } = useWindowScroll()

x,y的值会随着页面滚动实时变化。

源码分析

export function useWindowScroll({ window = defaultWindow }: ConfigurableWindow = {}) {
  if (!window) {
    return {
      x: ref(0),
      y: ref(0),
    }
  }

  const x = ref(window.pageXOffset)
  const y = ref(window.pageYOffset)

  useEventListener(
    window,
    'scroll',
    () => {
      x.value = window.pageXOffset
      y.value = window.pageYOffset
    },
    {
      capture: false,
      passive: true,
    },
  )

  return { x, y }
}
  1. x, y初始值是window.pageXOffset, window.pageYOffset
  2. 监听滚动事件,重新赋值。passive: true,显式告诉浏览器,回调中不会阻止默认事件。这有利于减少浏览器等待时间,提高性能

不足:没有提供取消监听的方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值