输入框 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>
三种大小
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 | 输入框宽度,单位 px | string | number | '100%' |
size | 输入框大小 | 'small' | 'middle' | 'large' | 'middle' |
addonBefore | 设置前置标签 | string | slot | undefined |
addonAfter | 设置后置标签 | string | slot | undefined |
prefix | 前缀图标 | string | slot | undefined |
suffix | 后缀图标 | string | slot | undefined |
allowClear | 可以点击清除图标删除内容 | boolean | false |
password | 是否启用密码框 | boolean | false |
disabled | 是否禁用 | boolean | false |
placeholder | 文本输入的占位符 | string | undefined |
maxlength | 最大长度 | number | undefined |
showCount | 是否展示字数 | boolean | false |
value v-model | 输入框内容 | string | undefined |
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 |