vue自定义指令v-scroll。下拉加载更多

vue自定义指令v-scroll

用于下拉加载更多

import Vue from 'vue';
Vue.directive("scroll", {
  inserted: function(el, bind, vnode) {
    let scrollHeight = el.offsetHeight,
      cb_name = bind.expression, // 绑定的函数名
      cb = vnode.context[cb_name]; 
    el.addEventListener("scroll", async () => {
    		// +1防止高度不够
          if (scrollHeight + el.scrollTop + 1 >= el.firstChild.clientHeight) {
        try {
          cb && (await cb()); // 触发绑定的函数
        } catch (error) {
          console.log(error);
        }
      }
    });
  }
});

使用

在这里插入图片描述

引用中给出了一个使用Vue的滚动加载列表的示例代码。在该示例中,通过在要实现滚动加载的列表上添加`v-infinite-scroll`指令,并赋值相应的加载方法,可以实现滚动到底部时自动执行加载方法。代码中的`v-infinite-scroll`指令绑定了`load`方法,当滚动条滚动到底部时,`load`方法会被自动调用。 引用中给出了一些用于获取页面滚动相关信息的函数。其中,`getClientHeight`函数用于获取当前可视范围的高度,`getScrollHeight`函数用于获取文档完整的高度,`getScrollTop`函数用于获取当前滚动条的位置。 引用中给出了一个使用Vue实现无限下拉加载的示例代码。在该示例中,使用`scroll`事件监听滚动条的滚动,当滚动到底部时调用`load`方法加载更多数据。为了避免内存泄漏,需要在`destroyed`钩子函数中销毁该事件监听。 综上所述,`v-infinite-scroll`可以帮助实现Vue的无限滚动加载功能,通过监听滚动条滚动事件并调用相应的加载方法,可以在滚动到底部时自动加载更多数据。同时,需要注意在组件销毁时及时销毁该事件监听,以避免内存泄漏。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Vue项目实现自定义组件 Infinite Scroll 无限滚动加载数据](https://blog.csdn.net/weixin_44111507/article/details/127211214)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [【Vue】实现无限滚动加载](https://blog.csdn.net/NineWaited/article/details/126387768)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值