Skip to main content

Criando pequenos componentes dinâmicos com Javascript puro

Porque nem sempre precisaremos de um framework


Substituir o React? Tá maluco?!


Sabe aquela velha historia de que não precisamos utilizar um canhão pra matar um passarinho? Como já devem ter lido muitas vezes, nem sempre precisamos sobrecarregar um projeto com todos os recursos que uma lib oferece, nesse caso podemos optar por alternativas mais leves e com objetivos mais direcionados (como o Preact em relação ao React). Mas e quando o projeto é tão pequeno que nem mesmo a alternativa mais leve vale o esforço?

ES6 Rocks!


O ES6 nos trouxe uma lista enorme de novos e fantásticos recursos além de bons upgrades na sintaxe de alguns recursos já existentes. Um desses novos recursos em particular é extremamente util na criação de componentes dinâmicos: Template Literals (ou Template Strings) e é ele que iremos utilizar nos exemplos a seguir.

O que vamos precisar?


Meu objetivo nesse post é que seja simples o suficiente pra que não precisemos de nenhum tipo de configuração prévia (Nada de babel, Webpack, Gulp, etc). Utilizaremos constantes, arrow functions e template literals que já tem um suporte bastante decente nos browsers modernos. Vocês podem conferir mais sobre o suporte clicando aqui

O que criaremos?


Nada de muito especial, apenas uma lista simples de nomes que será gerada a partir de um array de objetos. Vamos começar?

Primeiro definimos nosso modelo de dados:

const data = [
{name: 'João',id: '1'},
{name: 'Manuel',id: '2'},
{name: 'Pedro',id: '3'},
{name: 'José',id: '4'}
]

Criamos então um elemento de referência em nosso HTML:

<ul data-list></ul>

E este será nosso componente dinâmico:

const listComponent = (data) => {
return data.map((item) => {
return (
`<li><span>${ item.id }</span><span>${ item.name }</span></li>`
)
}).join('')
}


O que fizemos? Primeiro atribuímos a nossa constante uma arrow function que recebe o argumento data. Em seguida invocamos o método map de nosso argumento que por sua vez invocará uma função de callback para cada item em nosso array, como nosso array contém quatro objetos, teremos então quatro elementos de lista em forma de template strings. Utilizamos então um recurso chamado string interpolation (${ data.value }) para inserir os dados de nossos objetos em nossa template. Por fim note acima que utilizamos o método join() após o map, fizemos isso para evitar algumas virgulas indesejadas na conversão do array em string.

Para prosseguir armazenamos nosso elemento HTML em uma constante:

const el = document.querySelector('[data-list]')

E pra finalizar invocamos o método innerHTML chamando a função listComponent(), que receberá nosso array data como argumento:

el.innerHTML = listComponent(data)


Esse tipo de abordagem na criação de componentes simples pode ser bastante útil quando precisamos, por exemplo, popular as options de um select dinamicamente ou criar listas de qualquer tipo.

Um ponto importante: Diferentemente do React e outras UI libs modernas que, em resumo, utilizam um DOM virtual absurdamente veloz, o componente que criamos será inserido no DOM real, que é muito mais lento, por isso recomendo fortemente que utilize-o com moderação.

Comments

Popular posts from this blog

Criando um filtro de busca customizável com JavaScript funcional

Tutoriais utilizando bibliotecas e frameworks para state management se tornaram comuns. Apesar disso, já que muita gente usa muitos frameworks diferentes, muitas vezes precisamos falar sobre a plataforma que permite isso tudo: a odiadíssima ferramenta que é o JavaScript, na sua forma mais pura — conforme descrito com documentações excelentes como a da MDN . Esse tutorial também pode ser útil para quem está iniciando em JavaScript e desenvolvimento em geral já começar com alguma ideia do que é programação funcional. O termo está se tornando popular e quem não subir nesse barco pode ficar para trás em pouco tempo. Não vamos adentrar nos detalhes do que é programação funcional neste artigo — isso é assunto para outras horas de conversa. Aqui, ficaremos no rápido e simples: alcançar nosso objetivo, evitando mutações dos dados e estado global. Iniciando o projeto Pelo bem da simplicidade, vamos manter tudo num único arquivo, que vai ter essa cara: <!DOCTYPE HTML> ...

Vue.js, React.js ou angular. O que escolher?

As estruturas JavaScript estão se desenvolvendo em um ritmo extremamente rápido, o que significa que hoje temos versões atualizadas frequentemente do Angular, ReactJS e de outro player neste mercado - Vue.js. Analisando o número de posições abertas em todo o mundo que exigem um conhecimento específico de um determinado framework. Como fonte, Indeed.com  chegando a seguinte distribuição de acordo com mais de 60.000 ofertas de emprego. Levando em conta os dados a seguir, será apresentado as principais vantagens e desvantagens de cada framework frontend para ajudar os profissionais de tecnologia ou engenheiros a escolher o melhor para suas necessidades de desenvolvimento. Prós e contras do angular Angular é uma estrutura de MVVM super-heróica de JavaScript, fundada em 2009, que é incrível para a criação de aplicativos da Web altamente interativos. Benefícios do Angular  Novos recursos como RXJS aprimorado, compilação mais rápida (em menos de 3 segundos),...

Como filtrar consultas no firebase

Para filtrar dados, combine um dos métodos de limite ou de intervalo com um método de ordenação ao criar uma consulta. Método Uso limitToFirst() Definir o número máximo de itens para retornar a partir do início da lista ordenada de resultados. limitToLast() Definir o número máximo de itens para retornar a partir do fim da lista ordenada de resultados. startAt() Retornar itens maiores ou iguais à chave ou ao valor especificado, dependendo do método de ordenação escolhido. endAt() Retornar itens menores ou iguais à chave ou ao valor especificado, dependendo do método de ordenação escolhido. equalTo() Retornar itens iguais à chave ou ao valor especificado, dependendo do método de ordenação escolhido. Ao contrário dos métodos de ordenação, você pode combinar várias funções de limite ou   de   intervalo. Por exemplo, combine os métodos startAt() e endAt() para limitar os resultados a um intervalo especificado de valores. Mesmo quando há apenas uma correspond...