InputNumber 数字输入框

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

何时使用

当需要获取标准数值时。

代码演示

基本

数字输入框。

InputNumber数字输入框 - 图1

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

小数

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

InputNumber数字输入框 - 图2

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

不可用

点击按钮切换可用状态。

InputNumber数字输入框 - 图3

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

格式化展示

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

InputNumber数字输入框 - 图4

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

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()获取焦点