O que eu respondo quando me perguntam "Por onde começar a programar?"

O mercado de tecnologia e desenvolvimento tem chamado bastante a atenção devido ao seu rápido crescimento, "baixa curva de aprendizado", altos salários e ótimos benefícios. Com quase 10 anos de experiência eu tenho cada vez mais recebido a pergunta "Por onde começar a programar?", e por conta disso eu comecei a consumir e compilar materiais que possam ajudar pessoas a começarem sua jornada na área de desenvolvimento web, principalmente focado em frontend.

Abaixo segue uma nota que tenho salva e envio para conhecidos que me perguntam sobre como começar. Não é nada complexo e provavelmente existem melhores formas de se aprender, principalmente considerando que diferentes pessoas possuem diferentes preferências sobre como estudar. Mas se você ou algum conhecido esta buscando uma forma leve e com baixo custo para começar a explorar essa área, segue abaixo alguns materiais e links que recomendo.

⚠️ Alguns conteúdos podem ser datados e talvez não façam sentido daqui alguns anos caso os materiais não sejam atualizados, mas para hoje (2022/2023) eu acredito que merecem a atenção dos novatos.


Notas pessoais: Como começar a aprender sobre desenvolvimento web focado em frontend

Na área de desenvolvimento existem muitos caminhos diferentes para seguir. Por sorte existem sites específicos que apresentam diferentes "roadmaps" para ajudar quem esta começando a entender o que precisa estudar no curto e no longo prazo de acordo com os objetivos individuals.

Dois sites bem conhecidos são o https://roadmap.sh/ (em inglês) e o https://techguide.sh/ (em português). Recomendo abrir ambos e explorar um pouco sobre o que cada área possui de requisitos. Mas vale lembrar que normalmente alguém que possui uns 20% de conhecimento desses roadmaps já conseguiria atuar como desenvolvedor junior ou estagiário no mercado.

Nós por aqui atuamos principalmente com desenvolvimento web e eu sempre recomendo seguir um currículo que ensine o básico de web antes de se aprofundar em tecnologias mais avançadas. Aplicativos web rodam principalmente com HTML, CSS e Javascript, então os materiais que recomendo começar estudando são os que focam nessas tecnologias. Entendendo bem essas tecnologias fica mais fácil para se aprofundar em Frontend ou Backend ao longo do tempo.

Cursos Desenvolvimento

Esses cursos do Curso em Vídeo são ótimos para começar a estudar. Eu recomendo assistir com bastante atenção e seguir os exemplos que ele apresenta nas aulas. Se sentir que esta muito fácil, acelera a velocidade de reprodução pra 1.5x ou 2x mas não deixe de assistir, fazer anotações e testar os códigos por conta própria.

Durante os cursos, além do conteúdo principal, o professor Gustavo irá introduzir ferramentas como Visual Studio Code, Gimp, Git (+ Github), entre outras. Se estiver começando e não possuir experiência com essas tecnologias e ferramentas, eu recomendo utilizar as mesmas que ele apresenta e tentar explorar mais sobre essas ferramentas pesquisando sobre elas no youtube e google.

  1. Curso em Vídeo: Curso HTML5 e CSS3: módulo 1 de 5
  2. Curso em Vídeo: Curso HTML5 e CSS3: módulo 2 de 5
  3. Curso em Vídeo: Curso HTML5 e CSS3: módulo 3 de 5
  4. Curso em Vídeo: Curso HTML5 e CSS3: módulo 4 de 5
  5. Curso em Vídeo: Algoritmo
  6. Curso em Vídeo: Javascript

Cursos e Playlists complementares

Além dos cursos acima que são ótimos para dar uma base geral de conhecimento sobre desenvolviment oweb, recomendo também esses cursos complementares que vão dar uma noção melhor de como utilizar Git com Github e Linux, que são assuntos bastante presentes no dia a dia de quem trabalha com desenvolvimento

Links extras

  • https://www.cursoemvideo.com - Plataforma com cursos gratuitos na área de tecnologia. Após finalizar os cursos é possível pagar uma taxa para emitir um certificado digital se tiver interesse.
  • https://www.freecodecamp.org - Plataforma sem fins lucrativos com cursos interativos em várias áreas diferentes. A plataforma é originalmente em inglês mas possui bastante conteúdo em português também. Após finalizar os cursos é possível emitir um certificado digital gratuitamente.
  • https://www.theodinproject.com - Uma das plataformas mais bem avaliadas para formação Fullstack (frontend + backend). O material é bastante atualizado e amplo, mas o conteúdo é apenas em inglês.
  • https://web.dio.me - Plataforma com cursos, bootcamps, labs, iterações sociais e muito mais. Possui muitos materiais desenvolvidos por pessoas que já atuam no mercado. Também possui um sistema de gamificação que te da pontos por consumir os materiais (ex: terminar cursos). Eles tem como missão ensinar tecnologia e conectar os melhores talentos com as empresas mais inovadoras. Não consegui explorar muito a plataformar, mas me parace um ótimo lugar para quem quer começar a estudar e ficar de olho nas oportunidades do mercado.

Esse tópico tem muita informação bacana - técnica - então vou falar um pouco sobre o que eu respondo quando alguém me pergunta isso, e é uma resposta menos focada em skills e aprendizado:

Por que você quer aprender a programar?

Apesar de parecer uma pergunta que está só 'peitando' o que a pessoa quer, acho que é uma reflexão válida, principalmente se você consegue perceber que a pessoa quer começar pelo hype e não tem muita noção do que vai encontrar pela frente.

Eu tenho muitos amigos que me perguntam como começar, se vale a pena fazer o Bootcamp X ou o curso Y, que os salários de TI são altíssimos, etc. E sinceramente? Zero problemas com isso, cada um com sua motivação - eu mesma voltei a "fazer sites" (que era o que eu fazia na época) porque o mercado de TI estava em alta pra quem queria sair do Brasil :P

Programar é uma delícia - pra alguns - e é uma dopamina ferrada você conseguir quebrar tua cabeça e no fim resolver um problema, mas eu acho que se a gente conseguir orientar melhor as pessoas sobre motivação, resiliência e quaisquer outras palavras bonitas, a gente consegue diminuir o índice de desistência e frustração, hehe.

E não me entendam mal, eu sou absolutamente CONTRA aquele terrorismo de 'vida real' que você só mostra os perrengues, mas acho que além de compartilhar onde/como começar, vale também você mostrar os seus porquês de continuar na área :)


E respondendo a pergunta de forma mais técnica, eu sempre indico que a pessoa NÃO comece logo de cara com linguagem A, B ou C ou framework Z ou W. Eu indico que ela estude muito coisas como lógica, funções, algoritmos... Fundamentos mesmo. Pra método de estudo, eu não sou uma pessoa que consegue ficar muito focada em teoria por muito tempo, então sempre alterno conteúdo teórico com exercícios (e uma pausa pro cafezinho) :)

Eu comcei do zero fazendo o curso de algoritmo do curso em video, e recomendo para qualquer um que esta começando, principalmente para aprender lógica.

Só complementando: eu sou do time de educação da DIO e lá nós temos essa missão de além de ensinar a tecnologia, também conectarmos os melhores talentos com as empresas mais inovadoras.

Pra quem tiver interesse em saber como funciona esse Talent Match: https://web.dio.me/course/turbine-seu-curriculo-na-dio/learning/a2dd47e9-8b67-4317-b757-6f96b5412a63

Muito bom saber sobre a missão da plataforma [@caiolongo](https://www.tabnews.com.br/caiolongo). Até atualizei a publicação para refletir essa descrição de forma mais assertiva. Eu realmente não consegui explorar o quanto gostaria, mas conheço pessoas que usaram e gostaram bastante.De muitas outas plataformas que acessei essa me pareceu uma das mais completas com conteúdo gratuito em português. Parabéns pelo trabalho!

A Rocketseat também tem um ótimo curso grátis (Discover) para introduzir iniciantes da programação principalmente para quem quer focar em Javascript/Typescript: https://rocketseat.com.br/

Consumi pouquissímo conteúdo da rocketseat. Do que consumi alguns anos atrás eu não senti que seria uma boa opção para quem está começando na área sem nenhuma referência. Eu não cheguei a consumir conteúdo deles nos últimos anos. Você acha que esse curso **Discover** é bom para quem não tem nenhuma base? Eu por exemplo evitaria introduzir Typescript para alguém que mal entende como Javascript funciona. Entendo que no mercado é essencial utilizar Node, NPM, configurar pré-compiladores, etc. Mas é possível fazer muita coisa sem nem mesmo ter que instalar e configurar Node (e NPM), e acho que conteúdos para iniciates deveriam possuir o mínimo de atrito possível para poder criar a base de conhecimento sobre o que realmente roda na web.
Sim, o Discover é justamente para quem não tem base, não é semelhantes aos conteúdos mais avançados e focados, como os de React. Esse é mesmo para o básico mesmo, desde o a introdução em html e css, avançando um pouco tem introdução a git, etc. E na parte de javascript é javascript mesmo, realmente não faz sentido introduzir typescript para quem está iniciando.

Para front-end recomendo fortemente essa plataforma:

https://www.origamid.com/

Sou aluno da origamid e realmente é um curso muito fora da curva no que diz respeito a front-end! O professor tem uma didática incrível e tem muito conteudo.
Já conhecia a plataforma e realmente acho uma ótima opção para quem esta disposto a investir. Mas eu evitaria indicar a alguém que invista mais de R$1.000,00 em uma plataforma. Digo o mesmo sobre a Alura por exemplo. Ambas parecem ótimas plataformas, mas para quem esta começando eu sempre tento indicar conteúdos gratuítos ou com baixo investimento. Muitas pessoas começam a estudar e acabam não avançando ao ponto de atuar na área, o que significaria um prejuízo definitivo sobre esse investimento feito. Indicar um curso ou plataforma que custe mais de mil reais seria uma enorme barreira para muitas pessoas, principalmente se ela não estiver muito tempo para se dedicar aos estudos, o que significaria um longo prazo para ter retorno do investimento.
O Anual da Origamid é uns R$384,00, o vitalício (que eu peguei) tá saindo por R$384,00. Mês passado já adicionaram o curso de typescript e sempre estão atualizando os cursos. Cursos gratuitos tem a vantagem do dindin $$$ mas peca por não ter um certificado.

Já tinha ouvido falar deste método do Pomodoro, acho interessante e vejo ser bastante funcional.

Irei aplicar aos meus estudos, obrigado por compartilhar e destrinchar toda essa explicação.

Tem um game na plataforma da Steam que aplica essa ideia do Pomodoro, super bacana, com um lo-fi e com a possibilidade de criar uma ambientação.

O app se chama: Virtual Cottage, é gratuito.

Hoje tenho muita dificuldade na contratação de novos colaboradores devido a falta de base (o velho alicerce de tudo). Vejo muito a discussão de linguagem A ou B, de frameworks e ferramentas em geral, mas sinto falta da base de tudo: raciocínio lógico e design patterns.

Eu uso ferramentas como essas, para me lapidar e sempre manter meu raciocínio rápido:

Acho essas ferramentas muito úteis para quem esta buscando se preparar para entrevistas. Inclusive tenho algumas anotações também sobre esse assunto. Em 2020, por cerca de 3 meses eu usei algumas dessas ferramentas para me preparar para entrevistas internacionais e com certeza ajudaram muito para eu conseguir ir bem em várias entrevistas e acabar sendo contratado. Uma ferramenta que gostei muito na época foi a [leetcode](https://leetcode.com/). Mas temos que tomar cuidado em indicar essas ferramentas para quem esta começando. As pessoas possuem tempo e energia limitados, e não sabendo nem o básico de web e ferramental, talvez seja um precoce mergulhar nessas plataformas para praticar algorítmos e estruturas de dados. Normalmente existe o suficiente sobre isso nos cursos de Javascript. Na freecodecamp mesmo existe um ótimo curso focado em algorítimos e estrutura de dados. Dito isso, se alguém estiver começando e estiver interessado em estudar algorítmos e estruturas de dados de uma forma mais ativa, recomendo o livro [Entendendo Algoritmos: Um Guia Ilustrado Para Programadores e Outros Curiosos](https://www.amazon.com.br/Entendendo-Algoritmos-Ilustrado-Programadores-Curiosos/dp/8575225634). Ele apresenta conceitos básicos e avançados de uma forma super leve e descontraída.

Para quem estiver interessado tem também o https://exercism.org/ Tem uma gama de linguagens bem interessante essa plataforma!!!

A plataforma parece realmente muito boa. Acho que pra quem tem um bom nível de inglês seria ótimo combinar a trilha do [The Odin Project](https://www.theodinproject.com) com uma plataforma como Exercism. Provavelmente teria algum conteúdo duplicado, mas acho esse tipo de redundância ótimo para reforçar conceitos.

Sem dúvida o conteúdo do Gustavo Guanabara é um dos melhores pra quem quer começar. Me ajudou muito na faculdade e sempre recomendo pra quem me pergunta por onde começar!

bem bom os videos dele, foi um up pra minha experiencia,recomendo fortemente os videos dele

Já estava vindo aqui recomendar o The Odin Project e percebi que já deixou na sessão de links extras haha.

Ótima coletânea de conteúdos pra quem está decidindo por onde começar a programar, acaba sendo tanta opção que fica difícil de escolher algo no início, acho que o mais importante nessa fase inicial é escolher uma e focar nela mesmo, depois disso é mais uma questão de testes práticos e ir aprendendo o que você precisa no meio do caminho

Eu gostei bastante do [The Odin Project](https://www.theodinproject.com/). Acho que pra quem não tem dificuldade em consumir materiais em inglês fica muito mais fácil para encontrar bons materiais de estudo gratuitos, e o The Odin Project é um ótimo exemplo.

Cara, sensacional! Estou mandando para varios amigos ja! Fica aqui mais uma contribuição, é tipo o roadmap.sh só que em português mesmo: https://www.trilha.info/

Isso aqui está só o ouro