Skip to main content

Os dois front-ends: designer e engineer — Parte 3: Questionando as responsabilidades de um front-end

Terceiro artigo da série onde eu tento explicar meu ponto de vista sobre como o profissional front-end está se transformando.

Diego Eis

Nos outros dois artigos da série (Parte 1 e Parte 2), eu tentei desbravar os perfis de front-end que surgiram e até citei uma transformação que tem acontecido nos bastidores, onde é possível que designers se aproximem mais do código, juntamente com a ajuda do perfil front-end designer. E que essa aproximação tem acontecido com os back-ends, que estão cada vez mais interessados em tecnologias como NodeJS.

Nesse artigo, eu quero tentar questionar as responsabilidades de um
front-end
, tentando dar um outro ponto de vista.

Eu acho que no final você pode sair com mais perguntas do que respostas. Mas a
ideia é essa mesmo: cavar, procurar e encontrar bifurcações dos caminhos desse
profissional.

Escrevi ouvindo essa música. Recomendo para a leitura:
There is A Light That Never Goes Out — The Smiths


O front-end levanta e atende os requisitos de interface?

Historicamente o dono do layout é o Designer. É ele que levanta os requisitos de
como uma interface deve ser criada levando em consideração todos os estudos,
pesquisas e entrevistas que ele fez com o usuário. O front-end, nesse ponto,
pode ser um participante influenciador. Mas ele não levanta os requisitos.

Contudo, o front-end se torna um tradutor do designer ao implementar a primeira
camada de código.

Essa é uma responsabilidade compartilhada com o Designer, sendo que o Designer é o DONO da interface e do layout.

Se um layout vai pra produção com partes da interface mal feitas, com elementos
desalinhados, sem seguir as especificações de layout, é uma constatação que
tanto o designer quanto o front-end foram desleixados. O designer foi relaxado
por não ter tido a preocupação de avaliar e modificar o layout antes de ir para
produção e o front-end por não ter tido o esmero de seguir as especificações
definidas.


https://www.slideshare.net/diegoeis/ux-and-frontend/49

Exatamente por isso que Designers estão cada vez mais se aproximando do código front-end. O suficiente pra conseguir traduzir seu próprio layout pra código. E obviamente, isso faz que surjam cada vez mais ferramentas que ajudam os Designers a abstrair a camada de código, fazendo a ponte entre design e
back-end.

Quem trabalha nessa área sabe como é difícil encontrar front-ends realmente
capazes implementar interfaces perfeitas. Há muito tempo atrás tinha aquele
orgulho de fazer um layout pixel perfect, hoje não mais.

O front-end garante funcionalidade da interface em qualquer dispositivo?

Esse ponto é muito relacionado com a responsabilidade anterior e tem muito a ver
com o perfil que já falamos anteriormente: o front-end designer.

Mas sejamos sinceros: a maioria dos front-ends não começam a fazer as
funcionalidades e a interface iniciando pelo Mobile. Manja aquela história de
Mobile First? Na maioria da vezes isso não acontece na vida real.

Não é de hoje que existem plugins e outros softwares de design que dão esse
poder para os designers. Só para citar dois:
http://macaw.co/ e http://trymason.com. Obviamente o uso desses serviços ainda é muito restrito e só serve para alguns projetos.

Mesmo assim — por conta da falta de designers que codificam — a
responsabilidade de ter um projeto que funcione bem em tablets e mobile é sim do front-end.
O front-end designer é o responsável por essa tarefa. Contudo cabe ao designer dar todas as especificações. O que quase nunca acontece. :-)

O front-end garante a escabalabilidade e manutenibilidade do código?

A escalabilidade aqui se refere a de código e não de infra. Logo, nesse caso,
temos que falar sobre código legível/bonito.

Foram 46 pessoas respondendo a pergunta. 99% das respostas foram algo assim:

  • eu faço código bonito para outra pessoa ou eu mesmo entender posteriormente;
  • eu faço código bonito para executar um trabalho decente e impecável;
  • eu faço código bonito para reduzir complexidade e tempo;

Logo, se tirarmos da conta o ser humano, não precisamos nos preocupar com código bonito (que é diferente de código que funciona e com boa lógica). Código bonito não serve pra aumentar performance, não faz uma feature funcionar melhor, não faz a empresa vender mais. Mas um código bem escrito sim. Um código bem escrito é a mesma coisa que código bonito?

Aliás, artifícios como minificar código, image sprites e outras soluções, são gambiarras em sua essência para solucionar um problema de performance, afim de facilitar o download de arquivos no client e não de funcionamento de código. Com tecnologias como o HTTPv2, nenhuma dessas gambiarras serão necessárias.

Obviamente, códigos bem programados, com uma lógica impecável, faz a performance do sistema melhorar muito. Mas a beleza do código não.

Existe sim uma complexidade na organização de estrutura de arquivos,
nomenclatura e componentização no front-end que afeta e muito a escalabilidade e
manutenção do projeto. Todos sabem que CSS é fácil, mas se ele não for bem
organizado desde o início, vira um inferno.

O front-end pensa e calcula os custos de desenvolvimento, afim de defender o alto impacto por baixo custo?

Eu não acho que isso seja responsabilidade de um dev front-end. Diretor de
Tecnologia, Gerente de tecnologia, Operações, infraestrutura, DevOps são só
alguns dos profissionais que, na minha opinião, devem pensar nesses assuntos
muito antes de front-end.

Quando um dev resolve ir pra parte de gestão, ele fica sabendo que
desenvolvimento é tratado como custo nos projetos. Decisões como contratar uma empresa terceira ou um funcionário CLT fazem parte do cotidiano e causam mais impacto no custo do que a stack de front.

O front-end é responsável por garantir entregas rápidas, estáveis e testáveis, monitorar o software para correção ou prevenção de falhas

Garantir entregas, estabilidade e monitoração não é responsabilidade exclusiva
de front, mas do time inteiro. Mas coisas como monitoração é com o pessoal de
Operações, por exemplo.

Eu acho que todas essas responsabilidades são divididas em diversas
especialidades na empresa.

Por exemplo testes: praticamente todos os times, no momento do Pull Request,
fazem apenas a leitura do código e dão sugestões de melhorias, boas práticas e
tudo mais. Contudo quase nunca um membro do time baixa o código pra testar a
funcionalidade. Pasme: diversas vezes já vi códigos que passaram por um crivo rígido de code review, mas que não estavam funcionando.

Pull Request/Merge Request/Code Review são uma oportunidade para o dev testar a funcionalidade do código, além da lógica.

O front-end é o responsável por fazer a ponte entre back-end e design?

Eu já pensei isso no começo e no meio da minha carreira de front-end. Contudo,
conforme o penso foi passando, eu comecei a entender que isso era uma
esquizofrenia do sistema. O mercado estava tão quebrado, ou seja: o designer SÓ
queria fazer telinha e o back-end só queria escrever código de servidor. NENHUM
DOS DOIS era capaz de fazer o trabalho manjado de HTML/CSS/JS.

É bem esse ponto produtos como Sketch, Supernova,
Framer-X e tantos outros estão tentando resolver: não tem sentido você criar um design e ter alguém que replica isso em código. São dois processos que não precisam ser separados. Aliás, eles são separados hoje em dia pela falta de tecnologia.

Conversando com um ex dev do MarvelApp, ele disse:

The future is in collaboration. Rather than taking static pictures and trying to convert them into code, we are taking code and simplifying it. By visualising code, we can make it easier to digest, so designers can understand it and manipulate it.

Nenhuma tecnologia criada até agora dava conta de fazer isso. Vide Dreamweaver,
frontpage e outros que geravam código horrível. O problema principal desses
softwares era que eles tentavam gerar código que um ser humano pudesse dar
manutenção, ou seja, eles tentavam fazer um código bonito pra gente entender.

Mas veja, se um dev não precisasse abrir o código pra fazer manutenção, então, a
feiúra do código que esses sistemas geravam não seria problema. Mas naquele
tempo, a quantidade de código gerada era um problema por causa do tamanho do
arquivo final que afetava o download do site. Hoje nós temos problemas com
performance de carregamento de site e tentamos resolver isso de todos os jeitos
absurdos. Naquele tempo, fazer um site funcionar na conexão de um modem de
14kbps era realmente um desafio.

Além disso, o movimento de ter profissionais full-stack no time veio exatamente
pra acabar com o processo waterfall repetitivo que existia.

Conheço vários front-ends experientes que preparam o banco, criam a API e depois
implementam a interface… tanto fazem isso que eles nem deveriam ser considerados
front-end. Só são chamados assim, poois sua linguagem principal é Javascript.

Essa coisa de fazer ponte entre back e design não existe mais — ou não deveria
mais existir.

Um dev web experiente, já percebeu que não existe mais profissionais X ou Y.
Você é um desenvolvedor e resolve problemas.

E entenda: não sou a favor ou contra full-stack ou especialistas. Eu sou a favor
do profissional com perfil em
T
.

Colaboração

Esse não é o futuro do front-end, mas do mercado de desenvolvimento como um
todo. Pense num ambiente onde você automatiza boa parte do processo e passa seu
tempo realmente pensando na estrutura e arquitetura do sistema. Pense num
ambiente onde designers e front-ends usam uma mesma plataforma para editar a
mesma tela.

Esse é o tema do próximo artigo.