Liquid, JavaScript, themes, sales channels
Hi,I am trying to add HTML sitemap page on my shopify store.I have listed all the products and blogs but not sure how to list all pages of store aswell in html sitemap? Please share the code if anyone have ,thanks in advance
Solved! Go to the solution
This is an accepted solution.
Create a linklist (menu) with the pages you want to show - and in your preferred order - and loop over that instead.
This is an accepted solution.
A sane alternative is to use an app like usemechanic to script a sitemap generator using the shopify api that then adds the generated file to the theme.
Jasons method of linklists will give the most control, especially in art-direction, but suffers from having to manually create and manage all such links as it will not auto-update when new pages, or other resources, are created .(there is no native menu api for automating this either)
https://shopify.dev/api/liquid/objects#pages
<ul>
{%- paginate pages by 50 -%}
{%- for p in pages -%}
<li>{{p.title}}</li>
{%- endfor -%}
{{ paginate | default_pagination: next: 'Older', previous: 'Newer' }}
{%- endpaginate -%}
</ul>
Also don't forget policies, maybe the collections-list page /collections, and or things like vendor/product-type pages.
https://shopify.dev/api/liquid/objects/shop#shop-policies
Do note that for things like collection/all , anecdotally , a store could have perf issues from having overly large collections of products
In which case you may want to look at stuff like the map filter for optimizations, using the theme inspector tool to evaluate a possible perf problem.
https://shopify.dev/api/liquid/filters/array-filters#map
{% assign collection_titles = collections | map: 'title' %}
Or use an app.
This is an accepted solution.
Thanks @Jason for helping us.I have added your code and it is working for all Pages.if i have to add it for collections,products and blogs aswell how can i use it?Thanks in advance
This is an accepted solution.
Create a linklist (menu) with the pages you want to show - and in your preferred order - and loop over that instead.
This is an accepted solution.
A sane alternative is to use an app like usemechanic to script a sitemap generator using the shopify api that then adds the generated file to the theme.
Jasons method of linklists will give the most control, especially in art-direction, but suffers from having to manually create and manage all such links as it will not auto-update when new pages, or other resources, are created .(there is no native menu api for automating this either)
https://shopify.dev/api/liquid/objects#pages
<ul>
{%- paginate pages by 50 -%}
{%- for p in pages -%}
<li>{{p.title}}</li>
{%- endfor -%}
{{ paginate | default_pagination: next: 'Older', previous: 'Newer' }}
{%- endpaginate -%}
</ul>
Also don't forget policies, maybe the collections-list page /collections, and or things like vendor/product-type pages.
https://shopify.dev/api/liquid/objects/shop#shop-policies
Do note that for things like collection/all , anecdotally , a store could have perf issues from having overly large collections of products
In which case you may want to look at stuff like the map filter for optimizations, using the theme inspector tool to evaluate a possible perf problem.
https://shopify.dev/api/liquid/filters/array-filters#map
{% assign collection_titles = collections | map: 'title' %}
Or use an app.
This is an accepted solution.
Thanks @Jason for helping us.I have added your code and it is working for all Pages.if i have to add it for collections,products and blogs aswell how can i use it?Thanks in advance
Learn these 5 things I had to learn the hard way with starting and running my own business
By Kitana Jan 27, 2023Would you love to unleash the unbridled power of the Google Shopping Channel into your sho...
By Gabe Jan 6, 2023How can you turn a hobby into a career? That’s what Emmanuel did while working as a wa...
By Skye Dec 30, 2022