防止退格键以避免擦除React文本框中的初始值

时间:2019-02-15 07:54:37

标签: reactjs textbox antd preventdefault

我在项目中使用 antd 。 代码是:

<FormItem  style={{'marginLeft':'-28px', 'marginTop':'10px'}}
>
 {getFieldDecorator('invoiceNumber', {
 initialValue: this.state.TxnNumber ? this.state.TxnNumber : "#",
  rules: [{                       
 required: false, message: 'Please Input Invoice!',
 }],
 })(
 <Input placeholder="S.O.NO#" style={{'width':'120px','height':'28px' }} onChange={(e)=>{e.preventDefault(); e.stopPropagation();                                   
 this.handleChange(0,e, 'invoiceNumber')}}  />
 )}                  
</FormItem>

handleChange = (index, e, field) => {
if(field == 'invoiceNumber')
    this.state.TxnNumber = e.target.value;
}

我希望在文本框中输入符号“#”作为初始值。还应防止退格键删除“#”符号。 如何在React中做到这一点?

1 个答案:

答案 0 :(得分:0)

只需使用受控输入,即可在处理程序方法中控制输入的初始值,如下所示:

class App extends React.Component {
  constructor() {
    super();
    this.state = {
      value: '#'
    }
  }

  handleChange = ({ target: { value } }) => {
    this.setState({ value: value || '#'  })
  }
  
  render(){
    const { value } = this.state;
    
    return (
      <input
        value={value}
        onChange={this.handleChange}
      />
    )
  }
}

ReactDOM.render(<App />, document.getElementById('root'));
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
<div id="root"></div>