Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Fixing the Todo Application | Hooks
Introduction to React

bookFixing the Todo Application

We had made a nonfunctional Todo application as we had used props to store the data. This time we will create a new Todo application using state variables.

We will start by creating the basic format of the Todo application, along with two state variables:

function Todo(props) {
return (
<div>
<ul></ul>
<form>
<input />
<button>
Add Item
</button>
</form>
</div>
);
}

We will create two state variables, text and todos.

function Todo(props) {
const [text, setText] = useState("");
const [todos, setTodos] = useState([]);

return (
<div>
<ul>{todos}</ul>
<form>
<input value={text} />
<button>
Add Item
</button>
</form>
</div>
);
}

Here todos is supposed to be an array containing <li> elements representing the Todos. By default, the todos array is empty. The text variable is supposed to be the input value of the <input> element. We’ve put {todos} inside the <ul> elements so that the data is automatically displayed when the array is populated.

We've also set the value attribute of the <input> element to {text}.

If we try typing anything in the input text, nothing will appear in the input box as the value attribute of the input box is set to text and text is set to an empty string.

We will fix that by writing a handleChange function for the <input> element:

function Todo(props) {
const [text, setText] = useState("");
const [todos, setTodos] = useState([]);


let handleChange = (e) => {
setText(e.target.value);
};


return (
<div>
<ul>{todos}</ul>
<form>
<input value={text} onChange={handleChange} />
<button>
Add Item
</button>
</form>
</div>
);
}

Now if we try running the application, it should look like this:

If you click Add Item it will refresh the page, and nothing will change. We want to add logic for that. We will create a new function for handling the submit action.

Using preventDefault method prevents the page reload. We will append a new <li> element to the todos array every time the Add Item button is clicked, but only if the text is not an empty string.

We will also set the text value to an empty string at the end to clear the input field. In code, it will look something like this:

function Todo(props) {
const [text, setText] = useState("");
const [todos, setTodos] = useState([]);



let handleChange = (e) => {
setText(e.target.value);
};

let handleSubmit = (e) => {
e.preventDefault();
if(text) {
setTodos(
todos.concat(
<li>{text}</li>
)
);
setText("");
}
};

return (
<div>
<ul>{todos}</ul>
<form>
<input value={text} onChange={handleChange} />
<button onClick={handleSubmit}>
Add Item
</button>
</form>
</div>
);
}

Now if you check the application, you should be able to add items, and it should appear in the form of a list:

Why did we create a `text` state variable?

Why did we create a text state variable?

Selecione algumas respostas corretas

Tudo estava claro?

Como podemos melhorá-lo?

Obrigado pelo seu feedback!

Seção 6. Capítulo 6
We use cookies to make your experience better!
some-alt