title | description | buttonTitle | parentId | layout | time | weight |
---|---|---|---|---|---|---|
Components |
asdf |
Next |
tutorial-todo-jsx |
tutorial |
90 |
3 |
In the metal-tutorial-todo
boilerplate there are already three components defined to help get you started. Each component is defined as an ES6 class that extends from Metal's JSXComponent
class:
class TodoApp extends JSXComponent {
}
Each component has a render function where the JSX template is defined. This creates the HTML you see in the demo page:
class TodoApp extends JSXComponent {
render() {
return (
<div>Hello, World</div>
);
}
}
The TodoApp
component will be the root level component. It will handle storing
the todo data, and the rendering of the other two components.
The TodoItem
component will render each item in the list of todos.
The TodoForm
component will render a form for adding new todo items to the
list. It will consist of a text input and add button.
It might seem more trouble than it's worth splitting up the Todo App into multiple components, but it's absolutely necessary when creating larger applications. This tutorial aims to teach you how to handle nested components for more complex use cases.