我的网站使用免费的"响应式"Wordpress主题,这是我第一次使用Child主题。
我需要在小部件<h3>
标记下面添加一个div标记,但标记所在的侧边栏函数存储在父函数中,并且我在覆盖Child主题中的函数时遇到了问题。
这就是我必须尝试删除家长边栏功能,并重新添加我自己的功能,但它并没有删除边栏:
添加边条的原始函数看起来与我的函数child_responsive_widgets_init()
相同,但如果有帮助的话,它被称为responsive_widgets_init()
。
<?php
function child_responsive_widgets_init() {
register_sidebar( array(
'name' => __( 'Main Sidebar', 'responsive' ),
'description' => __( 'Area 1 - sidebar.php - Displays on Default, Blog, Blog Excerpt page templates', 'responsive' ),
'id' => 'main-sidebar',
'before_title' => '<div class="widget-title"><h3>',
'after_title' => '</h3><em> </em></div>',
'before_widget' => '<div id="%1$s" class="widget-wrapper %2$s">',
'after_widget' => '</div>'
) );
}
function remove_parent_widgets() {
remove_action( 'widgets_init', 'responsive_widgets_init' );
}
add_action('init','remove_parent_widgets');
add_action( 'widgets_init', 'parent_unregister_sidebars' );
function parent_unregister_sidebars() {
unregister_sidebar( 'main-sidebar' );
}
add_action( 'widgets_init', 'child_responsive_widgets_init' );
?>
我们必须等到functions.php
文件加载后,才能拦截父级的钩子。
将此添加到孩子的functions.php
:
add_action( 'after_setup_theme', 'remove_parent_hook_so_22995302' );
function remove_parent_hook_so_22995302()
{
remove_action( 'widgets_init', 'responsive_widgets_init' );
}
从问题移到答案中
多亏了brasofilo和他的解决方案,我已经正确地覆盖了函数文件。如果有人想知道的话,下面是更新的代码。
function child_responsive_widgets_init() {
register_sidebar( array(
'name' => __( 'Main Sidebar', 'responsive' ),
'description' => __( 'Area 1 - sidebar.php - Displays on Default, Blog, Blog Excerpt page templates', 'responsive' ),
'id' => 'main-sidebar',
'before_title' => '<div class="widget-title"><h3>',
'after_title' => '</h3><em> </em></div>',
'before_widget' => '<div id="%1$s" class="widget-wrapper %2$s">',
'after_widget' => '</div>'
) );
}
add_action('after_setup_theme','remove_parent_widgets');
function remove_parent_widgets() {
remove_action( 'widgets_init', 'responsive_widgets_init' );
}
add_action( 'after_setup_theme', 'child_responsive_widgets_init' );