Discuss and resolve questions on Liquid, JavaScript, themes, sales channels, and site speed enhancements.
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.
Contact paull.newton+shopifyforum@gmail.com for the solutions you need
Save time & money ,Ask Questions The Smart Way
Problem Solved? ✔Accept and Like solutions to help future merchants
Answers powered by coffee Thank Paul with a ☕ Coffee for more answers or donate to eff.org
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.
Contact paull.newton+shopifyforum@gmail.com for the solutions you need
Save time & money ,Ask Questions The Smart Way
Problem Solved? ✔Accept and Like solutions to help future merchants
Answers powered by coffee Thank Paul with a ☕ Coffee for more answers or donate to eff.org
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
Hey @matloobsahmal How do I display more that 1000 products in the template ?
please do help in that
try it "
<ul>
{%- paginate pages by 50 -%}
{%- for p in pages -%}
<li>{{p.title}}</li>
{%- endfor -%}
{{ paginate | default_pagination: next: 'Older', previous: 'Newer' }}
{%- endpaginate -%}
</ul>
Hey Community! As the holiday season unfolds, we want to extend heartfelt thanks to a...
By JasonH Dec 6, 2024Dropshipping, a high-growth, $226 billion-dollar industry, remains a highly dynamic bus...
By JasonH Nov 27, 2024Hey Community! It’s time to share some appreciation and celebrate what we have accomplis...
By JasonH Nov 14, 2024