# useCategory composable
useCategory
composition API function is responsible, as it's name suggests for interactions with category from your eCommerce. This function returns following values:
search
- a main querying function that is used to query products from eCommerce platform and populate theproducts
object with the result. Every time you invoke this function API request is made. This method accepts a singleparams
object.- The
params
has the following options:id
(String) The id of the collection to fetch.slug
(String) The handle of the collection to fetch.customQuery
(Object) An object specifying the query data containing zero or more of:first
(Int) The relayfirst
param. This specifies page size.sortKey
(String) The key to sort results by. Available values are ID, TITLE, UPDATED_ATquery
(String) A query string.reverse
(Boolean) Whether or not to reverse the sort order of the results
withProducts
(Boolean) Fetch collections, including products.
- The
categories: Category[]
- a main data object that contains an array of categories fetched bysearch
method
export type Category = {
__typename?: 'Category';
id: string;
handle: string;
title: string;
image: string;
description: string;
descriptionHtml: string;
updatedAt: string;
products: array;
}
loading
- a reactive object containing information about loading state of yoursearch
method
# Examples
Fetches all collections on the shop, including products.
import { useCategory } from '@vue-storefront/shopify';
import { onSSR } from '@vue-storefront/core'
export default {
setup() {
const { categories, search, loading } = useCategory('menu-categories');
onSSR(async () => {
await search({});
});
return {
categories,
loading
}
}
}
Fetches a single collection by slug on the shop, including products.
const { categories, search } = useCategory('categories');
onSSR(async () => {
await search({ slug: 'sale' });
});
return {
categories
};
← useCart useContent →