gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 19:01:41 25 4
gpt4 key购买 nike

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

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

Grapghql query error searchKeyword is declared but not used.

这是我根据titletagproduct_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)

如果您有一个要用作 $mySearchQuery 一部分的 javascript 变量,您可以在 javascript 代码中设置为 $mySearchQuery 传入的值,方法是使用模板文字:

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

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

关于javascript - Graphql 查询错误!变量已声明但从未使用过,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46488163/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com