WordPress教程

给WooCommerce结算回执页面添加打印按钮

阿里云

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

示例 1

这会在两个页面(”已收到订单”页面和客户的”查看订单”页面)的”订单详细信息”部分的正右上方添加”打印收据”链接按钮,将以下代码粘贴到 functions.php 文件。

也想出现在这里?联系我们
创客主机
  1. /**
  2.  * Add "Print receipt" link to Order Received page and View Order page
  3.  */
  4. function isa_woo_thankyou() {
  5.     echo '<a href="javascript:window.print()" id="wc-print-button">打印页面</a>';
  6. }
  7. add_action( 'woocommerce_thankyou', 'isa_woo_thankyou', 1);
  8. add_action( 'woocommerce_view_order', 'isa_woo_thankyou', 8 );

示例 2

注意:示例 1 在”谢谢,你的订单已收到”之后和”订单详细信息”之前语句添加了打印链接按钮。在”收到的订单”页面上,可以选择将”打印收据”按钮链接移到”谢谢”上方的顶部。要将你的按钮移到那里,请使用该按钮代替上面的代码(这仍会将打印链接添加到与上面的代码相同的位置的”查看订单”页面上):

  1. function isa_get_wc_print_receipt_link() {
  2.     return '<a href="javascript:window.print()" id="wc-print-button">打印页面</a>';
  3. }
  4.  
  5. /**
  6.  * 将"打印页面"链接添加到WooCommerce查看订单页面
  7.  */
  8. function isa_woo_view_order_print_receipt() {
  9.     echo isa_get_wc_print_receipt_link();
  10. }
  11. add_action( 'woocommerce_view_order', 'isa_woo_view_order_print_receipt', 8 );
  12.  
  13. /**
  14.  * 将"打印页面"链接添加到WooCommerce收到的订单页面顶部
  15.  */
  16. function isa_woo_order_print_receipt_top( $text, $order ) {
  17.     $out = isa_get_wc_print_receipt_link();
  18.     return $out . ' ' . $text;
  19. }
  20. add_filter( 'woocommerce_thankyou_order_received_text', 'isa_woo_order_print_receipt_top', 999, 2);

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

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

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

  1. @media print {
  2.  
  3.     body{
  4.         font-size: 11px;
  5.     }
  6.  
  7.     .site-title,
  8.     .site-description,
  9.     h2,
  10.     h3{
  11.         font-size: 12pt;
  12.     }
  13.  
  14.     .custom-header-media,
  15.     .entry-title,
  16.     #wc-print-button,
  17.     .site-description{
  18.         display: none !important;
  19.     }
  20.  
  21.     .site-branding,
  22.     .custom-header,
  23.     .page:not(.home) #content,
  24.     #content .site-content  {
  25.         margin:0 !important;
  26.         padding:0 !important;
  27.     }
  28.  
  29. }

WooCommerce 订单(Twenty Seventeen 主题)的印刷收据长 2 页。

添加 CSS @print media query 后,相同 WooCommerce 订单的打印收据。请注意,现在收据已最小化以适合一页。

给 WooCommerce 结算回执页面添加打印按钮

已有 280 人购买
查看演示升级 VIP立刻购买

收藏
(0)

发表回复

热销模板

Ashade - 作品展示摄影相册WordPress汉化主题
LensNews

本站承接 WordPress / PbootCMS / DedeCMS 等
系统建站、仿站、开发、定制等业务!