如何检查哪些优惠券适用于 WooCommerce 中的哪些产品?

2024-01-10

由于我们可以为订单中的每个产品应用不同的优惠券, 有什么方法可以知道哪些优惠券适用于哪些产品? 我用过$order->get_used_coupons()函数,但它只返回使用过的优惠券代码。

请帮忙解决。 谢谢。


2016 年 6 月为 Woocommerce 2.5.x 制作的示例(不适用于 Woocommerce 3+)

此示例基于编译的搜索:

function wc_my_order_coupons( $order_id ) {
    $order = new WC_Order( $order_id );

    // checking if order has some used coupons
    if( sizeof($order->get_used_coupons()) > 0 ) {
        foreach( $order->get_used_coupons() as $coupon_code ) {

            // Retrieving the coupon ID
            $post_obj = get_page_by_title($coupon_code, OBJECT, 'shop_coupon');
            $coupon_id = $post_obj->ID;

            // here is a list of most all data that you can use for a coupon
            $cp_discount_type = get_post_meta( $coupon_id, 'discount_type', true );
            $cp_amount = get_post_meta( $coupon_id, 'coupon_amount', true );
            $cp_indiv_use = get_post_meta( $coupon_id, 'individual_use', true );
            $cp_products = get_post_meta( $coupon_id, 'product_ids' ); 
            $cp_excl_products = get_post_meta( $coupon_id, 'exclude_product_ids' );
            $cp_usage_limit = get_post_meta( $coupon_id, 'usage_limit', true );
            $cp_expiry_date = get_post_meta( $coupon_id, 'expiry_date', true );
            $cp_apply_before_tax = get_post_meta( $coupon_id, 'apply_before_tax', true );
            $cp_free_shipping = get_post_meta( $coupon_id, 'free_shipping', true ); 

            // Getting the products in this order_id
            $items = $order->get_items();
            foreach ($items as $key => $item) {
                $product_name = $item['name'];
                $product_id = $item['product_id'];

                // Example: we use product_ids authorized in the coupon $cp_products
                if (in_array($product_id, $cp_products)) {
                    echo $product_name . 'uses the coupon: ' . $coupon->code . '<br>';
                }
            }
        }
    }
}

参考 :

  • WC_Coupon 类方法和属性 https://docs.woothemes.com/wc-apidocs/class-WC_Coupon.html
  • WC ApiDocs - WC_Coupon 类源 https://docs.woothemes.com/wc-apidocs/source-class-WC_Coupon.html#18
  • 以编程方式创建优惠券 https://docs.woothemes.com/document/create-a-coupon-programatically/
  • 通过电子邮件发送订单中使用的优惠券 https://docs.woothemes.com/document/send-coupons-used-in-an-order-by-email/
  • 显示优惠券说明 woocommerce https://stackoverflow.com/questions/28017767/display-coupon-description-woocommerce
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何检查哪些优惠券适用于 WooCommerce 中的哪些产品? 的相关文章

  • PHP cURL 重定向到本地主机

    我正在尝试使用带有 cURL 的 php 脚本登录外部网页 我是 cURL 的新手 所以我觉得我错过了很多东西 我找到了几个例子并修改了它们以允许访问https页面 最终 我的目标是能够登录页面并在登录后通过指定的链接下载 csv 到目前为
  • 知道何时调用 persist

    我正在使用 Doctrine 2 作为我的 ORM 一切进展顺利 但我一直想知道EntityManager persist 方法 这 持久实体 https www doctrine project org projects doctrine
  • 在 PHP 中拆分 XML

    我有一个带有根元素和多个项目子元素的合并 xml 像这样的东西
  • 在 php 和 mysql 中使用 utf8mb4

    我读过 mysql gt 5 5 3 完全支持每个可能的字符 如果您使用编码utf8mb4对于某个表 列http mathiasbynens be notes mysql utf8mb4 http mathiasbynens be note
  • php exec 返回的结果比直接进入命令行要少

    我有一个 exec 命令 它的行为与通过 Penguinet 给 linux 的相同命令不同 res exec cd mnt mydirectory zcat log file gz echo res 当将命令直接放入命令行时 我在日志文件
  • 限制分页页数

    objConnect mysql connect localhost root or die mysql error objDB mysql select db Test strSQL SELECT FROM UserAddedRecord
  • 用PHP动态生成二维码[关闭]

    Closed 此问题正在寻求书籍 工具 软件库等的推荐 不满足堆栈溢出指南 help closed questions 目前不接受答案 我正在尝试在我的网站上生成二维码 他们所要做的就是在其中包含一个 URL 我网站上的变量将提供该 URL
  • PHP 和 MySQL 的重音字符错误

    我的问题是 直接通过 PHP 编写的内容是正确重音的 但是当重音单词来自 MySQL 时 字母会像这样 我尝试使用html charset as ISO 8859 1它修复了 MySQL 字母 但破坏了其他字母 解决这一切的一种方法是设置我
  • 新的 Wp_Query() 或 pre_get_posts() 来查看自定义帖子类型的所有帖子?

    我有一个存档模板文件 显示自定义帖子类型人员的所有帖子 称为 archive personnel php 这是文件的开头
  • 扫描 PHP 上传的病毒

    我目前正在使用以下代码来扫描作为申请表的一部分上传的文件 safe path escapeshellarg dir file command usr bin clamscan stdout safe path out int 1 exec
  • 无法在 PHPUnit 中使用数据提供程序运行单个测试

    使用命令行运行测试时遇到问题 如果我像这样运行 phpunit phpunit no configuration filter testAdd DataTest DataProviderTest php 效果很好 但是我们使用正则表达式来准
  • 在 PHP 中使用数组来比较用户名/密码

    我有以下 php 脚本 其中有一个用户名和密码 Username user1 Password pass1 if isset POST submitform Clean up the input values foreach POST as
  • 我应该使用排队系统来处理付款吗?

    我在用着Slim https www slimframework com和这个结合Stripe 的 PHP 库 https stripe com docs api php在我的应用程序中处理付款 一切都很好 但是直到最近 我在我的系统中发现
  • SVG 转 JPG / PNG

    有没有工作模块可以convert a SVG image into像素格式如JPEG or PNG 看看蜡染工具包 具体来说是光栅化器 http xmlgraphics apache org batik tools rasterizer h
  • 如何检查一个值是否已经存在以避免重复?

    我有一个 URL 表 但我不想要任何重复的 URL 如何使用 PHP MySQL 检查给定 URL 是否已在表中 如果您不想重复 可以执行以下操作 添加唯一性约束 use REPLACE http dev mysql com doc ref
  • 除括号之间的内容外,所有内容均小写

    考虑以下字符串 LoReM FOO IPSUM dolor BAR Samet fooBar 我正在寻找一种方法来小写所有内容 除了 brackets 之间的内容应该被忽略 所以期望的输出是 lorem FOO ipsum dolor BA
  • 如何在 PHP >= 5.3 严格模式下向对象添加属性而不产生错误

    这必须很简单 但我似乎找不到答案 我有一个通用的 stdClass 对象 foo没有属性 我想添加一个新属性 bar尚未定义 如果我这样做 foo new StdClass foo gt bar 1234 严格模式下的 PHP 会抱怨 将属
  • 有关于 PHP 中的 V8JS 的文档吗?

    有没有关于V8JS的文档 我是否只需要标准 PHP 或一些扩展即可使用 V8JS 我将非常感谢有关 PHP 中的 V8JS 的任何信息 要求 PHP 5 3 3 和 V8 库和标头安装在正确的路径中 Install http www php
  • 使用“AND”表达式构建动态 SQL,而不混淆嵌套条件?

    总的来说 我对 php 和编码相当陌生 我有一系列条件需要测试它们是否已设置 它们是 option1 option2 option3 if isset option1 if isset option2 if isset option3 qu
  • MYSQL 按喜欢/不喜欢和受欢迎程度排序

    我有评论表 其中包括喜欢和不喜欢的内容 现在我在正确的顺序上遇到了问题 实际上 我的系统在顶部显示了最多点赞的评论 我正在 youtube 上寻找类似系统的东西 这意味着 100like 100dislikes 的评论的顺序高于 1 1 我

随机推荐