我有一个WordPress网站,使用woocommerce(在内部页面),我的网页结构如下:
mysite的/店铺/
woocommerce页面上的breadcrumb仅显示主页链接: 你在这里:主页
和我的产品页面网址:
MYSITE /产品类别/ CATEGORY_NAME /
我的店铺面包屑显示如下:
You are here: Home
我的类别页面痕迹显示如下:
You are here: Home
我需要将其显示为:
您现在的位置:主页/购物/ category_name
我检查了固定链接选项,但似乎没问题。 我检查了breadcrumb.php模板文件,似乎认为shop()页面是我网站的主页。
如果我编辑breadcrumb.php或我的设置中有错误,我该怎么办呢? 提前谢谢。
答案 0 :(得分:8)
我正在调试这个,不幸的是Woocommerce(版本2.3.8)没有使用任何钩子来直接调整breadcrumbs数组。因此,如果您想要修改显示的面包屑而不更改固定链接结构,最好是将插件(/woocommerce/templates/global/breadcrumb.php
)中的面包屑模板文件复制到您的主题(/theme_name/woocommerce/global/
)中,然后添加代码以包含输出循环开始之前的链接。我只针对产品类别,标签和细节进行此操作,但如果您愿意,可以添加其他条件。
<?php
/**
* Shop breadcrumb
*
* @author WooThemes
* @package WooCommerce/Templates
* @version 2.3.0
* @see woocommerce_breadcrumb()
*/
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
if ( $breadcrumb ) {
// add shop home url to breadcrumbs
if( is_product_category() || is_product_tag() || is_product() ) {
$shop_page_id = wc_get_page_id( 'shop' );
$shop_home_arr = array( get_the_title($shop_page_id), get_permalink($shop_page_id));
// insert to breadcrumbs array on second position
array_splice($breadcrumb, 1, 0, array($shop_home_arr));
}
echo $wrap_before;
foreach ( $breadcrumb as $key => $crumb ) {
echo $before;
if ( ! empty( $crumb[1] ) && sizeof( $breadcrumb ) !== $key + 1 ) {
echo '<a href="' . esc_url( $crumb[1] ) . '">' . esc_html( $crumb[0] ) . '</a>';
} else {
echo esc_html( $crumb[0] );
}
echo $after;
if ( sizeof( $breadcrumb ) !== $key + 1 ) {
echo $delimiter;
}
}
echo $wrap_after;
}
答案 1 :(得分:4)
这可以轻松完成。只需要相应地更改永久链接设置 - 如issue 3145上的github所述:
符合此标准:
// If permalinks contain the shop page in the URI prepend the breadcrumb with shop if ( $shop_page_id && strstr( $permalinks['product_base'], '/' . $shop_page->post_name ) && get_option( 'page_on_front' ) !== $shop_page_id ) { $prepend = $before . '<a href="' . get_permalink( $shop_page ) . '">' . $shop_page->post_title . '</a> ' . $after . $delimiter; }
否则它永远不会被放在前面。
要申请这个,必须去:
→WordPress后端→设置→永久链接
并将woocommerce永久链接设置设置为以下其中一种:
如果使用后者,则必须预留slu»»/ shop / ...«。
有一个issue 6584:
警告:preg_match():第533行wc-core-functions.php中的未知修饰符't'
例如,如果»Custom Base«如下所示:»/ shop / product / ...«。有一个commit修复了它,可以在master中使用,但不是2.2.8。
slug part shop也可以被其他东西替换,例如本地化的东西。
答案 2 :(得分:1)
我发现breadcrumb代码在我的courture主题文件夹的header.php中,该主题的作者没有为产品或产品类别页面编写代码,所以我添加了
elseif (is_single() && get_post_type() == 'product'){
$posts_page_id = get_option('page_for_posts');
$posts_page_url = get_permalink($posts_page_id);
echo '<li>';$bar = "shopping";
if(get_option_tree('blog_name', '', false))
/*$bar=get_option_tree('blog_name', '', false);*/
echo "<a href=".home_url()."/shopping/>$bar</a></li>";
echo "<li>";
the_title();
echo"</li>";
}
和产品类别页面
if (is_tax()) {
$posts_page_id = get_option('page_for_posts');
$posts_page_url = get_permalink($posts_page_id);
echo '<li>';$bar = "Shopping";
if(get_option_tree('blog_name', '', false))
echo "<a href=".home_url()."/shopping/>$bar</a> > </li>" ;
echo "<li>";
woocommerce_page_title();
echo"</li>";}
我评论了获取blog_name的行,因为我使用自定义页面为我的商店而不是woocommerce默认页面。我不知道是否有另一种方法可以做到这一点,但我注意到这个主题中的大多数代码都不是真正专业,即使在widget css中它也是一个糟糕的选择。
答案 3 :(得分:1)
对于任何在2019年偶然发现此问题的人,如果您不想更改固定链接或编辑主题文件,则可以使用一种更简单的方法在“主页”面包屑后添加项目。这可能不是一个完美的解决方案,但对我有用。
WC_Breadcrumb类在将面包屑返回之前对其进行过滤,我们可以挂接并修改数组。 $ crumbs数组只是[[title,url],[title,url]]的数组
add_filter( 'woocommerce_get_breadcrumb', function($crumbs, $Breadcrumb){
$shop_page_id = wc_get_page_id('shop'); //Get the shop page ID
if($shop_page_id > 0 && !is_shop()) { //Check we got an ID (shop page is set). Added check for is_shop to prevent Home / Shop / Shop as suggested in comments
$new_breadcrumb = [
_x( 'Shop', 'breadcrumb', 'woocommerce' ), //Title
get_permalink(wc_get_page_id('shop')) // URL
];
array_splice($crumbs, 1, 0, [$new_breadcrumb]); //Insert a new breadcrumb after the 'Home' crumb
}
return $crumbs;
}, 10, 2 );