Graphql query error ! variable is declared but never used(GraphQL查询错误!变量已声明但从未使用过)
问题描述
我正在尝试根据搜索关键字获取Shopify产品。
我通过在查询中传递硬编码值来测试此查询,它工作得很好,但我需要传递变量值,因此在这种情况下它会给出错误
GRapghql查询错误搜索关键字已声明,但未使用。
以下是我根据title、tag和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)
如果您有一个要用作$mySearchQuery的一部分的Java脚本变量,则可以使用模板文字来设置在您的Java代码中为$mySearchQuery传递的值:
const options = {
variables: {
mySearchQuery: `title:'${keyword}' OR tag:'${keyword}' OR product_type:'${keyword}'`
}
}
您会看到一个错误,说明您的变量已声明且从未使用,因为它从未使用过--查询中对它的引用是字符串的一部分,因此将逐字解析。
这篇关于GraphQL查询错误!变量已声明但从未使用过的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:GraphQL查询错误!变量已声明但从未使用过
基础教程推荐
- 从快速中间件中排除路由 2022-01-01
- 带角度的选项卡:仅使用 $http 在单击时加载选项卡 2022-01-01
- 即使每次插入第一个输入的值不同,第二个输入仍显示相同的输入值 2022-01-01
- HTML5 画布调整为父级 2022-01-01
- CORS:当凭据标志为真时,无法在 Access-Control-Allow-Origin 中使用通配符 2022-01-01
- 逻辑运算符 ||在 javascript 中,0 代表 Boolean false? 2022-01-01
- 最佳动态 JavaScript/JQuery 网格 2022-01-01
- 当木偶师打开Chrome时,不能使用Chrome扩展 2022-01-01
- 使用 jQuery 在悬停时交换 DIV 类 2022-01-01
- 在 Javascript 中使用 Fetch API 上传文件并显示进度 2022-01-01
