当前位置:首页 » 《资源分享》 » 正文

前端vue成功解决滚动条滚动监听问题!

4 人参与  2024年09月24日 15:20  分类 : 《资源分享》  评论

点击全文阅读


前端vue成功解决滚动条滚动监听问题!

vueuse------useScroll的使用安装说明vue3 Vue2 的话还需要额外安装 @vue/composition-apiuseScroll的使用1.在@vueuse/core包下引入useScroll2.可以手动设置滚动位置3.这个方法也提供自定义指令的方式4.场景
前端处理滚动条滚动事件无非就是监听scroll事件,但是我们经常会遇到 滚动事件频繁触发无法正常获取滚动的元素,最常见的就是 处理滚动位置

vueuse------useScroll的使用

安装说明
vue3
npm i @vueuse/core --save
Vue2 的话还需要额外安装 @vue/composition-api
npm i @vue/composition-api --save
useScroll的使用
1.在@vueuse/core包下引入useScroll
import { useScroll } from '@vueuse/core'
<!--需要滚动的容器--><div id="container" ref="container" class="container"></div>
<!--第一个参数el(需要滚动的容器)-->this.$nextTick(() => {  const { x, y, isScrolling, arrivedState, directions } = useScroll(document.getElementById('container'))  this.x = x  this.y = y  this.isScrolling = isScrolling  this.arrivedState = arrivedState  this.directions = directions})<!--x:用于记录上次滚动的scrollLeft的值,y:记录上次滚动的scrollTop的值,isScrolling: 表示是否正在滚动,arrivedState: {top/right/bottom/left}表示滚动条是否到达指定边界,directions: {top/right/bottom/left} 表示滚动条正在滚动的方向-->
<!--第二个参数,可以设置偏移量offset(滚动条到达上下左右边界的一个偏移值,例如left设置为30, 则水平滚动条距离左边界30px时则认为到达了左边界)-->const { x, y, isScrolling, arrivedState, directions } = useScroll(document.getElementById('container'), { offset: { top: 0, bottom: 300, right: 30, left: 0 }})
<!--第二个参数,{behavior: smooth}设置平滑的滚动-->const { x, y, isScrolling, arrivedState, directions } = useScroll(document.getElementById('container'), { behavior: 'smooth' })
2.可以手动设置滚动位置
3.这个方法也提供自定义指令的方式

自定义指令vScroll在@vueuse/components中

import { vScroll } from '@vueuse/components'Vue.directive('scroll', vScroll)<div id="container" ref="container" v-scroll="onScroll" class="container"></div>onScroll({ x, y, isScrolling, arrivedState, directions }) {  this.x = x  this.y = y  this.isScrolling = isScrolling  this.arrivedState = arrivedState  this.directions = directions}
4.场景

1.滚动到底部,出现‘返回顶部’按钮
2.滚动到底部,加载新数据
3.其他


点击全文阅读


本文链接:http://zhangshiyu.com/post/164016.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1