How URLs Map to Shopify Templates

shopify tutorial- how URLs map to Shopify themes

One of the (many) features I love about working with Shopify Themes is the simple folder structure. Each store can be powered by a single layout file and a handful of templates meaning you can achieve a lot with a little — power in simplicity.

However if you are new to Shopify Themes, you may not know exactly when each template gets rendered, or be aware that the same template gets used in various places around the store.

We've already looked at how to use both alternatelayoutandtemplatefiles, therefore in this article we'll turn our focus to understanding under what conditions each template is rendered in a store.

While we're on the topic of URLs, learn more about what acanonical URLis, and why they're so important.

URL template mapping

Internally, Shopify has its own routing table which determines which template is displayed based on the URL requested by the user. If you have ever used one of the popular development frameworks, you might be familiar with the concept of URL routing. Put simply it's a way of determining which template to send to the browser based on the requested URL.

I mentioned earlier that there are only a handful of templates required to power a store. Each of these templates serves one or more URL — in other words, we are able to utilise the same templates for multiple URLs. From a design perspective, this enables us to reduce our overhead when building a new store.

You might also like:Using Metafields in Your Shopify Theme

URLs to templates

Here's an overview of which template is rendered as determined by the URL:

/thisisntarealurl → 404.liquid
/blogs/{blog-name}/{article-id-handle} → article.liquid
/blogs/{blog-name} → blog.liquid
/cart → cart.liquid
/collections → list-collections.liquid
/collections/{collection-handle} → collection.liquid
/collections/{collection-handle}/{tag} → collection.liquid
/ → index.liquid
/pages/{page-handle} → page.liquid
/products → list-collections.liquid
/products/{product-handle} → product.liquid
/search?q={search-term} → search.liquid

Password protected

You might have noticed that thepassword.liquidtemplate is not included in the list. This template is only seen if you choose to password protect your storefront and as such will override all other URLs.

If your store is password protected and you do not have apassword.liquidtemplate in your theme, Shopify will render it's default password login page instead.

Alternate templates

It's also worth remembering that the above routing table can be affected by alternate templates — something we have covered ina previous tutorial.

URL parameters

As you will see above, a number of the routes have elements of the URL path wrapped in{ }. I have included this to denote a variable which will have an impact on the data loaded into a template.

For example, if we take the/collections/{collection-handle}URL pattern a different set of data will be loaded into the template and sent to the browser if we requested/collections/bikescompared to/collections/cars.

You will also notice that a number of different URL patterns share the same template file, e.g/productsand/collectionswill both render thelist-collections.liquidtemplate. Likewise/collections/,/collections/{collection-handle}/and/collections/{collection-handle}/{tag}all make use ofcollection.liquid.

Final note

If you are ever unsure which template is being rendered, there's a really simple way to check.

All you need to do is add{{ template }}to yourtheme.liquidfile and start browsing your store. This global Shopify variable will output the currently rendered template minus the.liquidextension. It's a neat way to be doubly sure your templates are working as expected.

Here's a handy snippet that you can use in your own theme development with the output shown in the screenshot below:

Current template: {{ template }}.liquid

How URLs Map to Shopify Templates: Keir Whitaker's site

Want to learn more about building with Shopify? Check out our full list ofShopify tutorials.

You might also like:How to Optimize Themes for Performance

Grow your business with the Shopify Partner Program

Learn more