Graphql查询错误!变量已声明但从未使用

2024-04-19

我正在尝试根据搜索关键字获取 Shopify 产品。

我通过在查询中传递硬编码值来测试此查询,它工作正常,但我需要传递变量值,因此在这种情况下它会给出错误

Graphql 查询错误 search 关键字已声明但未使用。

这是我根据以下内容搜索产品的查询title, tag and product_type.

不成功案例:

export const searchProductsQuery = gql` query($searchKeyword: String!){
    shop {
        products(first: 10, query:"title:'$searchKeyword' OR tag:'$searchKeyword' OR product_type:'$searchKeyword'") {
            edges {
                cursor
                node {
                    id
                    title
                    handle
                    description
                    productType
                    images(first: 5) {
                        edges {
                            node {
                                id
                                src
                            }
                        }
                    }
                    variants(first: 5) {
                        edges {
                            node {
                                id
                                title
                                price
                            }
                        }
                    }
                }
            }
        }
    }
}`;

成功案例:

export const searchProductsQuery = gql` query{
shop {
     products(first: 10, query:"title:'games' OR tag:'games' OR product_type:'games'") {
    ...
};

您为操作定义的变量就是变量。它们不能像模板文字占位符一样使用,而这正是您想要做的。

在 GraphQL 中,变量只能用作参数的输入。例如,query是一个采用(非空)字符串的参数。所以,我们可以创建一个像这样的变量$mySearchQuery,将其设置为"title:'games' OR tag:'games' OR product_type:'games'"然后像这样使用它:

products(query:$mySearchQuery)

如果您想将 javascript 变量用作$mySearchQuery,您可以设置传入的值$mySearchQuery在你的 javascript 代码中使用模板文字:

const options = {
  variables: {
    mySearchQuery: `title:'${keyword}' OR tag:'${keyword}' OR product_type:'${keyword}'`
  }
}

您看到一个错误,表明您的变量已声明但从未使用过,因为它从未使用过 - 查询中对它的引用是字符串的一部分,因此按字面解析。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Graphql查询错误!变量已声明但从未使用 的相关文章

随机推荐