Refatorando blocos
Refatorando blocos
Alguns blocos ao longo do tempo são substituídos por outros não só para aumentar a flexibilidade e facilidade de operação, mas também para otimizar o seu comportamento e performance.
O Slider Layout (conhecido no curso de Layouts Complexos) foi aprimorado para que usasse lazy load no conteúdo carregado. Isto quer dizer que produtos e imagens só são carregados quando o usuário, de fato, as solicita. Este tipo de comportamento não está disponível na Shelf e Carrossel, e para otimizar ainda mais a performance, vamos ver como podemos substituí-los.
Atividade
-
No arquivo
home.jsonc
declare dois blocos de texto para substituir os títulos:// store/blocks/home/home.jsonc { ... + "rich-text#new-arrivals": { + "props": { + "text": "New arrivals", + "font": "t-heading-2", + "textPosition": "CENTER", + "textAlign": "CENTER" + } + }, + "rich-text#clearance": { + "props": { + "text": "Clearance", + "font": "t-heading-2", + "textPosition": "CENTER", + "textAlign": "CENTER" + } + }, }
-
Mude o nome das
shelf
's para que uselist-context.product-list
:{ ... - "shelf#new-arrivals": { + "list-context.product-list#new-arrivals": { ... - "shelf#clearance": { + "list-context.product-list#clearance": { ... }
-
Remova as propriedades da shelf que não são mais necessárias em ambas as shelfs:
{ "list-context.product-list#new-arrivals": { "blocks": ["product-summary.shelf"], "props": { "orderBy": "OrderByTopSaleDESC", - "paginationDotsVisibility": "never", "collection": "139", - "productList": { - "maxItems": 9, - "itemsPerPage": 3, - "minItemsPerPage": 1.5, - "scroll": "BY_PAGE", - "arrows": true, - "titleText": "New arrivals" - } } }, ... }
-
Adicione um
slider-layout#shelf
a ambosproduct-list
's:{ "list-context.product-list#new-arrivals": { "blocks": ["product-summary.shelf"], + "children": ["slider-layout#shelf"], ... }, "list-context.product-list#clearance": { "blocks": ["product-summary.shelf"], + "children": ["slider-layout#shelf"], ... }, }
-
Por fim, defina o
slider-layout#shelf
para que tenha o mesmo comportamento da prateleira que tiramos:{ ... + "slider-layout#shelf": { + "props": { + "itemsPerPage": { + "desktop": 3 + } + } + } }
-
Edite os blocos que estão sendo usados no template:
{
"store.home": {
"blocks": [
- "shelf#new-arrivals",
- "shelf#clearance",
+ "rich-text#new-arrivals",
+ "list-context.product-list#new-arrivals",
+ "rich-text#clearance",
+ "list-context.product-list#clearance",
]
}
}
O resultado deve ser:
DICA: Experimente fazer a mesma investigação do
view-source
do passo 3 e ver que os produtos da segunda página de cada prateleira não são carregados no HTML depois do refatoramento.
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 8 months ago