Reactjs 具有多个值的字段的解析器的Drupal GraphQL逻辑
我的第一个Drupal无头项目是GraphQL,我正在与解析器背后的逻辑作斗争 有一个内容类型项目,其字段字段项目描述为。该字段可以存储多个值 这是我的模式的一部分:Reactjs 具有多个值的字段的解析器的Drupal GraphQL逻辑,reactjs,graphql,drupal-8,react-apollo,Reactjs,Graphql,Drupal 8,React Apollo,我的第一个Drupal无头项目是GraphQL,我正在与解析器背后的逻辑作斗争 有一个内容类型项目,其字段字段项目描述为。该字段可以存储多个值 这是我的模式的一部分: type Project { id: Int! project_title: String! project_description: [ProjectDescription] } type ProjectDescription { value: String } 这就是相应解析器的一部分的外观: $r
type Project {
id: Int!
project_title: String!
project_description: [ProjectDescription]
}
type ProjectDescription {
value: String
}
这就是相应解析器的一部分的外观:
$registry->addFieldResolver('ProjectDescription', 'value',
$builder->produce('property_path')
->map('type', $builder->fromValue('entity:node'))
->map('value', $builder->fromParent())
->map('path', $builder->fromValue('field_project_project_desc.value'))
);
但据我所知,必须有另一个类似的解析器
$registry->addFieldResolver'Project'、'Project_description'
我不知道这个解析器应该是什么样子。好的,我自己解决了这个问题。答案其实很简单 您不需要第二个解析器。只需一个带有附加PHP函数的解析器,即可将数组展平为字符串。这就是代码现在的样子 模式:
type Project {
id: Int!
project_title: String!
project_description: [String]
}
和解析器:
$registry->addFieldResolver('Project', 'project_description',
$builder->compose(
$builder->produce('property_path')
->map('type', $builder->fromValue('entity:node'))
->map('value', $builder->fromParent())
->map('path', $builder->fromValue('field_project_project_desc')),
$builder->callback(function ($entity) {
$list = [];
foreach($entity as $item){
array_push($list, $item['value']);
}
return $list;
})
)
);
我希望我能在这方面帮助别人