Browse Source

Adding `e.preventDefault()` to `handleSubmit`,

Also added plain `return`, updated text.
main
Michael Randers-Pehrson 11 years ago
parent
commit
83cf623476
  1. 16
      docs/tutorial.md

16
docs/tutorial.md

@ -481,16 +481,17 @@ Let's make the form interactive. When the user submits the form, we should clear
```javascript{3-13,16-18} ```javascript{3-13,16-18}
// tutorial16.js // tutorial16.js
var CommentForm = React.createClass({ var CommentForm = React.createClass({
handleSubmit: function() { handleSubmit: function(e) {
e.preventDefault();
var author = this.refs.author.getDOMNode().value.trim(); var author = this.refs.author.getDOMNode().value.trim();
var text = this.refs.text.getDOMNode().value.trim(); var text = this.refs.text.getDOMNode().value.trim();
if (!text || !author) { if (!text || !author) {
return false; return;
} }
// TODO: send request to the server // TODO: send request to the server
this.refs.author.getDOMNode().value = ''; this.refs.author.getDOMNode().value = '';
this.refs.text.getDOMNode().value = ''; this.refs.text.getDOMNode().value = '';
return false; return;
}, },
render: function() { render: function() {
return ( return (
@ -508,7 +509,7 @@ var CommentForm = React.createClass({
React attaches event handlers to components using a camelCase naming convention. We attach an `onSubmit` handler to the form that clears the form fields when the form is submitted with valid input. React attaches event handlers to components using a camelCase naming convention. We attach an `onSubmit` handler to the form that clears the form fields when the form is submitted with valid input.
We always return `false` from the event handler to prevent the browser's default action of submitting the form. (If you prefer, you can instead take the event as an argument and call `preventDefault()` on it.) Call `preventDefault()` on the event to prevent the browser's default action of submitting the form.
##### Refs ##### Refs
@ -562,16 +563,17 @@ Let's call the callback from the `CommentForm` when the user submits the form:
```javascript{6} ```javascript{6}
// tutorial18.js // tutorial18.js
var CommentForm = React.createClass({ var CommentForm = React.createClass({
handleSubmit: function() { handleSubmit: function(e) {
e.preventDefault();
var author = this.refs.author.getDOMNode().value.trim(); var author = this.refs.author.getDOMNode().value.trim();
var text = this.refs.text.getDOMNode().value.trim(); var text = this.refs.text.getDOMNode().value.trim();
if (!text || !author) { if (!text || !author) {
return false; return;
} }
this.props.onCommentSubmit({author: author, text: text}); this.props.onCommentSubmit({author: author, text: text});
this.refs.author.getDOMNode().value = ''; this.refs.author.getDOMNode().value = '';
this.refs.text.getDOMNode().value = ''; this.refs.text.getDOMNode().value = '';
return false; return;
}, },
render: function() { render: function() {
return ( return (

Loading…
Cancel
Save