3

我有简单的古腾堡块和谷歌字体选择。

el (SelectControl,
{   
    value: fontFamily,
    label: __('Шрифт'),
    options: [                                  
        {
            value: 'Georgia',
            label: 'Georgia'
        },
        { 
            value: 'PT Sans', 
            label: 'PT Sans' 
        },
        { 
            value: 'Amatic SC', 
            label: 'Amatic SC' 
        },
    ],
    onChange: onChangefontFamily,
},),

php:

function google_fonts_url() {   
  $fonts_url = '';  
  $font_families = array();
  $font_families[] = 'Amatic SC|PT Sans:400,400i';
  $query_args = array(
      'family' => urlencode( implode( '|', $font_families ) ),
      'subset' => urlencode( 'latin,cyrillic' ),
  );
  $fonts_url = add_query_arg( $query_args, 'https://fonts.googleapis.com/css' );    
  return $fonts_url; }                                           

我只需要从谷歌加载选定的字体。

如何从选择中获取 val ?

4

1 回答 1

0

Gutenberg 将块的属性保存在 post_content 内的 HTML 注释中。因此,您需要使用 PHP 解析 HTML 注释。一种方法是使用DOMDocument

假设您的内容保存在 post_content 中,如下所示:

<!-- wp:yourprefix/yourblock {"fontFamily":"Amatic SC"} -->
 <div class="wp-block-yourprefix-yourblock"></div>
<!-- /wp:yourprefix/yourblock -->

然后,您可以使用以下命令获取帖子/页面的内容:

$content_post = get_post($my_postid);
$content = $content_post->post_content;

然后可以通过 DOMDocument 库解析此内容以提取以 JSON 编码的 select 的值

$dom = new DOMDocument();

//Pass the content to the loadHTML function
$dom->loadHTML($content);
$xpath = new DOMXPath($dom);

//Extract Comment Nodes
$comments = $xpath->query('//comment()');

//Extract text from the 1st node
$text = $comments->item(0)->data;

//Match the JSON string and decode to get the selected font value
preg_match('~\{(?:[^{}]|(?R))*\}~', $text,$res);
$fontFamily = json_decode($res[0])->fontFamily;
于 2019-01-17T16:20:09.950 回答