Dun*_*Luk 7 javascript apollo graphql
我有以下 GraphQL 查询(使用 Apollo Client JS):
query GetUsers($searchFilter: String) {
users(
first: 10,
filter: { search: $searchFilter }
) {
nodes {
id
name
}
}
}
Run Code Online (Sandbox Code Playgroud)
当我传递参数时,这很有效$searchFilter。但是,我希望这个$searchFilter参数是可选的。因此,当它出现时,null它不会应用过滤器。
这看起来很简单,但 API 要求search不可为空。filter: { search: null }所以不允许传入。
我想实现以下目标:
query GetUsers($searchFilter: String) {
users(
first: 10,
filter: $searchFilter = null ? null : { search: $searchFilter }
) {
nodes {
id
name
}
}
}
Run Code Online (Sandbox Code Playgroud)
我如何有条件地包含filter参数?
xad*_*adm 12
只需传递(整个“先前组成/准备”)值filter(在查询时定义)变量即可。保留此变量未定义使其成为可选的。
query GetUsers($filter: SomeFilterInputType) {
users(
first: 10,
filter: $filter ) {
Run Code Online (Sandbox Code Playgroud)
filter为 [query] 变量传递值:
{
filter: { search: 'sth'}
}
Run Code Online (Sandbox Code Playgroud)
...其中SomeFilterInputType是 [ usersquery] arg 类型名称,它可以从 API 规范中读取,可在 graphiql/playground 文档中找到...或服务器代码/类型定义
可以使用查询变量在 graphiql/playground 中对其进行测试。
variables从 JavaScript 传递的是一个具有相同结构的对象,可以轻松地有条件地创建/修改。
在这种情况下SomeFilterInputType(!类型名称后没有标记)意味着它(filter变量)可以为空/未定义 -通常可选参数可以为空(不是必需的)。如果 API/BE 规范中需要某些参数,那么客户端中也必须需要它。
| 归档时间: |
|
| 查看次数: |
10987 次 |
| 最近记录: |