Otimizando menus
Otimizando menus
O menu é um dos pontos críticos de performance em uma loja. Por estar presente em (quase) todas as páginas, quando mal otimizado, pode fazer com que qualquer página tenha problemas de performance independente do quão bem implementada ela esteja. Neste passo, vamos aprender como otimizar a sua implementação para, não só viabilizar a edição deste no Site Editor, como reduzir o overhead de blocos necessários em sua definição
Props vs children
Em geral uma implementação de menu em uma loja segue o seguinte padrão:
{
"[email protected]:menu#category-menu": {
"children": [
"menu-item#category-electronics",
"menu-item#category-major-appliances",
"menu-item#category-small-appliances"
]
},
"menu-item#category-electronics": {
"props": {
"id": "menu-item-category-electronics",
"type": "custom",
"iconId": null,
"highlight": false,
"itemProps": {
"categoryId": 153,
"type": "internal",
"href": "/electronics/",
"noFollow": true,
"tagTitle": "Electronics",
"text": "Electronics"
}
}
},
...
}
Existem dois problemas em implementar um menu desta forma:
-
Por se usar o
children
, o menu passa a ter implementação parecida com a de um layout, o que faz com que todo o conteúdo dentro dele não seja facilmente editável no Site Editor -
Para cada novo menu que for criado, é necessária a definição de um novo bloco, o que aumenta o overhead dos blocos que são necessários para compor uma página
Atividade
-
Para melhorar, então, a performance do menu da nossa Appliance Store, vá até o arquivo
/store/blocks/header/category-menu.jsonc
e remova sua seção dechildren
:{ "[email protected]:menu#category-menu": { - "children": [ - "menu-item#category-electronics", - "menu-item#category-major-appliances", - "menu-item#category-small-appliances" - ] } ... }
NOTA: Não apague as definições destes blocos, eles estão sendo utilizados em outros lugares
-
Adicione agora uma nova seção de
props
e um array deitems
:{ "[email protected]:menu#category-menu": { + "props": { + "items": [] + } } ... }
-
Para fechar, para cada um dos
menu-items
que tínhamos ("menu-item#category-electronics"
;"menu-item#category-major-appliances"
;"menu-item#category-small-appliances"
), adicione suasprops
como itens do array que criamos:{ "[email protected]:menu#category-menu": { "props": { "items": [ + { + "id": "menu-item-category-electronics", + "type": "custom", + "iconId": null, + "highlight": false, + "itemProps": { + "categoryId": 153, + "type": "internal", + "href": "/electronics/", + "noFollow": true, + "tagTitle": "Electronics", + "text": "Electronics" + } + } + ... ] }
O resultado esperado é um menu exatamente igual ao que tínhamos, mas que agora conseguimos controlar pelo Site Editor e adicionar novos itens.
Está com dúvidas?
Veja o gabarito para esta etapa ou acompanhe nosso [office hours] no canal VTEX Developers(https://www.youtube.com/c/VTEXDevelopers)
Ajude-nos a fazer este conteúdo melhor!
Os cursos do VTEX IO são de código aberto. Se você perceber algum problema, pode abrir um pull request!
Faça uma contribuiçãoUpdated 11 months ago