<aside>
💡 Este guia ensina a criar um projeto React com TypeScript usando o comando npx create-react-app my-app --template typescript
. Inclui a remoção de arquivos desnecessários e a modificação dos arquivos App.tsx
e index.tsx
para corresponder ao projeto fornecido. O resultado é uma estrutura de projeto limpa e organizada. Recursos adicionais são fornecidos para mais aprendizado.
</aside>
Instalar o Create React App:
npx create-react-app my-app --template typescript
Navegar até o Diretório do Projeto:
cd my-app
Estrutura Inicial do Projeto: Após a criação, a estrutura inicial do projeto será similar a esta:
my-app
├── node_modules
├── public
│ └── index.html
├── src
│ ├── App.css
│ ├── App.test.tsx
│ ├── App.tsx
│ ├── index.css
│ ├── index.tsx
│ ├── logo.svg
│ ├── react-app-env.d.ts
│ ├── reportWebVitals.ts
│ └── setupTests.ts
├── package.json
├── tsconfig.json
└── README.md
Para adaptar o projeto recém-criado para ficar igual ao projeto que você enviou, siga os passos abaixo:
Remover Arquivos Desnecessários:
src
:
App.css
App.test.tsx
logo.svg
reportWebVitals.ts
setupTests.ts
Após a remoção, a estrutura do src
deve ficar assim:
src
├── App.tsx
├── index.css
├── index.tsx
└── react-app-env.d.ts
Modificar o App.tsx
:
App.tsx
. O conteúdo deve ser:import React from "react";
//1 - Um componente SEMPRE deve começar com a primeira letra
//maiúscula
//2 - Todo componente DEVE ser uma função do JS
//3 - Todo deve retornar apenas UM elemento HTML
function App() {
return (
<div>
<h1>Projeto base em React com TypeScript</h1>
</div>
);
}
//4 - OBRIGATORIAMENTE o componente DEVE ser exportado
export default App;
Atualizar o index.tsx
:
index.tsx
importe e renderize corretamente o componente App
. O conteúdo deve ser:import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
ReactDOM.render(
<React.StrictMode>
<App />
</React.StrictMode>,
document.getElementById('root')
);
Após realizar as modificações, a estrutura final do projeto deve ser semelhante a esta:
my-app
├── node_modules
├── public
│ └── index.html
├── src
│ ├── App.tsx
│ ├── index.css
│ ├── index.tsx
│ └── react-app-env.d.ts
├── package.json
├── tsconfig.json
└── README.md