Refactoring Blocks
Refactoring blocks
Some blocks over time are replaced by others not only to increase flexibility and ease of operation, but also to optimize their behavior and performance.
The Slider Layout (known in the Complex Layouts course) has been improved so that it uses lazy load in the loaded content. This means that products and images are only loaded when the user, in fact, requests them. This type of behavior is not available at Shelf and Carousel, and to further optimize performance, let's see how we can replace them.
Activity
-
In the
home.jsonc
file, declare two blocks of text to replace the titles:// 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" + } + }, }
-
Change the name of the shelves to use
list-context.product-list
:{ ... - "shelf#new-arrivals": { + "list-context.product-list#new-arrivals": { ... - "shelf#clearance": { + "list-context.product-list#clearance": { ... }
-
Remove the shelf properties that are no longer needed on both shelves:
{ "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" - } } }, ... }
-
Add a
slider-layout#shelf
to bothproduct-lists
:{ "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"], ... }, }
-
Finally, define the
slider-layout#shelf
so that it has the same behavior as the shelf we removed:{ ... + "slider-layout#shelf": { + "props": { + "itemsPerPage": { + "desktop": 3 + } + } + } }
-
Edit the blocks being used in 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", ] } }
The result should be:
TIP: Try the same view-source investigation as in step 3 and see that the products on the second page of each shelf are not loaded into HTML after refactoring.
Any questions?
See the answersheet for this step or check our [office hours] on the VTEX Developers channel(https://www.youtube.com/c/VTEXDevelopers)
Help us make this content better!
VTEX IO courses are open source. If you see something wrong, you can open a pull request!
Make a contributionUpdated 8 months ago