问题描述
我目前在 WooCommerce 插件的函数文件中有这个代码。
function my_theme_wrapper_start()
{
echo the_breadcrumb();
echo '<section role="main"><div class="wrap">';
}
function my_theme_wrapper_end()
{
echo '</div></section>';
}
function mytheme_prepare_woocommerce_wrappers()
{
remove_action( 'woocommerce_before_main_content', 'woocommerce_output_content_wrapper', 10 );
remove_action( 'woocommerce_after_main_content', 'woocommerce_output_content_wrapper_end', 10);
add_action( 'woocommerce_before_main_content', 'my_theme_wrapper_start', 10 );
add_action( 'woocommerce_after_main_content', 'my_theme_wrapper_end', 10 );
}
add_action( 'wp_head', 'mytheme_prepare_woocommerce_wrappers' );
add_theme_support( 'woocommerce' );
现在我想在 Section.main 类之外重新定位 WooCommerce 面包屑,但我看不到如何做到这一点。有没有办法做到这一点?
这是我为 WooCommerce 面包屑编写的代码…
function woocommerce_breadcrumb( $args = array() ) {
$defaults = apply_filters( 'woocommerce_breadcrumb_defaults', array(
'delimiter' => ' / ',
'wrap_before' => '<nav class="bcrumb" itemprop="breadcrumb">',
'wrap_after' => '</nav>',
'before' => '',
'after' => '',
'home' => _x( 'Home', 'breadcrumb', 'woocommerce' ),
) );
$args = wp_parse_args( $args, $defaults );
woocommerce_get_template( 'shop/breadcrumb.php', $args );
}
我已经尝试将 section.main 标签放在’before’ 行中,但这只是在面包屑中添加了一个 section 标签,它不会重新定位导航痕迹。
最佳解决方案
好的,我似乎有工作。我在函数文件中添加了这个…
//Reposition WooCommerce breadcrumb
function woocommerce_remove_breadcrumb(){
remove_action(
'woocommerce_before_main_content', 'woocommerce_breadcrumb', 20);
}
add_action(
'woocommerce_before_main_content', 'woocommerce_remove_breadcrumb'
);
function woocommerce_custom_breadcrumb(){
woocommerce_breadcrumb();
}
add_action( 'woo_custom_breadcrumb', 'woocommerce_custom_breadcrumb' );
然后添加…
do_action('woo_custom_breadcrumb');
… 我想要面包屑显示。
参考文献
注:本文内容整合自 Google/Baidu/Bing 辅助翻译的英文资料结果。如果您对结果不满意,可以加入我们改善翻译效果:薇晓朵技术论坛。