Trybe - Exercícios

Este repositório contém todas as atividades de aprendizagem desenvolvidas por Mateus Alencar Alves enquanto estudava na Trybe 🚀

"A Trybe é uma escola do futuro para qualquer pessoa que queira melhorar de vida e construir uma carreira de sucesso em tecnologia, onde a pessoa só paga quando conseguir um bom trabalho."

O programa conta com mais de 1.500 horas de aulas presenciais e online e aborda introdução ao desenvolvimento de software, front-end, back-end, ciência da computação, engenharia de software, metodologias ágeis e habilidades comportamentais.

Introdução - Desenvolvimento Web ✅

Bloco 1: Introdução - Unix & Bash
  • 1-3: Unix & Bash - Part 1
  • 1-4: Unix & Bash - Part 2
  • 1-5: Shell Script
Bloco 2: Git, GitHub e Internet
  • 2-1: O que é e para que serve?
  • 2-2: Entendendo os comandos
  • 2-3: Internet - Entendendo como ela funciona
Bloco 3: Introdução - HTML & CSS
  • 3-1: HTML & CSS - Estruturas de página
  • 3-2: HTML & CSS - Primeiros passos em CSS
  • 3-3: HTML & CSS - Seletores e posicionamento
  • 3-4: HTML Semântico
  • 3-5: Projeto - HTML & CSS
Bloco 4: Introdução à JavaScript e Lógica de Programação
  • 4-1: JavaScript - Primeiros passos
  • 4-2: JavaScript - Array e loop For
  • 4-3: JavaScript - Objetos e funções
  • 4-4: JavaScript - DOM e seletores
  • 4-5: JavaScript - Trabalhando com elementos
  • 4-6: JavaScript - Eventos
  • 4-7: JavaScript - Web Storage
Bloco 5: JavaScript: DOM, Eventos e Web Storage
Bloco 6: HTML e CSS: Forms, Flexbox e Responsivo
  • 6-1: HTML & CSS - Forms
  • 6-2: Bibliotecas JavaScript e Frameworks CSS
  • 6-3: CSS Flexbox - Part 1
  • 6-4: CSS Flexbox - Part 2
  • 6-5: CSS Responsivo - Mobile First
  • 6-6: Projeto - Página inicial do Facebook
Bloco 7: Introdução à JavaScript ES6 e Testes Unitários
  • 7-1: JavaScript ES6 - let, const, arrow functions e template literals
  • 7-2: JavaScript ES6 - Objects
  • 7-3: Testes unitários em JavaScript
  • 7-4: Testando em pequenos passos
  • 7-5: Projeto - JavaScript Testes Unitários
Bloco 8: Higher Order Functions do JavaScript ES6
  • 8-1: JavaScript ES6 - Higher Order Functions - forEach, find, filter, some, every, sort
  • 8-2: JavaScript ES6 - Higher Order Functions - map e reduce
  • 8-3: JavaScript ES6 - spread operator, rest parameter, destructuring e mais
  • 8-4: Projeto - Zoo functions
Bloco 9: Assincronicidade & Callbacks
Bloco 10: Jest

Desenvolvimento Front-end ⏳

Bloco 11: Introdução - React
Bloco 12: React
Bloco 13: React
  • 13-1: Melhorando o reuso de componentes: props.children e PropTypes
  • 13-2: Ciclo de vida de componentes em React
  • 13-3: React Router
  • 13-4: Projeto - Movie Cards Library CRUD
Bloco 14: Metodologias Ágeis
Bloco 15: Testes em React
  • 15-1: Testando React com a React Testing Library
  • 15-2: Testando React com a React Testing Library - Parte 2
  • 15-3: Projeto - Testes em React
Bloco 16: Introdução ao Redux
  • 16-1: Introdução ao Redux
  • 16-2: React com Redux - Parte 1
  • 16-3: React com Redux - Prática
  • 16-4: React com Redux - Parte 2
  • 16-5: Testes síncronos com React-Redux
  • 16-6: Projeto - Tabela com filtros de dados
Bloco 17: Projeto React
Bloco 18: React & Context API
Bloco 19: Projeto Final de Front-end

Desenvolvimento Back-end ⏳

Bloco 20: Introdução - Bancos de dados relacionais
  • 20-1: Banco de dados SQL
  • 20-2: Encontrando dados em um banco de dados
  • 20-3: Filtrando dados de forma específica
  • 20-4: Manipulando tabelas
  • 20-5: Projeto - All For One
Bloco 21: Bancos de dados relacionais
  • 21-1: Funções mais usadas no SQL
  • 21-2: Descomplicando JOINs e UNIONs
  • 21-3: Stored Routines & Subqueries
  • 21-4: Projeto - Vocabulary Booster
Bloco 22: Bancos de dados relacionais
  • 22-1: Transformando ideias em um modelo de banco de dados
  • 22-2: Normalização, Formas Normais e Dumps
  • 22-2: Transformando ideias em um modelo de banco de dados - Parte 2
  • 22-3: Projeto - One For All
Bloco 23: Introdução - NoSQL
Bloco 24: Updates
  • 24-1: Updates Simples
  • 24-2: Updates Complexos - Arrays - Parte 1
  • 24-3: Updates Complexos - Arrays - Parte 2
  • 24-4: Projeto - Commerce
Bloco 25: Aggregation Framework
Bloco 25: Intro - NodeJS
Bloco 26: NodeJS
  • 26-1: Arquitetura de Software - Camada de Serviço
  • 26-2: Arquitetura web - Rest e Restful
  • 26-3: Projeto - Store Manager
Bloco 27: NodeJS
Bloco 28: Introdução - Deploy
Bloco 29: Arquitetura: SOLID e ORM
  • 29-1: Arquitetura - Princípios SOLID
  • 29-2: ORM - Interface da aplicação com o banco de dados
  • 29-3: ORM - Associations
  • 32-3: Projeto - API de Blogs
Bloco 30: Sockets
  • 30-1: Arquitetura de Software - Camada de View
  • 30-1: Sockets - TCP/UDP & NET
  • 30-2: Sockets - Socket.io
  • 30-3: Projeto - Webchat
Bloco 31: Projeto

Ciência da Computação ⏳

Bloco 32: Introdução à Python
  • 32-1: Introdução - Ciência da Computação
  • 32-2: Aprendendo Python
  • 32-3: Entrada e Saída de Dados
  • 32-3: Testes
  • 32-4: Projeto - Job Insights
Bloco 33: Programação Orientada a Objetos e Padrões de Projeto
  • 33-1: Introdução à programação orientada a objetos
  • 33-2: Herança, Composição e Interfaces
  • 33-3: Padrões de projeto
  • 33-4: Projeto - Relatórios de Estoque
Bloco 34: Redes e Raspagem de Dados
  • 34-1: Arquitetura de Redes
  • 34-2: Redes de computadores, ferramentas e segurança
  • 34-3: Raspagem de Dados
  • 34-4: Projeto - Tech news
Bloco 35: Algoritmos
  • 35-1: Complexidade de Algoritimos
  • 35-2: Recursividade e Estratégias para solução de problemas
  • 35-3: Algoritmos de ordenação e busca
  • 35-4: Projeto - Algoritmos
Bloco 36: Estrutura de Dados I: Arrays, Hashmaps e Sets
Bloco 37: Estrutura de Dados II: Listas, Filas e Pilhas