Skip to content

输入框 Input

通过鼠标或键盘输入内容,是最基础的表单域的包装

何时使用

  • 需要用户输入表单域内容时
  • 提供组合型输入框,带搜索的输入框,还可以进行大小选择

基本使用

.lazy

默认情况下,v-model 会在每次 input 事件后更新数据 (IME 拼字阶段的状态例外)。你可以添加 lazy 修饰符来改为在每次 change 事件后更新数据

vue
<!-- 在 "change" 事件后同步更新而不是 "input" -->
<Input v-model:value.lazy="msg" />
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const value = ref('')
const lazyValue = ref('')
watchEffect(() => {
  console.log('value', value.value)
})
watchEffect(() => {
  console.log('lazyValue', lazyValue.value)
})
function onChange (e: Event) {
  console.log('change', e)
}
function onEnter (e: KeyboardEvent) {
  console.log('enter', e)
}
</script>
<template>
  <Space gap="small" vertical :width="200">
    <Input v-model:value="value" placeholder="Basic usage" @change="onChange" @enter="onEnter" />
    <Input v-model:value.lazy="lazyValue" placeholder="Lazy usage" @change="onChange" @enter="onEnter" />
  </Space>
</template>

前缀和后缀

RMB
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
import { UserOutlined, InfoCircleOutlined } from '@ant-design/icons-vue'
const value = ref('')
watchEffect(() => {
  console.log('value', value.value)
})
</script>
<template>
  <Space gap="small" vertical :width="300">
  <Input v-model:value="value" placeholder="Basic usage" prefix="¥" suffix="RMB" />
  <Input v-model:value="value" placeholder="Basic usage">
    <template #prefix>
      <UserOutlined />
    </template>
    <template #suffix>
      <Tooltip :max-width="150" tooltip="Extra information">
        <InfoCircleOutlined />
      </Tooltip>
    </template>
  </Input>
</Space>
</template>

前置和后置标签

Http://
.com
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
import { SettingOutlined } from '@ant-design/icons-vue'
const value = ref('')
watchEffect(() => {
  console.log('value', value.value)
})
</script>
<template>
  <Space gap="small" vertical :width="300">
  <Input
    v-model:value="value"
    placeholder="Basic usage"
    addon-before="Http://"
    addon-after=".com"
  />
  <Input v-model:value="value" placeholder="Basic usage">
    <template #addonAfter>
      <SettingOutlined />
    </template>
  </Input>
</Space>
</template>

三种大小

small
middle
large
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
import { UserOutlined, InfoCircleOutlined, EnvironmentOutlined, CompassOutlined } from '@ant-design/icons-vue'
const value = ref('')
const sizeOptions = [
  {
    label: 'small',
    value: 'small'
  },
  {
    label: 'middle',
    value: 'middle'
  },
  {
    label: 'large',
    value: 'large'
  }
]
const size = ref('middle')
watchEffect(() => {
  console.log('value', value.value)
})
</script>
<template>
  <Space gap="small" vertical :width="300">
    <Radio :options="sizeOptions" v-model:value="size" button button-style="solid" />
    <Input v-model:value="value" :size="size" placeholder="Basic usage" />
    <Input
      v-model:value="value"
      :size="size"
      placeholder="Basic usage"
    >
      <template #prefix>
        <UserOutlined />
      </template>
      <template #suffix>
        <InfoCircleOutlined />
      </template>
    </Input>
    <Input
      v-model:value="value"
      :size="size"
      placeholder="Basic usage"
    >
      <template #addonBefore>
        <EnvironmentOutlined />
      </template>
      <template #addonAfter>
        <CompassOutlined />
      </template>
    </Input>
  </Space>
</template>

带清除图标

Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const value = ref('')
watchEffect(() => {
  console.log('value', value.value)
})
</script>
<template>
  <Space>
    <Input allow-clear v-model:value="value" placeholder="input with clear icon" />
  </Space>
</template>

密码框

Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const value = ref('')
watchEffect(() => {
  console.log('value', value.value)
})
</script>
<template>
  <Space>
    <Input password v-model:value="value" placeholder="input password" />
  </Space>
</template>

带字数提示

0
0 / 20
Show Code
vue
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const value = ref('')
watchEffect(() => {
  console.log('value', value.value)
})
</script>
<template>
  <Space vertical>
    <Input show-count allow-clear v-model:value="value" placeholder="please input" />
    <Input show-count allow-clear v-model:value="value" :maxlength="20" placeholder="please input" />
  </Space>
</template>

禁用

Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const value = ref('')
</script>
<template>
  <Input disabled v-model:value="value" placeholder="disabled input" />
</template>

APIs

Input

参数说明类型默认值
width输入框宽度,单位 pxstring | number'100%'
size输入框大小'small' | 'middle' | 'large''middle'
addonBefore设置前置标签string | slotundefined
addonAfter设置后置标签string | slotundefined
prefix前缀图标string | slotundefined
suffix后缀图标string | slotundefined
allowClear可以点击清除图标删除内容booleanfalse
password是否启用密码框booleanfalse
disabled是否禁用booleanfalse
placeholder文本输入的占位符stringundefined
maxlength最大长度numberundefined
showCount是否展示字数booleanfalse
value
v-model
输入框内容stringundefined

Slots

名称说明类型
addonBefore自定义前置标签v-slot:addonBefore
addonAfter自定义后置标签v-slot:addonAfter
prefix自定义前缀图标v-slot:prefix
suffix自定义后缀图标v-slot:suffix

Events

名称说明类型
change输入框内容变化时的回调(e: Event) => void
enter按下回车的回调(e: KeyboardEvent) => void

Released under the MIT License.