Sto eseguendo un'applicazione Laravel 5 che ha la sua vista principale visualizzata utilizzando React.js. Nella pagina, ho un semplice modulo di input, che sto gestendo con Ajax (rimandando l'input senza aggiornare la pagina). Convalido i dati di input nel mio UserController. Quello che mi piacerebbe fare è visualizzare i messaggi di errore (se l'input non supera la convalida) nella mia vista.Visualizzazione degli errori di convalida in Laravel 5 con React.js e Ajax
Vorrei anche che gli errori di validazione appaiano in base allo stato (inviato o non inviato) all'interno del codice React.js.
Come faccio a utilizzare React.js e senza aggiornare la pagina?
Ecco il codice: il codice
React.js:
var ReactCSSTransitionGroup = React.addons.CSSTransitionGroup;
var SignupForm = React.createClass({
getInitialState: function() {
return {email: '', submitted: false, error: false};
},
_updateInputValue(e) {
this.setState({email: e.target.value});
},
render: function() {
var text = this.state.submitted ? 'Thank you! Expect a follow up at '+email+' soon!' : 'Enter your email to request early access:';
var style = this.state.submitted ? {"backgroundColor": "rgba(26, 188, 156, 0.4)"} : {};
return (
<div>
{this.state.submitted ? null :
<div className="overall-input">
<ReactCSSTransitionGroup transitionName="example" transitionAppear={true}>
<input type="email" className="input_field" onChange={this._updateInputValue} ref="email" value={this.state.email} />
<div className="button-row">
<a href="#" className="button" onClick={this.saveAndContinue}>Request Invite</a>
</div>
</ReactCSSTransitionGroup>
</div>
}
</div>
)
},
saveAndContinue: function(e) {
e.preventDefault()
if(this.state.submitted==false) {
email = this.refs.email.getDOMNode().value
this.setState({email: email})
this.setState({submitted: !this.state.submitted});
request = $.ajax({
url: "/user",
type: "post",
data: 'email=' + email + '&_token={{ csrf_token() }}',
data: {'email': email, '_token': $('meta[name=_token]').attr('content')},
beforeSend: function(data){console.log(data);},
success:function(data){},
});
setTimeout(function(){
this.setState({submitted:false});
}.bind(this),5000);
}
}
});
React.render(<SignupForm/>, document.getElementById('content'));
UserController:
public function store(Request $request) {
$this->validate($request, [
'email' => 'Required|Email|Min:2|Max:80'
]);
$email = $request->input('email');;
$user = new User;
$user->email = $email;
$user->save();
return $email;
}
Grazie per il vostro aiuto!
cosa errore stai ottenendo? –
Scusa, è più che altro non capisco come passare gli errori di convalida a React.js – user1072337
Non potresti semplicemente inviare un HTTP 400 come risposta quando la convalida non viene passata e visualizzare l'errore nel callback "error" nel tuo richiesta di ajax? –