Vue页面滚动到底部触发

一、首先要设置需要滚动的盒子,给div添加overflow-y:auto或overflow-y: scroll样式,然后给盒子添加@scroll事件。

<div class="scroll_box" @scroll="scrollEventFn">
    <div class="item" v-for="(item, index) in list" :key="index">
     	{{item}}
    </div>
</div>

二、@scroll事件调用内容

scrollEventFn(e){
	//e.srcElement.scrollTop: 滚动条距离页面顶部距离
	//e.srcElement.clientHeight: 滚动页面高度
	//e.srcElement.scrollHeight: 滚动条高度
    if (e.srcElement.scrollTop + e.srcElement.clientHeight > e.srcElement.scrollHeight - 50) {//-50距离底部50px是触发以下内容
        console.log("触发了", this.pageData.pageIndex, this.pageData.pageTotal)
        if(this.pageData.pageIndex < this.pageData.pageTotal){
            this.pageData.pageIndex ++
            this.getUserActionDataFn()
        }
    }
},
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue中,当滚动条滑动到某个元素的底部时,可以通过监听滚动事件(通常是`scroll`事件)来触发自定义的回调函数。这种行为通常在需要加载更多内容或者自动滚动到特定位置时使用。 以下是一个简单的例子,展示如何在Vue组件中监听滚动条滑动到底部事件: ```html <template> <div ref="scrollElement" :style="{ height: 'calc(100vh - 100px)' }"> <!-- 假设这是你的可滚动区域 --> <div v-for="item in items" :key="item.id">{{ item.content }}</div> <!-- ... --> </div> </template> <script> export default { data() { return { items: [], // 其他数据... }; }, mounted() { this.$refs.scrollElement.addEventListener('scroll', this.handleScroll); }, methods: { handleScroll() { if ( this.$refs.scrollElement.scrollHeight - this.$refs.scrollElement.scrollTop === this.$refs.scrollElement.clientHeight ) { // 当滚动底部时执行的代码 this.loadMoreItems(); // 加载更多数据的方法 } }, loadMoreItems() { // 在这里实现加载更多数据的逻辑 }, }, beforeDestroy() { this.$refs.scrollElement.removeEventListener('scroll', this.handleScroll); }, }; </script> ``` 在这个例子中,我们首先使用`ref`属性为可滚动区域添加了一个引用,然后在`mounted`生命周期钩子中添加了滚动事件监听器。当滚动底部时,`handleScroll`方法会被调用,检查滚动条距离底部的距离是否等于滚动区域的高度,如果是,则说明已到达底部,执行`loadMoreItems`方法加载更多内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值