假设我有一个 GraphQL 类型Echo
,它可以用一些装饰来回显我查询的任何内容。另一方面,我有一个响应message
传递给它的 React 组件,其中包含一些由Echo
类型决定的装饰。如何设置initialVariables
组件Echo
?
我读到设置 props sets initialVariables
,但这不起作用。我试过componentDidMount
了,但这也不起作用。
此Relay Playground显示消息未正确显示。
对于上下文,
// This component consumes `Echo` type
class Echo extends React.Component {
componentDidMount() {
let {relay, message} = this.props;
relay.setVariables({
message
});
}
render() {
let name = '';
if (this.props.echo) {
name = this.props.echo.name;
}
return (
<li>Message: {name}</li>
);
}
}
Echo = Relay.createContainer(Echo, {
// By default `message` is null
initialVariables: {
message: null
},
fragments: {
echo: () => Relay.QL`
fragment on Echo {
name(message: $message)
}
`,
},
});
这是用回声解决的类型
let EchoType = new GraphQLObjectType({
name: 'Echo',
fields: () => ({
name: {
type: GraphQLString,
args: {
message: {
type: GraphQLString
}
},
resolve: (echo, {message}) => `Hello, ${message}!`
}
})
});