7

我正在构建一个自定义 Gutenberg 块,它向 WordPress REST API 发出请求以获取一些帖子。我axios用来向 REST 端点发出请求。

当结果返回时,有一个 Post 对象数组,我可以看到 Posts 的标题,但它们都包含在 JSON 对象中title.rendered并包含 HTML 实体,例如。

title: {
    rendered: "This has a hyphen – oh dear"
}`

我正在尝试<SelectControl>使用结果数据填充 a,因此无法使用 ReactdangerouslySetInnerHTML方法来解决实体问题。那么在填充选项时如何摆脱这些实体呢?

这是我用来填充 REST 响应中的选项的代码:

const options = response.data.map((post) => {
    return {
        label: post.title.rendered,
        value: post.id,
    };
});
4

2 回答 2

5

这不是很明显,但实际上 Blocks API 中提供了一种方法来执行此操作。

在块代码的顶部,键入:

const { decodeEntities } = wp.htmlEntities;

然后你可以像这样使用它:

const options = response.data.map((post) => {
    return {
        label: decodeEntities(post.title.rendered),
        value: post.id,
    };
});

火箭筒!HTML 实体消失了。

于 2018-09-07T20:16:07.400 回答
3

为什么不使用rest_prepare_<post_type>过滤器?

$post_type = "post"
add_filter( "rest_prepare_".$post_type, 'prefix_title_entity_decode'] , 10, 1 ); 
function prefix_title_entity_decode($response){
    $data = $response->get_data();
    $data['title']['rendered'] = html_entity_decode( $data['title']['rendered']);
    $response->set_data($data);
    return $response;
}
于 2019-11-08T13:22:36.573 回答