WordPress 6.5 新增块绑定 API 使用示例

2024-03-1714:21:31后端程序开发Comments482 views字数 3312阅读模式

WordPress 6.5 引入了一种扩展块的新方法——块绑定 APIBlock Bindings API),该方法大大减少了在块编辑器中集成不同类型数据所需的自定义代码。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

什么是块绑定 API?

假设给定一个核心块,并且用它显示来自特定源的数据,例如,文章元数据或自定义PHP逻辑。如何实现呢?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

WordPress 6.5 新增块绑定 API 使用示例

这实际上是一个棘手的问题:在 WordPress 的早期版本中,您无法使用Gutenberg的核心块来执行此操作 – 相反,它需要创建一个具有特定逻辑的自定义块来从相关源中读取数据。但从 WordPress 6.5 开始已经有实现的方式。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

使用块绑定 API,您现在可以绑定核心块以从不同的源读取,而无需编写自定义块样板 – 这意味着可以绑定段落以从文章的元数据中读取,或绑定标题以从插件中读取PHP 逻辑,所有这些都不需要处理React、块注册以及为您想要读取的每个新源从头开始编写自定义块的其他细节。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

WordPress 6.5 中块绑定 API 的初始版本是朝着简化扩展编辑器和扩展块功能的过程迈出的一大步。在幕后,该 API 已经支持了 WordPress 6.5 中附带的一个展示功能:将核心块连接文章元数据中的自定义字段。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

使用相同的功能,作为高级用例,还可以定义块并从自定义源读取块 – 下面简单说一下。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

注意:有关创建和使用块绑定的更详细演练,请参阅WordPress 开发人员博客中的块绑定简介教程文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

块绑定如何工作?

概述

在了解块绑定可以通过自定义源启用的丰富功能之前,本节将首先回顾 API 的一般工作原理,然后详细说明如何将核心块绑定到文章元数据中的自定义字段。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

下表列出了当前可以绑定的兼容块和属性:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

支持的块支持的属性
图像网址、ALT、标题
段落内容
标题内容
按钮url、文本、链接目标、rel

虽然目前兼容性列表还很短,但这已经支持了广泛的用例,并且计划在未来支持其余核心块以及自定义块。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

要使用块绑定,您需要指定应使用块标记从特定的注册源读取这些属性;然后,当在前端渲染时,将执行这些源的逻辑。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

绑定后,相关属性的编辑将被锁定,并且编辑器中将出现指示器以表明绑定已创建。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

WordPress 6.5 新增块绑定 API 使用示例

下面的示例,是如何通过内置自定义字段支持来利用它。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

自定义字段

重要的是,在块绑定 API 的第一个版本中,还没有用于将属性绑定到自定义字段的UI。因此,有必要使用古腾堡中的代码编辑器手动添加标记。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

要将受支持的属性绑定到文章元数据中的自定义字段,您可以使用如下标记:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

  1. <!-- wp:paragraph {
  2. "metadata":{
  3. "bindings":{
  4. "content":{
  5. "source":"core/post-meta",
  6. "args":{
  7. "key":"book-genre"
  8. }
  9. }
  10. }
  11. }
  12. } -->
  13. <p></p>
  14. <!-- /wp:paragraph -->

为了使其工作,您需要通过在主题functions.php或插件中包含如下代码来确保该字段已注册到文章元数据。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

  1. register_meta(
  2. 'post',
  3. 'book-genre',
  4. array(
  5. 'show_in_rest' => true,
  6. 'single' => true,
  7. 'type' => 'string',
  8. 'default' => 'Default text field',
  9. )
  10. );

*请注意,出于安全考虑,该show_in_rest属性必须暂时设置为true,尽管后续可能会想办法删除此要求。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

未来更多数据来源

对文章元数据的支持只是一个开始,计划是为 WordPress 6.6 添加更多内置数据来源,例如站点、用户和分类数据。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

即使这样,块绑定 API 已经具有允许注册自定义源的功能,这与内部用于注册上述源的core/post-meta功能相同。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

注册自定义源

概述

要注册块绑定源,需要使用具有以下签名的函数register_block_bindings_source()文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

  1. register_block_bindings_source(
  2. string $source_name,
  3. array $source_properties
  4. );

有两个可用参数:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

  • $source_name:自定义绑定源的唯一名称,格式为namespace/slug. 命名空间是必需的。
  • $source_properties:用于定义绑定源的属性数组:
    • label:表示绑定源的国际化文本字符串。注意:当前未在 UI 中的任何位置显示。
    • get_value_callback:当块的绑定属性源与参数$source_name匹配时调用的 PHP 可调用对象(函数、闭包等)。
    • use_context:( 可选)如果回调需要,则使用上下文数组扩展块实例。例如,要使用当前帖子 ID,应将其设置为[ 'postId' ]

当 WordPress 在解析块时遇到自定义绑定源时,它将运行该get_value_callback 函数,其签名应如下所示:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

  1. projectslug_bindings_callback(
  2. array $source_args,
  3. WP_Block $block_instance,
  4. string $attribute_name
  5. );

它最多可以接受三个参数,但您不需要包含它们,除非您的逻辑需要它们:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

  • $source_args:通过块的 metadata.bindings.$attribute.args属性传递的参数数组。
  • $block_instance:绑定作为WP_Block对象连接到的块的当前实例。
  • $attribute_name:通过块上的 metadata.bindings.$attribute属性键设置的当前属性。

使用注册机制

在实践中,您可以使用以下注册函数来创建版权信息的简单绑定:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

  1. add_action( 'init', 'projectslug_register_block_bindings' );
  2. function projectslug_register_block_bindings() {
  3. register_block_bindings_source( 'projectslug/copyright', array(
  4. 'label' => __( 'Copyright', 'projectslug' ),
  5. 'get_value_callback' => 'projectslug_copyright_binding'
  6. ) );
  7. }
  8. function projectslug_copyright_binding() {
  9. return '&copy; ' . date( 'Y' );
  10. }

以下是如何将段落绑定到块标记中的版权源,以及它在前端的外观:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

  1. <!-- wp:paragraph {
  2. "metadata":{
  3. "bindings":{
  4. "content":{
  5. "source":"projectslug/copyright"
  6. }
  7. }
  8. }
  9. } -->
  10. <p>Copyright Block</p>
  11. <!-- /wp:paragraph -->
WordPress 6.5 新增块绑定 API 使用示例

当然,这是一个简单的示例,您可以利用回调签名中的其他参数来创建更广泛的逻辑。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

其他API函数

此外,目前还有一些其他函数属于公共 API:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

  • unregister_block_bindings_source( $string source_name ) : 取消注册源
  • get_all_registered_block_bindings_sources():获取所有已注册的源
  • get_block_bindings_source( $string source_name ) : 检索已注册的源

另请注意,虽然核心源在编辑器 UI 中使用共享 API,但请注意,这些编辑器 API 将暂时保持私有状态,同时继续讨论如何围绕此功能标准化 UI 扩展。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

这意味着,如果您想实现一个 UI 来轻松处理自定义字段,目前您需要自己创建该功能。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

进一步学习和后续步骤

有关如何在自己的项目中使用块绑定的更多灵感,请参阅block-bindings.php中的注册逻辑和内置的core/post-meta源,并查看块绑定简介教程系列。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

块绑定才刚刚开始,未来的计划包括:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

  • 添加直接从 UI编辑元字段值的可能性。
  • 添加 UI 以允许用户通过编辑器添加绑定。
  • 创建新的内置源:站点数据、发布数据和分类数据。
  • 添加对更多核心块的支持。
  • 为开发人员添加扩展编辑器 UI 的能力。

来源:wordpress大学文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html

文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/62315.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/bc/62315.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定