Documentation / @ember-data/json-api / request / postQuery
Call Signature
function postQuery<T>(
type,
query?,
options?): PostQueryRequestOptions<CollectionResourceDataDocument<T>, T>;
Defined in: -private/builders/query.ts:149
Builds request options to query for resources, usually by a primary type, configured for the url and header expectations of most JSON:API APIs.
The key difference between this and query
is that this method will send the query as the JSON body of a "POST" request instead of as query params in the url of a "GET" request.
A CacheKey is generated from the url and query params, and used to cache the response in the store.
import { postQuery } from '@ember-data/json-api/request';
const options = postQuery('person', { include: ['pets', 'friends'] });
const data = await store.request(options);
Supplying Options to Modify the Request Behavior
The following options are supported:
host
- The host to use for the request, defaults to thehost
configured withsetBuildURLConfig
.namespace
- The namespace to use for the request, defaults to thenamespace
configured withsetBuildURLConfig
.resourcePath
- The resource path to use for the request, defaults to pluralizing the supplied typereload
- Whether to forcibly reload the request if it is already in the store, not supplying this option will delegate to the store's CachePolicy, defaulting tofalse
if none is configured.backgroundReload
- Whether to reload the request if it is already in the store, but to also resolve the promise with the cached value, not supplying this option will delegate to the store's CachePolicy, defaulting tofalse
if none is configured.urlParamsSetting
- an object containing options for how to serialize the query params (seebuildQueryParams
)
import { postQuery } from '@ember-data/json-api/request';
const options = postQuery('person', { include: ['pets', 'friends'] }, { reload: true });
const data = await store.request(options);
Type Parameters
T
T
Parameters
type
query?
options?
Returns
PostQueryRequestOptions
<CollectionResourceDataDocument
<T
>, T
>
Call Signature
function postQuery(
type,
query?,
options?): PostQueryRequestOptions;
Defined in: -private/builders/query.ts:154
Builds request options to query for resources, usually by a primary type, configured for the url and header expectations of most JSON:API APIs.
The key difference between this and query
is that this method will send the query as the JSON body of a "POST" request instead of as query params in the url of a "GET" request.
A CacheKey is generated from the url and query params, and used to cache the response in the store.
import { postQuery } from '@ember-data/json-api/request';
const options = postQuery('person', { include: ['pets', 'friends'] });
const data = await store.request(options);
Supplying Options to Modify the Request Behavior
The following options are supported:
host
- The host to use for the request, defaults to thehost
configured withsetBuildURLConfig
.namespace
- The namespace to use for the request, defaults to thenamespace
configured withsetBuildURLConfig
.resourcePath
- The resource path to use for the request, defaults to pluralizing the supplied typereload
- Whether to forcibly reload the request if it is already in the store, not supplying this option will delegate to the store's CachePolicy, defaulting tofalse
if none is configured.backgroundReload
- Whether to reload the request if it is already in the store, but to also resolve the promise with the cached value, not supplying this option will delegate to the store's CachePolicy, defaulting tofalse
if none is configured.urlParamsSetting
- an object containing options for how to serialize the query params (seebuildQueryParams
)
import { postQuery } from '@ember-data/json-api/request';
const options = postQuery('person', { include: ['pets', 'friends'] }, { reload: true });
const data = await store.request(options);
Parameters
type
string