滑动继续阅读⇓

在WooCommerce订单接收页面和查看订单页面添加打印按钮功能

这会将”打印页面”链接添加到WooCommerce”已收到订单”页面(收据页面)。还可将链接也添加到”查看订单”页面。客户可以在”帐户”区域的”最近订单”列表中看到”查看订单”页面。

将以下代码粘贴到functions.php文件。

示例1

这会在两个页面(”已收到订单”页面和客户的”查看订单”页面)的”订单详细信息”部分的正右上方添加”打印收据”链接按钮:


/**
 * Add "Print receipt" link to Order Received page and View Order page
 */
function isa_woo_thankyou() {
    echo '<a href="javascript:window.print()" id="wc-print-button">打印页面</a>';
}
add_action( 'woocommerce_thankyou', 'isa_woo_thankyou', 1);
add_action( 'woocommerce_view_order', 'isa_woo_thankyou', 8 );

示例2

注意:示例1在”谢谢,你的订单已收到”之后和”订单详细信息”之前语句添加了打印链接按钮。

在”收到的订单”页面上,可以选择将”打印收据”按钮链接移到”谢谢”上方的顶部。要将你的按钮移到那里,请使用该按钮代替上面的代码(这仍会将打印链接添加到与上面的代码相同的位置的”查看订单”页面上):


function isa_get_wc_print_receipt_link() {
    return '<a href="javascript:window.print()" id="wc-print-button">打印页面</a>';
}
 
/**
 * 将"打印页面"链接添加到WooCommerce查看订单页面
 */
function isa_woo_view_order_print_receipt() {
    echo isa_get_wc_print_receipt_link();
}
add_action( 'woocommerce_view_order', 'isa_woo_view_order_print_receipt', 8 );
 
/**
 * 将"打印页面"链接添加到WooCommerce收到的订单页面顶部
 */
function isa_woo_order_print_receipt_top( $text, $order ) {
    $out = isa_get_wc_print_receipt_link();
    return $out . ' ' . $text;
}
add_filter( 'woocommerce_thankyou_order_received_text', 'isa_woo_order_print_receipt_top', 999, 2);

设置打印收据链接的样式,使其看起来像一个按钮

添加此CSS来设置”打印回执”链接按钮的样式,使其看起来像一个常规的主题自带的功能按钮。


#wc-print-button {
    display: inline-block;
    text-decoration:none;
    margin: 8px 10px 8px 0;
    padding: 5px 15px;
    border:0;
    color: #fff;
    background-color: #6496c8;
    border-radius: 17px;
    box-shadow: 1px 1px 1px #888;
    float: right;
}
#wc-print-button:hover {
    opacity: .7;
    color: #fff;
}

打印按钮的样式
通过添加针对打印版面的CSS媒体查询,可以使打印的收据看起来更好看。以下CSS示例特定于WordPress Twenty Seventeen主题。如果使用”Twenty Seventeen主题”,此CSS将使WooCommerce打印的收据看起来更好。通过减小字体大小,减少空白和换行符,它可以完全适合页面。在使用这些CSS样式之前和之后,打印后的收据的前后图像请参见下文。


@media print {
 
    body{
        font-size: 11px;
    }
 
    .site-title,
    .site-description,
    h2,
    h3{
        font-size: 12pt;
    }
     
    .custom-header-media,
    .entry-title,
    #wc-print-button,
    .site-description{
        display: none !important;
    }
     
    .site-branding,
    .custom-header,
    .page:not(.home) #content,
    #content .site-content  {
        margin:0 !important;
        padding:0 !important;
    }
 
}

WooCommerce订单(Twenty Seventeen主题)的印刷收据长2页。
将打印回执添加到WooCommerce订单接收页和查看订单页
添加CSS @print media query后,相同WooCommerce订单的打印收据。请注意,现在收据已最小化以适合一页。
将打印回执添加到WooCommerce订单接收页和查看订单页

本文是否有帮助?



iTopVPN Black Friday Deal - Save up to 90%