'de boş varsayılan değer ile nasıl kontrol edilen bir girdi oluşturulur Kontrol edilmek istediğim bir metin girişi ile ilgili bir sorun yaşıyorum, ancak boş bir değeri desteklemesi gerekiyor. (Her zaman olmasa da) '' olarak ayarlanır bu başlangıçta props.value yaygın olduğu, monte edildiğindeReact 15
import React, { Component, PropTypes } from 'react';
import { ControlLabel, FormControl, FormGroup } from 'react-bootstrap';
const propTypes = {
id: PropTypes.string.isRequired,
label: PropTypes.string,
onChange: PropTypes.func,
upperCaseOnly: PropTypes.bool,
value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
};
export default class UppercaseTextField extends Component {
constructor(props) {
super();
this.state = { value: props.value };
this.onChange =() => this.onChange();
}
onChange(e) {
let value = e.target.value;
if (this.props.upperCaseOnly) {
value = value.toUpperCase();
}
this.setState({ value });
this.props.onChange(e);
}
render() {
return (
<FormGroup controlId={id}>
<ControlLabel>{this.props.label}</ControlLabel>
<FormControl
type="text"
onChange={this.onChange}
defaultValue={this.props.value}
value={this.state.value}
/>
</FormGroup>
);
}
}
UppercaseTextField.propTypes = propTypes;
: İşte benim bileşenidir. Bu, React 15'i mutsuz yapar, çünkü değer = '' değeri düşürür, bu yüzden React, bir onChange'a sahip olsa bile, kontrolsüz bir girdi olduğunu düşünür.
bileşeni çalışır, ama konsolda bu uyarıyı alıyorum sevmiyorum:
Uyarı: FormControl tipi metninin kontrollü girişini değişiyor kontrolsüz olmak. Giriş elemanları kontrolsüz olarak kontrolsüz ( ) olmamalıdır (veya tersi). Bileşenin ömrü boyunca kontrollü veya kontrolsüz giriş elemanı kullanma arasında karar verin. Daha bilgi: http://facebook.github.io/react/docs/forms.html#controlled-components
Bu, herhangi bir uyarı olmadan 0.14.x iyi çalıştı, ama şimdi 15 hoşlanmadım görünüyor. İşlevleri korumak için nasıl temizlerim, fakat uyarıdan kurtulurum?
Maalesef, bu işe yaramıyor. Gerekli bir destek oluşturursam, eksik olduğunu bildiren bir uyarı alırsınız. Çünkü React, boş dizgeyi ve null props değerlerini doğrulama gerektiren amaçlar için yok sayar. Diğer önerilerinizi denedim ('this.state = {value: props.value || ''}'), ancak boş-string bunu FormControl'ün değer propını almadığından (React düştüğü için) Aynı uyarıyı alıyorum. FormControl, tepkisel önyüklemenin bir parçası olduğu için, onu değiştirmek istemiyorum. React 15 için işe yarayacak başka bir fikir, çünkü bu sürüm ile yeni bir uyarı mı? –
Takip ettiğimden emin değilim. React boş dize aksesuarı göz ardı etmez. İşte bir keman: https://jsfiddle.net/69z2wepo/41889/ – gurch101
Kemanında çalıştığını gördüm. React-bootstrap 0.29.3 ile bir şey olabilir mi? –