Outputting Categories on WebApp / Module / eCommerce Layouts
This Article shows how you can use the category_array field to access the IDs of the Categories assigned to a WebApp or Module Item
In this set of Articles, we'll show you the Liquid syntax needed to get the most out of Categories on the Front End. The following features are available in WebApp and Module Layouts only, as they require access to a particular Item's category_array field. In Module Layouts, they'll only be available in the item.liquid file.
- Using the category_array field to access the IDs of Categories that have been assigned to the current Item
- Displaying all Categories that belong to the current Item
- Displaying the first, last or nth Category which belongs to the current Item
- Check if an Item has an Nth Category assigned to it
Each WebApp or Module Item has a Category Array field stored inside the this object. For WebApps, you can access this in the Layout file. For Modules, you can access this in the item.liquid file in the Layout folder: {{this.category_array}}
This will output the IDs of Categories which are assigned to the current Item in an array e.g. if the Item is assigned to Categories with ID 1 and 2 it will look like this:
To loop over all these Category IDs you can use a Liquid For Loop:
Once you have the Category ID, you can use the Categories data object to access any other Category fields, e.g. the name:
Instead of using a Loop, you can access a specific index of the category_array field and use it to fetch a particular Category ID.
You can use the following to only output the name of the first category assigned to the Item:{{context.exports.categories.data[this.category_array.first].name}}
You can use the following to only output the name of the last category assigned to the Item:{{context.exports.categories.data[this.category_array.last].name}}
You can use the following to only output the name of a specifc category assigned to the Item, by its zeroed-index, where 0 is the first and 1 is the second:
If you want to make sure the category item in the array you are calling exists first, then you should do the following: First category in the array:
Second category in the array (and so on):