【发布时间】:2018-04-15 15:19:02
【问题描述】:
当我尝试在我的项目中运行 relay-compiler 时,我收到了标题中的错误。我正在使用 graphql-python/graphene-django 作为后端 graphql 服务器。这是我的架构的缩写副本。
grove.gql_schema.py:
from graphene_django import DjangoObjectType
from graphene_django.filter import DjangoFilterConnectionField
from .models import Tree
class TreeNode(DjangoObjectType):
class Meta:
model = Tree
filter_fields = ['owner']
interfaces = (relay.Node,)
class Query(ObjectType):
def resolve_my_trees(self, info):
if not info.context.user.is_authenticated:
return Tree.objects.none()
else:
return Tree.objects.filter(owner=info.context.user)
my_trees = DjangoFilterConnectionField(TreeNode)
tree = relay.Node.Field(TreeNode)
project.gql_schema:
class Query(grove.gql_schema.Query, graphene.ObjectType):
pass
schema = graphene.Schema(query=Query)
通过该设置,我可以在 GraphiQL 中成功运行以下查询
query {
myTrees {
edges {
node {
id
}
}
}
}
到目前为止一切顺利,但现在我正在尝试构建一个可以使用此查询的客户端组件。
jsapp/components/index.jsx:
import React from 'react';
import {graphql, QueryRenderer} from 'react-relay';
import environment from '../relay_env'
const myTreesQuery = graphql`
query componentsMyTreesQuery {
edges {
node {
id
}
}
}
`;
export default class App extends React.Component {
render() {
return (
<QueryRenderer
environment={environment}
query={myTreesQuery}
variables={{}}
render={({error, props}) => {
if (error) {
return <div>Error!</div>;
}
if (!props) {
return <div>Loading...</div>;
}
return <div>User ID: {props.edges}</div>;
}}
/>
);
}
}
查询是相同的,但是当我运行relay-compiler --src ./jsapp --schema ./schema.graphql --extensions js jsx 时出现错误:
GraphQLParser: Unknown field `edges` on type `Query`.
Source: document `componentsMyTreesQuery` file: `components/index.jsx`.
如果我使用 Django graphaql_schema 管理命令生成的 .json 架构或 get-graphql-schema 检索到的 .graphql 架构时,我会收到此错误。
我错过了什么?
【问题讨论】:
标签: django relayjs graphene-python