Blame view

Yi.Vben5.Vue3/playground/src/views/examples/form/modules/two-fields.vue 1.03 KB
515fceeb   “wangming”   框架初始化
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
  <script lang="ts" setup>
  import { Input, Select } from 'ant-design-vue';
  
  const emit = defineEmits(['blur', 'change']);
  
  const modelValue = defineModel<[string, string]>({
    default: () => [undefined, undefined],
  });
  
  function onChange() {
    emit('change', modelValue.value);
  }
  </script>
  <template>
    <div class="flex w-full gap-1">
      <Select
        v-model:value="modelValue[0]"
        class="w-[80px]"
        placeholder="类型"
        allow-clear
        :class="{ 'valid-success': !!modelValue[0] }"
        :options="[
          { label: '个人', value: 'personal' },
          { label: '工作', value: 'work' },
          { label: '私密', value: 'private' },
        ]"
        @blur="emit('blur')"
        @change="onChange"
      />
      <Input
        placeholder="请输入11位手机号码"
        class="flex-1"
        allow-clear
        :class="{ 'valid-success': modelValue[1]?.match(/^1[3-9]\d{9}$/) }"
        v-model:value="modelValue[1]"
        :maxlength="11"
        type="tel"
        @blur="emit('blur')"
        @change="onChange"
      />
    </div>
  </template>