Neste mini projeto, você criará uma galeria de produtos em uma página web. Cada produto tem como base dados provenientes de um arquivo data.js. Esse exercício é uma ótima oportunidade para melhorar suas habilidades com manipulação de DOM e eventos em JavaScript, além de praticar a criação de uma interface visual simples e interativa usando apenas HTML, CSS e JavaScript.
Para começar o projeto, utilize a seguinte estrutura já do repositório:
index.html
: Página principal do projeto.
styles.css
: Estilização dos elementos.
data.js
: Arquivo contendo os dados dos produtos (nome, preço, imagem e imagem de fundo).
E crie o seguinte arquivo:
script.js
: Arquivo JavaScript para controlar a lógica de interação e manipulação das imagens.
No arquivo index.html
, implemente a renderização dos produtos utilizando a DOM e adicione as imagens com as propriedades definidas no arquivo data.js
.A partir dos dados presentes no array de produtos em data.js
. Para cada produto, insira uma tag <img>
com a classe imageProduct
, configurando o atributo src com o valor de srcImg de cada objeto no array.
👀 Dicas: Use o método forEach para iterar sobre os produtos.
Implemente a funcionalidade de ordenação dos produtos com base em três critérios: menor preço
, maior preço
e avaliação
.O comportamento da ordenação deve alterar a ordem dos produtos exibidos na tela conforme o critério selecionado.
Crie um controle de filtro de preço máximo utilizando um input de tipo range. Os produtos cujo preço seja superior ao valor definido pelo range devem ser excluídos da exibição, mostrando apenas os produtos que atendem ao critério de preço.
Implemente um filtro de pesquisa para exibir apenas os produtos que correspondem ao nome digitado pelo usuário. A lista de produtos exibidos deve ser filtrada dinamicamente para mostrar apenas aqueles cujo nome contém o texto digitado pelo usuário. O filtro deve ser sensível a maiúsculas/minúsculas e ser aplicado assim que o usuário começar a digitar.
Adicione um menu responsivo que seja acessível em dispositivos móveis. O menu deve ser oculto por padrão e aparecer quando o usuário clicar em um ícone de menu (hamburger). O menu deve permitir navegar pelas opções da página e ser ocultado novamente ao clicar em uma opção ou no próprio ícone de menu.
Requisito extra 1: Adicione uma animação suave para a transição das imagens ao passar o mouse sobre elas.
Requisito extra 2: Implemente um sistema de modal para exibir detalhes completos do produto ao clicar sobre a imagem. Mostre o nome, preço, descrição e outras informações no modal.
Temos uma sugestão de design no Figma. Entretanto, fique à vontade para montar a aplicação conforme a sua criatividade.
- Manipulação do DOM com JavaScript
- Uso de eventos como mouseover e mouseout
- Interação dinâmica com os dados (exibição de imagens e informações)
- Uso de funções de manipulação de arrays (Filter, ForEach e Sort)
- Estilização simples com CSS para criar um layout agradável e responsivo
- Animações e transições para melhorar a interação com o usuário
- Conhecimento básico de HTML, CSS e JavaScript.
- Noções sobre como manipular elementos do DOM e adicionar eventos com JavaScript.