2016-03-31 14:17:09 +08:00
|
|
|
|
---
|
|
|
|
|
category: Components
|
2016-09-21 11:28:38 +08:00
|
|
|
|
subtitle: 数字输入框
|
2018-11-04 16:20:35 +08:00
|
|
|
|
type: 数据录入
|
2016-09-21 11:28:38 +08:00
|
|
|
|
title: InputNumber
|
2020-06-05 13:50:09 +08:00
|
|
|
|
cover: https://gw.alipayobjects.com/zos/alicdn/XOS8qZ0kU/InputNumber.svg
|
2016-03-31 14:17:09 +08:00
|
|
|
|
---
|
2015-07-01 14:48:47 +08:00
|
|
|
|
|
|
|
|
|
通过鼠标或键盘,输入范围内的数值。
|
|
|
|
|
|
|
|
|
|
## 何时使用
|
|
|
|
|
|
2015-07-20 19:25:34 +08:00
|
|
|
|
当需要获取标准数值时。
|
2015-07-01 14:48:47 +08:00
|
|
|
|
|
|
|
|
|
## API
|
|
|
|
|
|
|
|
|
|
属性如下
|
|
|
|
|
|
2020-10-10 17:49:50 +08:00
|
|
|
|
| 成员 | 说明 | 类型 | 默认值 | 版本 |
|
|
|
|
|
| --- | --- | --- | --- | --- |
|
2021-08-31 13:09:03 +08:00
|
|
|
|
| addonAfter | 带标签的 input,设置后置标签 | ReactNode | - | 4.17.0 |
|
|
|
|
|
| addonBefore | 带标签的 input,设置前置标签 | ReactNode | - | 4.17.0 |
|
2020-10-10 17:49:50 +08:00
|
|
|
|
| autoFocus | 自动获取焦点 | boolean | false | - |
|
2021-02-01 17:06:20 +08:00
|
|
|
|
| bordered | 是否有边框 | boolean | true | 4.12.0 |
|
2021-07-27 20:28:45 +08:00
|
|
|
|
| controls | 是否显示增减按钮 | boolean | true | 4.17.0 |
|
2020-10-21 10:33:43 +08:00
|
|
|
|
| decimalSeparator | 小数点 | string | - | - |
|
2020-10-10 17:49:50 +08:00
|
|
|
|
| defaultValue | 初始值 | number | - | - |
|
|
|
|
|
| disabled | 禁用 | boolean | false | - |
|
2021-06-17 21:45:03 +08:00
|
|
|
|
| formatter | 指定输入框展示值的格式 | function(value: number \| string, info: { userTyping: boolean, input: string }): string | - | info: 4.17.0 |
|
2021-01-29 14:35:05 +08:00
|
|
|
|
| keyboard | 是否启用键盘快捷行为 | boolean | true | 4.12.0 |
|
2020-10-10 17:49:50 +08:00
|
|
|
|
| max | 最大值 | number | [Number.MAX_SAFE_INTEGER](https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Number/MAX_SAFE_INTEGER) | - |
|
|
|
|
|
| min | 最小值 | number | [Number.MIN_SAFE_INTEGER](https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Number/MIN_SAFE_INTEGER) | - |
|
|
|
|
|
| parser | 指定从 `formatter` 里转换回数字的方式,和 `formatter` 搭配使用 | function(string): number | - | - |
|
2021-03-05 12:04:39 +08:00
|
|
|
|
| precision | 数值精度,配置 `formatter` 时会以 `formatter` 为准 | number | - | - |
|
2020-10-21 10:33:43 +08:00
|
|
|
|
| readOnly | 只读 | boolean | false | - |
|
2021-10-30 22:25:12 +08:00
|
|
|
|
| prefix | 带有前缀图标的 input | ReactNode | - | 4.17.0 |
|
2020-10-10 17:49:50 +08:00
|
|
|
|
| size | 输入框大小 | `large` \| `middle` \| `small` | - | - |
|
|
|
|
|
| step | 每次改变步数,可以为小数 | number \| string | 1 | - |
|
2021-02-22 22:07:19 +08:00
|
|
|
|
| stringMode | 字符值模式,开启后支持高精度小数。同时 `onChange` 将返回 string 类型 | boolean | false | 4.13.0 |
|
2020-10-10 17:49:50 +08:00
|
|
|
|
| value | 当前值 | number | - | - |
|
2021-01-08 20:15:37 +08:00
|
|
|
|
| onChange | 变化回调 | function(value: number \| string \| null) | - | - |
|
2020-10-10 17:49:50 +08:00
|
|
|
|
| onPressEnter | 按下回车的回调 | function(e) | - | - |
|
2020-10-21 10:33:43 +08:00
|
|
|
|
| onStep | 点击上下箭头的回调 | (value: number, info: { offset: number, type: 'up' \| 'down' }) => void | - | 4.7.0 |
|
2017-12-01 19:28:41 +08:00
|
|
|
|
|
|
|
|
|
## 方法
|
|
|
|
|
|
2021-03-05 12:04:39 +08:00
|
|
|
|
| 名称 | 描述 |
|
|
|
|
|
| ------- | -------- |
|
|
|
|
|
| blur() | 移除焦点 |
|
2019-11-22 14:37:39 +08:00
|
|
|
|
| focus() | 获取焦点 |
|
2021-02-22 22:07:19 +08:00
|
|
|
|
|
|
|
|
|
## FAQ
|
|
|
|
|
|
|
|
|
|
### 为何受控模式下,`value` 可以超出 `min` 和 `max` 范围?
|
|
|
|
|
|
|
|
|
|
在受控模式下,开发者可能自行存储相关数据。如果组件将数据约束回范围内,会导致展示数据与实际存储数据不一致的情况。这使得一些如表单场景存在潜在的数据问题。
|
|
|
|
|
|
|
|
|
|
### 为何动态修改 `min` 和 `max` 让 `value` 超出范围不会触发 `onChange` 事件?
|
|
|
|
|
|
|
|
|
|
`onChange` 事件为用户触发事件,自行触发会导致表单库误以为变更来自用户操作。我们以错误样式展示超出范围的数值。
|