如何在古腾堡的“文档”下添加新面板

更新于 2025年4月17日 WordPress 教程

如何在古腾堡的“文档”下添加新面板

我正在尝试在文档选项卡下添加一个新的组件面板,例如类别、特色图像等。

在此处输入图片说明

解决方案

他们现在添加了PluginDocumentSettingPanel SlotFill。

const { registerPlugin } = wp.plugins
const { PluginDocumentSettingPanel } = wp.editPost
 
const PluginDocumentSettingPanelDemo = () => (
    <PluginDocumentSettingPanel
        name="custom-panel"
        title="Custom Panel"
        className="custom-panel"
    >
        Custom Panel Contents
    </PluginDocumentSettingPanel>
)
registerPlugin('plugin-document-setting-panel-demo', {
    render: PluginDocumentSettingPanelDemo
})

add_meta_box可以解决问题,但前提是您添加值为'side'context参数:

add_meta_box(
    'box-id-here',
    'Box Title Here',
    'createBoxHtml',
    'post',
    'side' ); // <-- this is important

啊哈,两天一无所获!


旧答案

根据这个教程,我们可以添加自定义侧边栏并使用自定义表单输入填充它。

这是 React JSX 版本中的一个工作示例。 这增加了一个元字段country

const { registerPlugin } = wp.plugins;
const { PluginSidebar } = wp.editPost;
const { TextControl } = wp.components;
const { withSelect, withDispatch } = wp.data;

// Customized TextControl
const CustomMetaField = withDispatch( ( dispatch, props ) => {
    return {
        updateMetaValue: ( v ) => {
            dispatch( 'core/editor' ).editPost( {
                meta: {
                    [ props.metaFieldName ]: v
                }
            });
        }
    };
})( withSelect( ( select, props ) => {
    return {
        [ props.metaFieldName ]: select( 'core/editor' ).getEditedPostAttribute( 'meta' )[ props.metaFieldName ]
    };
} )( ( props ) => (
    <TextControl
        value={props[ props.metaFieldName ] }
        label="Country"
        onChange={( v ) => {
            props.updateMetaValue( v );
        }}
    /> )
) );


// Our custom sidebar
registerPlugin( 'custom-sidebar', {
    render() {
        return (
            <PluginSidebar
                name="project-meta-sidebar"
                title="Project Meta">
                <div className="plugin-sidebar-content">
                    <CustomMetaField metaFieldName="country" />
                </div>
            </PluginSidebar>
        );
    },
} );

在 PHP 中,在init hook 中注册元字段:

register_meta( 'post', 'country', [
    'show_in_rest' => TRUE,
    'single' => TRUE,
    'type' => 'string'
] );

我知道:

这仍然不是必需的解决方案,但差不多。

您可以将此代码添加到您的 function.php。 此代码创建新选项卡并将文本字段添加到此选项卡。 文本字段像 post_meta 表中的自定义字段一样保存到数据库中,您可以像默认 WP po​​st meta 一样输出它。
1. 创建标签。
2.创建自定义文本字段utm_post_class
3. 网站输出使用$utm = get_post_meta( $post->ID, 'utm_post_class', true );

//Article UTM Link
add_action( 'load-post.php', 'utm_post_meta_boxes_setup' );
add_action( 'load-post-new.php', 'utm_post_meta_boxes_setup' );

function utm_post_meta_boxes_setup() {
    add_action( 'add_meta_boxes', 'utm_add_post_meta_boxes' );
    add_action( 'save_post', 'utm_save_post_class_meta', 10, 2 );
}

function utm_add_post_meta_boxes() {
    add_meta_box(
        'utm-post-class',
        'Настройки UTM',
        'utm_post_class_meta_box',
        'post',
        'side',
        'default'
    );
}

function utm_post_class_meta_box( $post ) {
    wp_nonce_field( basename( __FILE__ ), 'utm_post_class_nonce' );?>

    <div class="components-base-control editor-post-excerpt__textarea">
        <div class="components-base-control__field">
            <label class="components-base-control__label" for="utm-post-class">UTM ссылка (необязательно)</label>
            <input type="text" name="utm-post-class" id="utm-post-class" class="edit-post-post-schedule" value="<?php echo esc_attr( get_post_meta( $post->ID, 'utm_post_class', true ) ); ?>">
        </div>
    </div>
<?php }

function utm_save_post_class_meta( $post_id, $post ) {

    if ( !isset( $_POST['utm_post_class_nonce'] ) || !wp_verify_nonce( $_POST['utm_post_class_nonce'], basename( __FILE__ ) ) )
        return $post_id;

    $post_type = get_post_type_object( $post->post_type );
    if ( !current_user_can( $post_type->cap->edit_post, $post_id ) )
        return $post_id;

    $new_meta_value = ( isset( $_POST['utm-post-class'] ) ? $_POST['utm-post-class'] : '' );
    $meta_key = 'utm_post_class';
    $meta_value = get_post_meta( $post_id, $meta_key, true );

    if ( $new_meta_value && '' == $meta_value )
        add_post_meta( $post_id, $meta_key, $new_meta_value, true );
    elseif ( $new_meta_value && $new_meta_value != $meta_value )
        update_post_meta( $post_id, $meta_key, $new_meta_value );
    elseif ( '' == $new_meta_value && $meta_value )
        delete_post_meta( $post_id, $meta_key, $meta_value );
}

您现在可以使用较新的useSelectuseDispatch自定义挂钩。 它们类似于withSelectwithDispatch ,但利用 React 16.8 中的自定义钩子来获得更简洁的开发体验:

(此外,使用@wordpress/scripts ,因此导入来自 npm 包而不是直接来自wp对象,但两者都可以。)

import { __ } from '@wordpress/i18n';
import { useSelect, useDispatch } from '@wordpress/data';
import { PluginDocumentSettingPanel } from '@wordpress/edit-post';
import { TextControl } from '@wordpress/components';

const TextController = (props) => {
  const meta = useSelect(
    (select) =>
      select('core/editor').getEditedPostAttribute('meta')['_myprefix_text_metafield']
  );
  const { editPost } = useDispatch('core/editor');
  return (
    <TextControl
      label={__("Text Meta", "textdomain")}
      value={meta}
      onChange={(value) => editPost({ meta: { _myprefix_text_metafield: value } })}
    />
  );
};

const PluginDocumentSettingPanelDemo = () => {
  return (
    <PluginDocumentSettingPanel
      name="custom-panel"
      title="Custom Panel"
      className="custom-panel"
    >
      <TextController />
    </PluginDocumentSettingPanel>
  );
};

export default PluginDocumentSettingPanelDemo;

除了像往常一样注册您的元字段:

function myprefix_register_meta()
{
    register_post_meta('post', '_myprefix_text_metafield', array(
        'show_in_rest' => true,
        'type' => 'string',
        'single' => true,
        'sanitize_callback' => 'sanitize_text_field',
        'auth_callback' => function () {
            return current_user_can('edit_posts');
        }
    ));
}
add_action('init', 'myprefix_register_meta');

并确保如果用于自定义帖子类型,则在supports数组中包含custom-fields

'supports' => array('title', 'editor', 'thumbnail', 'revisions', 'custom-fields'),

希望这有帮助。

你可能还喜欢下面这些文章

为什么WordPress自定义字段值在前台不显示为什么WordPress自定义字段值在前台不显示

WordPress自定义字段不显示是常见问题,本文系统分析8大原因及解决方案。首先确认后台"显示选项"中已启用自定义字段功能,检查主题模板是否包含get_post_meta()等字段调用代码,注意字段名称大小写和空格的一致性。排查插件冲突时建

如何利用WordPress自定义字段扩展文章元数据如何利用WordPress自定义字段扩展文章元数据

WordPress自定义字段是扩展文章元数据的强大工具,特别适合存储默认编辑界面无法满足的附加信息,如产品价格、活动日期等。本文详细介绍了如何启用和使用这一功能:首先确保自定义字段面板可见,通过“键-值”对结构化存储数据(如书评的ISBN号或

为什么WordPress主题自定义选项突然消失为什么WordPress主题自定义选项突然消失

WordPress主题自定义选项突然消失是常见问题,通常由主题兼容性、插件冲突或权限设置导致。本文提供详细排查步骤:首先检查当前主题是否支持Customizer功能,临时切换默认主题测试;其次通过停用插件逐一排查冲突源;验证用户权限是否被误修

如何为WordPress添加自定义文章类型如何为WordPress添加自定义文章类型

WordPress自定义文章类型(Custom Post Type)是扩展网站内容管理能力的强大工具。本文详细介绍了两种创建方法:使用Custom Post Type UI插件实现零代码操作,适合技术新手;通过functions.php文件手

如何为WordPress文章添加自定义字段如何为WordPress文章添加自定义字段

WordPress自定义字段功能允许为文章添加结构化额外信息,如产品参数或电影评分,解决内容管理中的复杂需求。文章详细介绍了从基础概念到高级应用的完整流程:首先解释自定义字段作为键值对的工作原理及原生功能的局限性;然后重点推荐使用Advanc

如何利用WordPress创建自定义404错误页面如何利用WordPress创建自定义404错误页面

如何利用WordPress创建自定义404错误页面 当用户访问不存在的页面时,默认的404错误页面往往缺乏吸引力且错失用户留存机会。本文详细介绍了如何通过简单方法打造个性化404页面,提升用户体验并降低跳出率。教程涵盖两种主流方案:使用El

为什么WordPress自定义文章类型无法归档为什么WordPress自定义文章类型无法归档

**摘要内容:** WordPress自定义文章类型(CPT)无法归档是开发者常见的问题,通常表现为日期归档页面404或内容缺失。本文系统分析了问题根源,并提供了完整解决方案:首先检查CPT注册参数,确保`has_archive`和`pub

如何通过WordPress创建自定义文章状态如何通过WordPress创建自定义文章状态

WordPress默认文章状态常无法满足复杂网站需求,本文详解如何创建自定义状态(如"特色文章""即将发布")来优化内容管理。教程提供两种实现方式:推荐新手使用PublishPress插件可视化添加状态(含颜色标记/RSS设置),或通过fun