@onemin-table/elem-select

@onemin-table/elem-select

Usage no npm install needed!

<script type="module">
  import oneminTableElemSelect from 'https://cdn.skypack.dev/@onemin-table/elem-select';
</script>

README

elem-select

🚀 schema-based选择器模板组件, 集成el-popover组件,实现关注点集中的反馈模式.

安装

$ npm i @onemin-table/elem-select
# OR
$ yarn add @onemin-table/elem-select

用法

在 HTML 中以 UMD 的形式使用:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <link href="https://cdn.bootcdn.net/ajax/libs/element-ui/2.15.0/theme-chalk/index.min.css" rel="stylesheet">
</head>
<body>
  <main id="app">
    <elem-select
      v-model="foo"
      :border-color="foo === 2 ? 'red' : ''"
      :width="foo === 2 ? 200 : 300"
      :options="options"
    />
  </main>
  <script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min.js"></script>
  <script src="https://cdn.bootcdn.net/ajax/libs/element-ui/2.15.0/index.min.js"></script>
  <script src="./node_modules/@onemin-table/elem-select/dist/elem-select.min.js"></script>
  <script>
    new Vue({
      el: '#app',
      components: {
        ElemSelect,
      },
      data() {
        return {
          foo: [],
        };
      },
      computed: {
        options() {
          return [{
            label: 'a',
            value: 1,
          }, {
            label: 'b',
            value: 2,
          }];
        },
      },
    });
  </script>
</body>
</html>

在工程项目中以 CommonJS / ESM 的形式使用:

<template>
  <div>
    <button @click="group = !group">切换</button>
    <span>{{ !group ? '单选' : '分组' }}</span>
    <elem-select
      ref="select"
      v-model="foo"
      :popoverVisible="!group"
      :options="group ? groupOptions : options"
      :prefix-slot-render="prefixSlotRender"
      :border-color="group ? '' : 'red'"
      :width="300"
      :popover-slot-render="popoverSlotRender"
      @change="handleChange"
    />
  </div>
</template>

<script>
  export default {
    data() {
      return {
        foo: 1,

        group: true,
      };
    },

    computed: {
      options() {
        return [{
          label: 'a',
          value: 1,
        }, {
          label: 'b',
          value: 2,
        }, {
          label: 'c',
          value: 3,
        }];
      },

      groupOptions() {
        return [{
          label: '分组1',
          children: this.options,
        }, {
          label: '分组2',
          children: [{
            label: 'd',
            value: 4,
          }],
        }];
      },
    },

    mounted() {
      const ref = this.$refs.select;
      if (ref) ref.focus();
    },

    methods: {
      handleChange(val) {
        console.warn(this.foo, val);
      },

      prefixSlotRender(h) {
        return <i class="el-icon-time el-input__icon" />;
      },

      popoverSlotRender() {
        return (
          <div>
            <i style="color: #F46A6A;margin-right: 10px;" class="el-icon-error" />
            错误
          </div>
        );
      },
    },
  };
</script>

<style>
  .ot-select__popover--elem {
    padding: 16px;
  }
</style>

代码预览

代码预览

参数 说明 类型
options(必填) 选择器下拉列表数据, 含有children的列表自动分组展示 Array<{ label: string, value?: any, disabled?: boolean, children?: Array }>
prefix-slot-render 选择器头部内容渲染函数, 相当于el-select的prefix slot Function
empty-slot-render 选择器无选项时列表渲染函数, 相当于el-select的empty slot Function
loading 选择器是否加载中 Boolean
loading-text 选择器选项加载中列表提示文字 String
loading-slot-render 选择器选项加载中列表内容渲染函数, 优先级高于loading-text Function
data-prop 元素标识,会被绑定到DOM元素的data-prop属性上, 默认为空 String
width 选择器宽度, 传入数字会被识别为像素值(px) String|Number
border-color 选择器边框颜色, 可用于校验不通过的提示,设为空字符串可还原 String
background-color 选择器背景颜色, 可用于校验不通过的提示,设为空字符串可还原 String
color 选择器字体颜色, 可用于校验不通过的提示,设为空字符串可还原 String
popover-visible <el-popover>弹出框是否显示 Boolean
popover-content <el-popover>弹出框内容 String
popover-attrs <el-popover>的属性 Object
popover-listeners <el-popover>的事件 Object
popover-slot-render 弹出框渲染函数, 相当于el-popover的default slot Function

其他继承自el-select的属性见element-ui文档

事件

继承自el-select的事件见element-ui文档

方法

继承自el-select的方法见element-ui文档