ant-design/components/input/index.zh-CN.md
2023-03-28 22:01:23 +08:00

7.4 KiB
Raw Blame History

category subtitle group title cover coverDark demo
Components 输入框 数据录入 Input https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*Y3R0RowXHlAAAAAAAAAAAAAADrJ8AQ/original https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*sBqqTatJ-AkAAAAAAAAAAAAADrJ8AQ/original
cols
2

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

何时使用

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

代码演示

基本使用 三种大小 前置/后置标签 紧凑模式 输入框组合 搜索框 搜索框 loading 文本域 适应文本高度的文本域 输入时格式化展示 前缀和后缀 密码框 带移除图标 带字数提示 带字数提示的文本域 自定义状态 无边框 聚焦 Style Debug 文本对齐 文本域 debug 前置/后置标签

API

Input

参数 说明 类型 默认值 版本
addonAfter 带标签的 input设置后置标签 ReactNode -
addonBefore 带标签的 input设置前置标签 ReactNode -
allowClear 可以点击清除图标删除内容 boolean | { clearIcon: ReactNode } -
bordered 是否有边框 boolean true 4.5.0
classNames 语义化结构 class Record<SemanticDOM, string> - 5.4.0
defaultValue 输入框默认内容 string -
disabled 是否禁用状态,默认为 false boolean false
id 输入框的 id string -
maxLength 最大长度 number -
showCount 是否展示字数 boolean | { formatter: (info: { value: string, count: number, maxLength?: number }) => ReactNode } false 4.18.0 info.value: 4.23.0
status 设置校验状态 'error' | 'warning' - 4.19.0
styles 语义化结构 style Record<SemanticDOM, CSSProperties> - 5.4.0
prefix 带有前缀图标的 input ReactNode -
size 控件大小。注:标准表单内的输入框大小限制为 middle large | middle | small -
suffix 带有后缀图标的 input ReactNode -
type 声明 input 类型,同原生 input 标签的 type 属性,见:MDN(请直接使用 Input.TextArea 代替 type="textarea") string text
value 输入框内容 string -
onChange 输入框内容变化时的回调 function(e) -
onPressEnter 按下回车的回调 function(e) -

如果 InputForm.Item 内,并且 Form.Item 设置了 idoptions 属性,则 value defaultValueid 属性会被自动设置。

Input 的其他属性和 React 自带的 input 一致。

Input.TextArea

参数 说明 类型 默认值 版本
allowClear 可以点击清除图标删除内容 boolean false
autoSize 自适应内容高度,可设置为 true | false 或对象:{ minRows: 2, maxRows: 6 } boolean | object false
bordered 是否有边框 boolean true 4.5.0
classNames 语义化结构 class Record<SemanticDOM, string> - 5.4.0
defaultValue 输入框默认内容 string -
maxLength 内容最大长度 number - 4.7.0
showCount 是否展示字数 boolean | { formatter: (info: { value: string, count: number, maxLength?: number }) => string } false 4.7.0 formatter: 4.10.0 info.value: 4.23.0
styles 语义化结构 style Record<SemanticDOM, CSSProperties> - 5.4.0
value 输入框内容 string -
onPressEnter 按下回车的回调 function(e) -
onResize resize 回调 function({ width, height }) -

Input.TextArea 的其他属性和浏览器自带的 textarea 一致。

Input.Search

参数 说明 类型 默认值
enterButton 是否有确认按钮,可设为按钮文字。该属性会与 addonAfter 冲突。 boolean | ReactNode false
loading 搜索 loading boolean false
onSearch 点击搜索图标、清除图标,或按下回车键时的回调 function(value, event) -

其余属性和 Input 一致。

Input.Password

参数 说明 类型 默认值 版本
iconRender 自定义切换按钮 (visible) => ReactNode (visible) => (visible ? <EyeOutlined /> : <EyeInvisibleOutlined />) 4.3.0
visibilityToggle 是否显示切换按钮或者控制密码显隐 boolean | VisibilityToggle true

VisibilityToggle

Property Description Type Default Version
visible 用于手动控制密码显隐 boolean false 4.24
onVisibleChange 显隐密码的回调 boolean - 4.24

Input Methods

名称 说明 参数 版本
blur 取消焦点 -
focus 获取焦点 (option?: { preventScroll?: boolean, cursor?: 'start' | 'end' | 'all' }) option - 4.10.0

Semantic DOM

Input

名称 说明 版本
input input 元素 5.4.0
prefix 所有前缀的包裹元素 5.4.0
suffix 所有后缀的包裹元素 5.4.0
count 文字计数元素 5.4.0

Input.TextArea

名称 说明 版本
textarea textarea 元素 5.4.0
count 文字计数元素 5.4.0

Design Token

FAQ

为什么我动态改变 prefix/suffix/showCountInput 会失去焦点?

当 Input 动态添加或者删除 prefix/suffix/showCountReact 会重新创建 DOM 结构而新的 input 是没有焦点的。你可以预设一个空的 <span /> 来保持 DOM 结构不变:

const suffix = condition ? <Icon type="smile" /> : <span />;

<Input suffix={suffix} />;

为何 TextArea 受控时,value 可以超过 maxLength

受控时,组件应该按照受控内容展示。以防止在表单组件内使用时显示值和提交值不同的问题。