如何有条件地在 GraphQL 查询中包含过滤参数?

我有以下 GraphQL 查询(使用 Apollo Client JS):


query GetUsers($searchFilter: String) {

    users(

        first: 10,

        filter: { search: $searchFilter }

    ) {

        nodes {

            id

            name

        }

    }

}

当我传递参数时,这很有效$searchFilter。但是,我希望这个$searchFilter参数是可选的。因此,当它出现时,null它不会应用过滤器。


这看起来很简单,但 API 要求search不可为空。filter: { search: null }所以不允许传入。


我想实现以下目标:


query GetUsers($searchFilter: String) {

    users(

        first: 10,

        filter: $searchFilter = null ? null : { search: $searchFilter }

    ) {

        nodes {

            id

            name

        }

    }

}

我如何有条件地包含filter参数?


慕虎7371278
浏览 172回答 1
1回答

胡子哥哥

只需传递(整个“先前组成/准备”)值filter(在查询时定义)变量即可。保留此变量未定义使其成为可选的。query GetUsers($filter: SomeFilterInputType) {  users(    first: 10,     filter: $filter ) {filter为 [query] 变量传递值:{  filter: { search: 'sth'}}...其中SomeFilterInputType是 [ usersquery] arg 类型名称,它可以从 API 规范中读取,可在 graphiql/playground 文档中找到...或服务器代码/类型定义可以使用查询变量在 graphiql/playground 中对其进行测试。variables从 JavaScript 传递的是一个具有相同结构的对象,可以轻松地有条件地创建/修改。在这种情况下SomeFilterInputType(类型名称后没有!标记)意味着它(filter变量)可以为空/未定义 -通常可选参数可以为空(不是必需的)。如果 API/BE 规范中需要某些参数,那么客户端中也必须需要它。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript