This module globally injects $content
instance, meaning that you can access it anywhere using this.$content
. For plugins, asyncData, nuxtServerInit and Middleware, you can access it from context.$content
.
Methods
$content(path, options?)
path
- Type:
String
- Default:
/
- Type:
options
- Type:
Object
- Default:
{}
- Version: >= v1.3.0
- Type:
options.deep
- Type:
Boolean
- Default:
false
- Version: >= v1.3.0
- Fetch files from subdirectories
- Type:
options.text
- Type:
Boolean
- Default:
false
- Version: >= v1.4.0
- Returns the original markdown content in a
text
variable
- Type:
- Returns a chain sequence
You can also give multiple arguments:
$content('articles', params.slug)
will be translated to/articles/${params.slug}
path
can be a file or a directory. If path
is a file, fetch()
will return an Object
, if it's a directory it will return an Array
.
All the methods below can be chained and return a chain sequence, except fetch
which returns a Promise
.
only(keys)
keys
- Type:
Array
|String
required
- Type:
Select a subset of fields.
const { title } = await this.$content('article-1').only(['title']).fetch()
without(keys)
keys
- Type:
Array
|String
required
- Type:
Remove a subset of fields.
const { title, ...propsWithoutBody } = await this.$content('article-1').without(['body']).fetch()
where(query)
query
- Type:
Object
required
- Type:
Filter results by query.
Where queries are based on subset of mongo query syntax, it handles for example: $eq
, $ne
, $gt
, $gte
, $lt
, $lte
, $in
, ...
// implicit (assumes $eq operator)const articles = await this.$content('articles').where({ title: 'Home' }).fetch()// explicit $eqconst articles = await this.$content('articles').where({ title: { $eq: 'Home' } }).fetch()// $gtconst articles = await this.$content('articles').where({ age: { $gt: 18 } }).fetch()// $inconst articles = await this.$content('articles').where({ name: { $in: ['odin', 'thor'] } }).fetch()
In order to filter in objects and array you need to enable nestedProperties, see configuration.
const products = await this.$content('products').where({ 'categories.slug': { $contains: 'top' } }).fetch()const products = await this.$content('products').where({ 'categories.slug': { $contains: ['top', 'woman'] } }).fetch()
This module uses LokiJS under the hood, you can check for query examples.
sortBy(key, direction)
key
- Type:
String
required
- Type:
direction
- Type:
String
- Value:
'asc'
or'desc'
- Default:
'asc'
- Type:
Sort results by key.
const articles = await this.$content('articles').sortBy('title').fetch()
Can be chained multiple times to sort on multiple fields.
sortBy
method does case-sensitive sort, which is currently not configurable.If you need case-insensitive sorting, check out this snippet on how to work around it.limit(n)
n
- Type:
String
|Number
required
- Type:
Limit number of results.
// fetch only 5 articlesconst articles = await this.$content('articles').limit(5).fetch()
skip(n)
n
- Type:
String
|Number
required
- Type:
Skip results.
// fetch the next 5 articlesconst articles = await this.$content('articles').skip(5).limit(5).fetch()
search(field, value)
field
- Type:
String
required
- Type:
value
- Type:
String
- Type:
Performs a full-text search on a field. value
is optional, in this case field
is the value
and search will be performed on all defined full-text search fields.
The fields you want to search on must be defined in options in order to be indexed, see configuration.
Using an empty string as parameter will skip the search.
// Search on field titleconst articles = await this.$content('articles').search('title', 'welcome').fetch()// Search on all pre-defined fieldsconst articles = await this.$content('articles').search('welcome').fetch()// Search will be skipped if the search string is emptyconst articles = await this.$content('articles').search('').fetch()
surround(slugOrPath, options)
slugOrPath
- Type:
String
required
- Type:
options
- Type:
Object
- Default:
{ before: 1, after: 1}
- Type:
Get prev and next results around a specific slug or path.
You will always obtain an array of fixed length filled with the maching document or null
.
const [prev, next] = await this.$content('articles') .only(['title', 'path']) .sortBy('date') .where({ isArchived: false }) .surround('article-2') .fetch()// Returns[ { title: 'Article 1', path: 'article-1' }, null // no article-3 here]
search
,limit
andskip
are ineffective when using this method.
path
is only supported since v1.12.0fetch()
- Returns:
Promise<Object>
|Promise<Array>
Ends the chain sequence and collects data.
catch()
Checks if the .md
file exists in content directory or not.
It should be inserted after the fetch()
.
Example
const articles = await this.$content('articles') .only(['title', 'date', 'authors']) .sortBy('date', 'asc') .limit(5) .skip(10) .where({ tags: 'testing', isArchived: false, date: { $gt: new Date('2020-03-31') }, rating: { $gte: 3 } }) .search('welcome') .fetch() .catch((err) => { error({ statusCode: 404, message: 'Page not found' }) })
You can check how to use the Content API in development.