vue+ElementUI el-select实现下拉列表分页的功能(下拉分页组件)

1、最终效果

vue+ElementUI el-select实现下拉列表分页的功能(下拉分页组件)_第1张图片

2、需求

因下拉框中的数据过多,所以需要使用分页的方式来实现

3、代码示例

<t-pagination-select
              @page-change="pageChange" // 分页器事件
              :optionSource="materialIdArr" // 数据源
              v-model="addForm.materialId" // 返回的值
              labelKey="materialName" // 下拉选择中文显示
              valueKey="id" // 下拉选择value
              :paginationOption="setSelectPage" // 分页器配置
            />

4、具体代码

<template>
  <div class="t_pagination_select">
    <el-select
      v-model="childSelectedValue"
      @change="(val) => $emit('change',val)"
      :style="{width: width||'100%'}"
      v-bind="attrs"
    >
      <el-option
        v-for="item in optionSource"
        :key="item[valueKey]"
        :label="item[labelKey]"
        :value="item[valueKey]"
      >el-option>
      <el-pagination
        small
        layout="total,prev, pager, next"
        @current-change="(val) => $emit('page-change',val)"
        :hide-on-single-page="true"
        :page-size="paginationOption.pageSize"
        :current-page="paginationOption.currentPage"
        :pager-count="paginationOption.pagerCount"
        :total="paginationOption.total"
      >el-pagination>
    el-select>
  div>
template>

<script>

export default {
  name: 'TPaginationSelect',
  props: {
    value: {
      type: [String, Number]
    },
    // 选择框宽度
    width: {
      type: String
    },
    // 传入的option数组中,要作为最终选择项的键值名称
    valueKey: {
      type: String
    },
    //传入的option数组中,要作为显示项的键值名称
    labelKey: {
      type: String
    },
    // 下拉框组件数据源
    optionSource: {
      type: Array
    },
    //分页配置项
    paginationOption: {
      type: Object,
      default: () => {
        return {
          pageSize: 6,//每页显示条数
          currentPage: 1,//当前页
          pagerCount: 5,//按钮数,超过时会折叠
          total: 0 //总条数
        }
      }
    }
  },
  computed: {
    childSelectedValue: {
      get () {
        return this.value
      },
      set (val) {
        this.$emit('input', val)
      }
    },
    attrs () {
      return {
        'popper-append-to-body': false,
        clearable: true,
        filterable: true,
        ...this.$attrs
      }
    }
  },
  watch: {
    childSelectedValue (val) {
      this.childSelectedValue = val
    }
  }
}
script>
 <style lang="scss" scoped>
.t_pagination_select {
  ::v-deep .el-pagination {
    display: flex;
    margin-top: 15px;
    margin-left: 15px;
    background-color: #fff;
    align-items: center;
    .el-pager {
      display: flex;
      align-items: center;
    }
  }
}
style>

5、组件地址

gitHub组件地址

gitee码云组件地址

基于ElementUi/Antd再次封装基础组件文档

你可能感兴趣的:(vue.js,elementui,二次封装,下拉选择分页,组件化)