InputNumber数字输入框

通过鼠标或键盘,输入范围内的数值。

何时使用

当需要获取标准数值时。

代码演示

InputNumber 数字输入框 - 图1

基本

数字输入框。

  1. import { InputNumber } from 'choerodon-ui';
  2. function onChange(value) {
  3. console.log('changed', value);
  4. }
  5. ReactDOM.render(
  6. <InputNumber label="数字" min={1} max={10} defaultValue={3} onChange={onChange} />,
  7. mountNode);

InputNumber 数字输入框 - 图2

不可用

点击按钮切换可用状态。

  1. import { InputNumber, Button } from 'choerodon-ui';
  2. class App extends React.Component {
  3. state = {
  4. disabled: true,
  5. };
  6. toggle = () => {
  7. this.setState({
  8. disabled: !this.state.disabled,
  9. });
  10. }
  11. render() {
  12. return (
  13. <div>
  14. <InputNumber label="禁用" min={1} max={10} disabled={this.state.disabled} defaultValue={3} />
  15. <div style={{ marginTop: 20 }}>
  16. <Button onClick={this.toggle} type="primary">Toggle disabled</Button>
  17. </div>
  18. </div>
  19. );
  20. }
  21. }
  22. ReactDOM.render(<App />, mountNode);

InputNumber 数字输入框 - 图3

小数

和原生的数字输入框一样,value 的精度由 step 的小数位数决定。

  1. import { InputNumber } from 'choerodon-ui';
  2. function onChange(value) {
  3. console.log('changed', value);
  4. }
  5. ReactDOM.render(
  6. <InputNumber label="小数" min={0} max={10} step={0.1} onChange={onChange} />,
  7. mountNode);

InputNumber 数字输入框 - 图4

格式化展示

通过 formatter 格式化数字,以展示具有具体含义的数据,往往需要配合 parser 一起使用。

  1. import { InputNumber } from 'choerodon-ui';
  2. function onChange(value) {
  3. console.log('changed', value);
  4. }
  5. ReactDOM.render(
  6. <div>
  7. <InputNumber
  8. defaultValue={1000}
  9. label="金额"
  10. formatter={value => `$ ${value}`.replace(/\B(?=(\d{3})+(?!\d))/g, ',')}
  11. parser={value => value.replace(/\$\s?|(,*)/g, '')}
  12. onChange={onChange}
  13. />
  14. <InputNumber
  15. defaultValue={100}
  16. label="百分比"
  17. min={0}
  18. max={100}
  19. formatter={value => `${value}%`}
  20. parser={value => value.replace('%', '')}
  21. onChange={onChange}
  22. />
  23. </div>,
  24. mountNode);

API

属性如下

成员说明类型默认值
autoFocus自动获取焦点booleanfalse
defaultValue初始值number
disabled禁用booleanfalse
formatter指定输入框展示值的格式function(value: number | string): string-
max最大值numberInfinity
min最小值number-Infinity
parser指定从 formatter 里转换回数字的方式,和 formatter 搭配使用function( string): number-
precision数值精度number-
step每次改变步数,可以为小数number|string1
value当前值number
onChange变化回调Function(value: number | string)

方法

名称描述
blur()移除焦点
focus()获取焦点