This tutorial is a part of official React documentation.
You will build a small tic-tac-toe game during this tutorial. This tutorial does not assume any existing React knowledge. The techniques you’ll learn in the tutorial are fundamental to building any React app, and fully understanding it will give you a deep understanding of React.
This tutorial is designed for people who prefer to learn by doing and want to quickly try making something tangible. If you prefer learning each concept step by step, start with Describing the UI.
In this tutorial, you'll build an interactive tic-tac-toe game with React.
App.js
, index.js
, styles.css
and a folder called public
Now let’s have a look at the files in the starter code.
App.js
The code in App.js
creates a component. In React, a component is a piece of reusable code that represents a part of a
user interface. Components are used to render, manage, and update the UI elements in your application. Let's look at the
component line by line to see what's going on:
export default function Square() {
return <button className="square">X</button>;
}
The first line defines a function called Square
. The export
JavaScript keyword makes this function accessible
outside of this file. The default
keyword tells other files using your code that it's the main function in your file.
export default function Square() {
return <button className="square">X</button>;
}
The second line returns a button. The return
JavaScript keyword means whatever comes after is returned as a value to
the caller of the function.
<button>
is a JSX element. A JSX element is a combination of JavaScript code and HTML tags that describes what you'd like to display. className="square"
is a button property or prop that tells CSS how to style the button. X
is the text displayed inside of the button and </button>
closes the JSX element to indicate that any following content shouldn't be placed inside the button.
styles.css
Click on the file labeled styles.css
in the Files section. This file defines the styles for your React
app. The first two CSS selectors (*
and body
) define the style of large parts of your app while the .square
selector
defines the style of any component where the className
property is set to square
. In your code, that would match the
button from your Square component in the App.js
file.
index.js
Click on the file labeled index.js
in the Files section. You won't be editing this file during the
tutorial but it is the bridge between the component you created in the App.js
file and the web browser.
import { StrictMode } from 'react';
import { createRoot } from 'react-dom/client';
import './styles.css';
import App from './App';
Lines 1-5 brings all the necessary pieces together:
App.js
.The remainder of the file brings all the pieces together and injects the final product into index.html
in the public
folder.
export default function Square() { return <button className="square">X</button>; }