✨: [#I55AK7] select 多选搜索
This commit is contained in:
		
							parent
							
								
									98666c4ac1
								
							
						
					
					
						commit
						97a4b14e08
					
				@ -21,6 +21,9 @@ dl.layui-anim-upbit > dd .layui-form-checkbox,
 | 
			
		||||
  box-sizing: border-box;
 | 
			
		||||
  overflow: hidden;
 | 
			
		||||
  cursor: pointer;
 | 
			
		||||
  background-color: #fff;
 | 
			
		||||
  border: 1px solid var(--input-border-color);
 | 
			
		||||
  border-right: unset;
 | 
			
		||||
  .layui-multiple-select-badge {
 | 
			
		||||
    width: ms-max-content;
 | 
			
		||||
    width: max-content;
 | 
			
		||||
@ -148,4 +151,24 @@ dl.layui-anim-upbit > dd .layui-form-checkbox,
 | 
			
		||||
 | 
			
		||||
.layui-form-selected dl {
 | 
			
		||||
  display: block;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.layui-multiple-select-input {
 | 
			
		||||
  margin-bottom: 5px;
 | 
			
		||||
  padding: 0 10px;
 | 
			
		||||
  cursor: pointer;
 | 
			
		||||
 | 
			
		||||
  .layui-input-wrapper {
 | 
			
		||||
    border: unset;
 | 
			
		||||
    border-bottom: 1px solid var(--input-border-color);
 | 
			
		||||
 | 
			
		||||
    .layui-input {
 | 
			
		||||
      border: unset;
 | 
			
		||||
      padding-left: 0;
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  .layui-input-wrapper:focus-within {
 | 
			
		||||
    border-color: var(--input-border-color);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
@ -16,6 +16,8 @@ import {
 | 
			
		||||
  reactive,
 | 
			
		||||
  toRefs,
 | 
			
		||||
  Ref,
 | 
			
		||||
  nextTick,
 | 
			
		||||
  shallowRef,
 | 
			
		||||
} from "vue";
 | 
			
		||||
import LayBadge from "../badge/index.vue";
 | 
			
		||||
import LayScroll from "../scroll/index.vue";
 | 
			
		||||
@ -40,7 +42,8 @@ export interface LaySelectProps {
 | 
			
		||||
  }[];
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
const selectRef = ref<null | HTMLElement>();
 | 
			
		||||
const selectRef = shallowRef<undefined | HTMLElement>(undefined);
 | 
			
		||||
const multipleSearchInputRef = shallowRef<HTMLElement | undefined>(undefined);
 | 
			
		||||
 | 
			
		||||
onClickOutside(selectRef, (event: Event) => {
 | 
			
		||||
  openState.value = false;
 | 
			
		||||
@ -63,6 +66,9 @@ const open = function () {
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
  openState.value = !openState.value;
 | 
			
		||||
  nextTick(() => {
 | 
			
		||||
    multipleSearchInputRef.value?.querySelector('input')?.focus();
 | 
			
		||||
  })
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
const emit = defineEmits(["update:modelValue", "change", "search", "create"]);
 | 
			
		||||
@ -238,6 +244,21 @@ provide("keyword", txt);
 | 
			
		||||
 | 
			
		||||
    <!-- 下拉内容 -->
 | 
			
		||||
    <dl class="layui-anim layui-anim-upbit">
 | 
			
		||||
      <div 
 | 
			
		||||
        ref="multipleSearchInputRef" 
 | 
			
		||||
        class="layui-multiple-select-input">
 | 
			
		||||
        <lay-input 
 | 
			
		||||
          v-if="multiple" 
 | 
			
		||||
          v-model="value"
 | 
			
		||||
          @input="input = true"
 | 
			
		||||
          @blur="input = false"
 | 
			
		||||
          :placeholder="placeholder"
 | 
			
		||||
          prefix-icon="layui-icon-search" 
 | 
			
		||||
          allow-clear 
 | 
			
		||||
          autocomplete
 | 
			
		||||
         >
 | 
			
		||||
        </lay-input>
 | 
			
		||||
      </div>
 | 
			
		||||
      <template v-if="!multiple && showEmpty && !props.create">
 | 
			
		||||
        <lay-select-option :value="null" :label="emptyMessage ?? placeholder" />
 | 
			
		||||
      </template>
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user