poo não é estritamente sobre classes porque também existe herança por prototipação, mas isso só existe no javascript e numa linguagem morta da xerox criada nos anos 80.

mas é interessante como introduziram a palavra "class" em javascript, não? por que o fizeram? não é um erro conceitual meu. em javascript existe class que por baixo dos panos não é class, literalmente com o nome class.

as linguagens mais tradicionais que suportam este paradigma não se aproximaram do javascript, mas javascript a cada atualização traz mais syntax sugars e conceitos pra se aproximar dessas linguagens. a última atualização recebeu itens relacionados a encapsulamento, o que já é muito maduro em java e c#, por exemplo, há décadas.

se é pra aprender poo, por que aprender primeiro em uma linguagem que tem muitas particularidades neste paradigma, ao invés de aprender em linguagens mais comumente utilizadas no mercado com este paradigma e cujos conceitos são comuns entre elas?

mas é interessante como introduziram a palavra "class" em javascript, não?

Eles fizeram como fazem com o C++. Agradar todo mundo.

itens relacionados a encapsulamento

JS sempre teve. Só não tinha a sintaxe que o alguns gostam kkkk Closuses sempre estiveram no JS.

se é pra aprender poo, por que aprender primeiro em uma linguagem que tem muitas particularidades neste paradigma

Para aumentar a inteligencia e ter uma bagagem melhor para criar coisas novas e criativas! Para isso é preciso conhecer e aprender coisas como essa que são bem diferentes!

Além de que, JS continua sendo prototipico. Pegar algum lib super otimizada vai ver prototipos lá! E não conhecer isso vai ser um grande problema!

Outra questão! JS já era comum no mercado de back com node desde 2009(ou rihno e outros). Mesmo sendo es5, com o es6(2015) e posteriormente implementado(a pra se dizer que totalmente em 2017). O povo fazia grandes maravilhas do mesmo modo.

O que a TC39 quis foi melhorar o inicio do programador que já programava em linguagens comuns. Que não queria aprender JS! Um programador velho é um programador que não gosta de aprender.

cujos conceitos são comuns entre elas?

Os conceitos sempre estiveram lá!

  • encapsulamento
  • herança
  • herança multipla
  • polimorfismo

Mas não com a sintaxe que alguns estava acostumados!

OBS: Self(da qual JS deriva) foi criada na Sun e Lua(criada na puc) são prototipicas! Lua foi criada sem class e o povo na época achou um tipo de desrepeito kkkk Mas lua é super bem conceituada e usada no mundo todo.

OBS2: O modo prototipico do JS não é bonito! Não da pra negar não! Mas eu acho que deveriam melhorar isso, no lugar de inserir outra forma! :)

interfaces, sobrecarga de métodos e construtores, enums, necessidade de implementar coisas simples como "classes" abstratas na unha... ter que implementar na mão, fazer workarounds, usar libs... claros indicativos de que "os conceitos sempre estiveram lá" é uma meia verdade.
Agora entendi seu ponto. Elucidou as minhas dúvidas! Tudo isso que você esta dizendo não é nada relacionado aos conceitos OOP diretamente. Principalmente de Simula e Smalltalk que são a origem de OOP. Ter que implementar na mão é algo estranho, pq nesse caso o programador não quis mudar sua forma de pensar. Ele esta querendo trazer o que sabe de outra linguagem e socar em JS. Esse é um erro comum. Mas que não deveria acontecer. É isso que eu digo sobre programador velho! Ele não quer aprender. Ele quer socar o que sabe de outra linguagem na nova! E isso gera grandes frustrações! Por isso uma linguagem que implementa OOP de uma forma diferente não é bem aceita. Pois não querer aprender e querer usar as mesmas coisas que usava em outra linguagens gera problemas! > os conceitos sempre estiveram lá Quais são os conceitos de OOP pra você? você segue a definição de Peter Wegner no artigo dele? Estou bem curioso! esta discussão esta muito boa! Abraços
você parte da premissa que todo "programador velho" é preguiçoso, e além de essa ser uma afirmação desrespeitosa, é inválida nessa discussão porque não apenas não sou um programador "velho", muito menos preguiçoso, como trabalho também diariamente com javascript, entre outras tecnologias. existem motivos sólidos para o mercado não adotar o javascript em projetos críticos, dentre eles está o suporte anêmico a poo. é mais provável uma empresa iniciar o desenvolvimento de um ERP hoje em pleno 2023 utilizando object pascal do que javascript. por que a minha equipe deve adotar uma linguagem em que "os conceitos de poo estão lá", mas que dificultam o desenvolvimento e consequentemente testes e manutenção? todas as demais linguagens orientadas a poo seguem determinado padrão de desenvolvimento, mas minha equipe "tem que aprender (tempo e dinheiro) coisas novas" (que não são novas) porque (apenas) em javascript é implementado diferente e para não ser taxado de programador velho e preguiçoso pelo uriel. "não é porque posso, que devo". tem que ser bom para o projeto, e não para o programador. os outros são velhos e preguiçosos ou você gosta de bater em prego com chave de fenda e acha que todos deveriam fazer o mesmo?
também convenhamos, é muito mais vantajoso usar JS funcional do que orientado a objetos. Mas acredito também que colocando o ts na balança isso mude um pouco, já que torna a orientação a objetos do javascript muito melhor. Como toda ferramenta a linguagem tem casos de uso e funciona melhor em determinados ambientes. Assim como toda linguagem permissiva, o javascript sofre muito do mau uso de pessoas que querem programar da mesma forma com que em outras linguagens, o que é um erro absurdo. Se você quer programar estilo Java, passe longe de javascript, é uma questão de gosto e de organização do projeto. Nem sempre POO vai ser o melhor e nem o mais indicado, parece ser óbvio, mas nem todo mundo tem esse conhecimento.
exato. é o que venho tentando dizer. sobre o typescript: sim, é mais seguro, tira bastante a permissividade do js e implementa coisas como interface, por exemplo, mas não da melhor forma (basta ler os códigos transpilados). tenho um webservice na nossa empresa que desenvolvi em node.js e typescript, e atende muito bem a sua proposta. ficou leve, é rápido, é escalável, está fácil de testar, mas tendo participado de outros projetos mais críticos com outras tecnologias na mesma empresa (com C# e ASP .NET Core), ficou evidente pra mim o limite. e tá tudo bem... linguagem é ferramenta, a gente usa o que serve para o projeto, não existe bala de prata em nenhum caso.