vue3 element-plus el-autocomplete 下拉滑动加载更多

1.0  引入下拉组件

 <el-autocomplete
              ref="autocomplete"
              :popper-append-to-body="false"
              v-model="keywordsUid"
              :fetch-suggestions="querySearch"
              placeholder="请输入产品代码"
              @select="handleSelect"
              clearable
              size="small"
            ></el-autocomplete>

2.0 在methods 里面写加载下拉的方法

async load() {
      console.log(56565);
      this.page++;
      let list = await this.search(this.keywords);

      console.log(this.$refs["autocomplete"].suggestions);
      this.$refs["autocomplete"].suggestions.push(...list);
    },

3.0需要借助与vue3 的directives 局部使用

  directives: {
    loadmore: {
      beforeMount(el, binding) {
        // 此处为了简单,直接判断触底了
        function handleScroll(e) {
          let isBottom =
            e.target.clientHeight + e.target.scrollTop == e.target.scrollHeight;
          if (isBottom) {
            binding.value();  // 这个就是调用了load 的方法
          }
        }
        // 监听滚动
        let wrapDom = el.querySelector(".el-autocomplete-suggestion__wrap");
        el.__handleScroll__ = handleScroll;
        el.__wrapDom__ = wrapDom;
        wrapDom.addEventListener("scroll", handleScroll, false);
      },
      unbind(el, binding, vnode) {
        // 解除事件监听
        el.__wrapDom__.removeEventListener(
          "scroll",
          el.__handleScroll__,
          false
        );
      },
    },
  },

注意directives 的使用是和methods 等声明周期平级的

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值