antd-vue - - - - - select自定义渲染[封装select组件]

select自定义渲染[封装select组件]

1. 期望效果

标签值和option展示不一致!
在这里插入图片描述

2. 代码展示

官网地址:【antd-vue select】

封装的select组件:

<template>
  <a-form ref="refForm" :model="selectConfig" :labelCol="_labelCol">
    <a-form-item label="管理员" name="list" :rules="selectConfig.rules">
      <a-select
        popupClassName="custom-search"
        v-model:value="selectConfig.list"
        mode="multiple"
        style="width: 100%"
        placeholder="请选择管理员"
        show-search
        :default-active-first-option="false"
        :filter-option="false"
        :not-found-content="null"
        @search="searchAdminList"
        :options="selectConfig.options"
      >
        <!-- 下拉option渲染 -->
        <template #option="{ label, dept_name }">
          &nbsp;&nbsp;{{ label }} {{ !!dept_name ? `(${dept_name})` : '' }}
        </template>
        <!-- value标签渲染 -->
        <template #tagRender="{ label, closable, onClose }">
          <a-tag :closable="closable" style="margin-right: 3px" @close="onClose">
            {{ label }}&nbsp;
          </a-tag>
        </template>
      </a-select>
    </a-form-item>
  </a-form>
</template>
<script setup lang="ts">
import { searchAdmin } from '@/api/common';

const props = defineProps({
  _rules: {
    type: Boolean,
    default: () => {
      return false;
    },
  },
  _options: {
    type: Array,
    default: () => {
      return [];
    },
  },
  _list: {
    type: Array,
    default: () => {
      return [];
    },
  },
  _labelCol: {
    type: Object,
    default: () => ({
      style: {
        width: '90px',
      },
    }),
  },
});

const refForm = ref(null);

const selectConfig = reactive({
  rules: props._rules ? [{ required: true, message: '请选择管理员' }] : [],
  options: [],
  list: [],
});

watch(
  props,
  val => {
    selectConfig.options = val._options;
    selectConfig.list = val._list;
  },
  {
    deep: true,
    immediate: true,
  },
);

/**
 * 搜索管理员
 */
function searchAdminList(e) {
  if (!e) return;
  searchAdmin({ keyword: e }).then(res => {
    if (res.code === 0) {
      const options = res.data.users.reduce((pre, cur) => {
        return [
          ...pre,
          {
            label: cur.name,
            value: cur.momoid,
            dept_name: cur.dept_name,
          },
        ];
      }, []);
      selectConfig.options = [].concat(options);
    }
  });
}

/**
 * 表单校验
 */
function formRules() {
  return refForm.value
    .validate()
    .then(() => {
      return true;
    })
    .catch(() => {
      return false;
    });
}

/**
 * 获取value值
 */
function getValue() {
  return selectConfig.list;
}

/**
 * 将子组件方法暴露给父组件
 */
defineExpose({
  formRules,
  getValue,
});
</script>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值