WordPress教程

允许用户在 WooCommerce 中通过搜索订单备注过滤订单

阿里云

在处理 WooCommerce 订单的时候,我们会添加一些信息到订单备注中,这些订单备注在 WooCommerce 的订单搜索功能中是无法被搜索的。当我们需要通过订单备注查找订单的时候,就变得非常困难了。

我们知道,WooCommerce 的订单备注是保存在评论数据库中的,同时 WooCommerce 为我们提供了一个名为「woocommerce_shop_order_search_results」的 filter 来让我们过滤订单搜索结果。有了这两个信息,我们就可以通过查询评论数据来搜索订单备注了。

也想出现在这里?联系我们
创客主机

在 WooCommerce 中搜索订单备注的关键代码

下面是允许用户在 WooCommerce 中搜索订单备注的代码。代码中通过查询评论数据中包含某关键词的评论,获取这些评论的文章 ID(也就是订单 ID)。然后包含这些评论的订单 ID,就达到了通过搜索订单备注查询过滤订单的目的。

  1. add_filter('woocommerce_shop_order_search_results', function ($order_ids, $term, $search_fields)
  2. {
  3.     global $wpdb;
  4.  
  5.     $comment_query = $wpdb->get_results(
  6.         $wpdb->prepare(
  7.             "SELECT comment_post_ID
  8.              FROM {$wpdb->prefix}comments as comment_ids
  9.              WHERE comment_content LIKE %s
  10.              AND comment_type LIKE %s",
  11.             '%' . $wpdb->esc_like(wc_clean($term)) . '%',
  12.             'order_note'
  13.         )
  14.     );
  15.  
  16.     $comment_posts_id = wp_list_pluck($comment_query, 'comment_post_ID');
  17.  
  18.     if ( ! empty($comment_posts_id)) {
  19.         $order_ids = array_merge($order_ids, $comment_posts_id);
  20.     }
  21.  
  22.     return $order_ids;
  23. }, 11, 3);

把上面的代码复制到主题的 functions.php 或插件中即可。

搜索更多 WooCommerce 自定义数据

除了搜索订单备注,我们还可以通过 「woocommerce_shop_order_search_results」filter 来实现更多自定义数据的搜索。这个 filter 提供了 3 个参数:$order_ids, $term, $search_fields

  • $order_ids: 上一个 Filter 返回的订单 ID 数据,如果我们的自定义查询没有结果,直接返回这个参数即可。
  • $term:搜索关键词
  • $search_fields:搜索字段,主要是指订单中的自定义字段,主要是搜索查询的自定义字段名称。我们可以用这个自定来做一些判断。如果想修改这个字段,请使用 「woocommerce_shop_order_search_fields」filter 进行修改。

允许用户在 WooCommerce 中通过搜索订单备注过滤订单

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

收藏
(0)

发表回复

热销模板

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

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