【问题标题】:Woocommerce - External/Affiliate Product Image and title to External Link (New tab)Woocommerce - 外部/附属产品图像和外部链接标题(新标签)
【发布时间】:2018-03-12 19:04:27
【问题描述】:

我开始使用 wordpress 和 woocommerce 进行编程。搜索 Stack 后我需要帮助。

我需要我的商店产品的图片和标题指向附属链接,而无需通过单个帖子页面。并且所有内容都在新标签页中打开。

一直在关注这个话题:Woocommerce - External/Affiliate Product Image to External Link (Buy url)

我使用了来自 Sadoo 的 Edit #2 代码,它非常适合我。

remove_action('woocommerce_before_shop_loop_item', 'woocommerce_template_loop_product_link_open');
add_action('woocommerce_before_shop_loop_item_title', 'woocommerce_template_loop_product_link_open', 15);

add_action('woocommerce_before_shop_loop_item', 'woocommerce_add_aff_link_open', 10);
add_action('woocommerce_before_shop_loop_item_title', 'woocommerce_add_aff_link_close', 10);

function woocommerce_add_aff_link_open(){
  $product = wc_get_product(get_the_ID());
  if( $product->is_type( 'external' ) )
    echo '<a href="' . $product->get_product_url() . '" class="woocommerce-LoopProductImage-link">';
}

function woocommerce_add_aff_link_close(){
  $product = wc_get_product(get_the_ID());
  if( $product->is_type( 'external' ) )
    echo '</a>';
}

我只需要像图片一样链接的标题,所有内容都会在新标签中打开。

有人可以说我该如何继续吗?

谢谢

IMAGE

【问题讨论】:

标签: php wordpress woocommerce affiliate woothemes


【解决方案1】:

如果您想在商店页面的外部产品的新标签中打开附加到图像的链接,请像这样编辑您的代码

remove_action('woocommerce_before_shop_loop_item', 'woocommerce_template_loop_product_link_open');
add_action('woocommerce_before_shop_loop_item_title', 'woocommerce_template_loop_product_link_open', 15);
add_action('woocommerce_before_shop_loop_item', 'woocommerce_add_aff_link_open', 10);
add_action('woocommerce_before_shop_loop_item_title', 'woocommerce_add_aff_link_close', 10);

function woocommerce_add_aff_link_open(){
    $product = wc_get_product(get_the_ID());

    if( $product->is_type( 'external' ) ) {
        echo '<a target="_blank" href="' . $product->get_product_url() . '" class="">';
    }
}

function woocommerce_add_aff_link_close(){
    $product = wc_get_product(get_the_ID());

    if( $product->is_type( 'external' ) ) {
        echo '</a>';
    }
}

然后,如果您希望标题将在带有外部链接的新选项卡中打开,而不是将这些覆盖的 woocommerce 功能添加到您主题的 functions.php 文件中

function woocommerce_template_loop_product_link_open() {
    global $product;

    if( $product->is_type( 'external' ) ) {
        $link = apply_filters( 'woocommerce_loop_product_link', $product->get_product_url(), $product );
        echo '<a target="_blank" href="' . esc_url( $link ) . '" class="woocommerce-LoopProduct-link woocommerce-loop-product__link">';
    } else {
        $link = apply_filters( 'woocommerce_loop_product_link', get_the_permalink(), $product );
        echo '<a href="' . esc_url( $link ) . '" class="woocommerce-LoopProduct-link woocommerce-loop-product__link">';
    }
} 

【讨论】:

    【解决方案2】:

    这是一种更简洁的方法,可以将 target="_blank" 添加到存档页面上的链接以在新标签页中打开它们:

    function ns_open_in_new_tab($args, $product) 
    {
        if( $product->is_type('external') ) {
            // Inject target="_blank" into the attributes array
            $args['attributes']['target'] = '_blank';
        }    
    
        return $args;
    }
    add_filter( 'woocommerce_loop_add_to_cart_args', 'ns_open_in_new_tab', 10, 2 );
    

    ns_ 部分替换为您自己的命名空间缩写。

    【讨论】:

    • 在我看来更好的解决方案。谢谢
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-08-12
    相关资源
    最近更新 更多