扩展ElementUI el-autocomplete 上下键闭环滚动选择

element ui中的 el-autocomplete中的上下键进行扩展,可上下键闭环滚动功能选择

关键对el-autocomplete进行监听上下键并处理

<template>
  <div class="content">
    <el-autocomplete
      v-model="value"
      ref="selectRemote"
      placeholder="请输入关键词"
      @select="handleSelect"
      @input="update"
      @keydown.down.native="nagtiveRow(highlightedIndex + 1)"
      @keydown.up.native="nagtiveRow(highlightedIndex - 1)"
    ></el-utocomplete>
  </div>
</template>

<script>
export default {
  data() {
    return {
     value:"",
      highlightedIndex: -1 // 用于标识上下键移动位置。input、select进行重置-1
    };
  },
  methods: {
    // 扩展autocomplete 上下键进行从头从尾
    nagtiveRow(index) {
      const selectRemote = this.$refs["selectRemote"];
      this.highlightedIndex = index;
      if (index < 0) {
        this.highlightedIndex = this.options.length - 1;
      } else if (index >= this.options.length) {
        this.highlightedIndex = 0;
      } else {
        this.highlightedIndex = index;
      }
      selectRemote.highlight(this.highlightedIndex);
      const suggestion = selectRemote.$refs.suggestions.$el.querySelector(
        ".el-autocomplete-suggestion__wrap"
      );
      const suggestionList = suggestion.querySelectorAll(
        ".el-autocomplete-suggestion__list li"
      );
      let highlightItem = suggestionList[this.highlightedIndex];
      let offsetTop = highlightItem.offsetTop;
      suggestion.scrollTop = offsetTop;
    },
    update(val) {
      this.highlightedIndex = -1;
    },
    handleSelect(row) {
      this.highlightedIndex = -1;
    }
  }
};
</script>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值