0

0

如何使用PHP过滤器使多个WooCommerce产品不可购买

霞舞

霞舞

发布时间:2025-11-22 10:56:28

|

468人浏览过

|

来源于php中文网

原创

如何使用php过滤器使多个woocommerce产品不可购买

本教程详细介绍了如何利用 `woocommerce_is_purchasable` 过滤器,在WooCommerce中将一系列指定产品设置为不可购买。通过在PHP代码中定义一个产品ID数组,并结合 `in_array()` 函数,开发者可以精确控制哪些产品不能被添加到购物车,从而实现“联系我们”或定制销售流程,为商家提供灵活的产品销售管理能力。

概述:控制WooCommerce产品的可购买性

在WooCommerce商店运营中,有时我们需要阻止用户直接购买某些特定产品。这可能是出于多种原因,例如:产品需要定制报价、缺货但仍需展示、仅供展示而非销售,或者需要客户在购买前联系商家。WooCommerce提供了一个强大的过滤器 woocommerce_is_purchasable,允许开发者通过自定义PHP代码来控制任何产品的可购买状态。

本教程将指导您如何使用此过滤器,特别是如何针对多个产品ID实现这一功能,从而将它们设置为不可购买。

理解 woocommerce_is_purchasable 过滤器

woocommerce_is_purchasable 是一个WordPress/WooCommerce过滤器钩子,它在系统判断一个产品是否可以被添加到购物车时触发。它的定义如下:

立即学习PHP免费学习笔记(深入)”;

apply_filters( 'woocommerce_is_purchasable', $is_purchasable, $this );

其中:

  • $is_purchasable:一个布尔值,表示产品当前的默认可购买状态(true 或 false)。
  • $this:当前正在检查的 WC_Product 对象。

通过这个过滤器,我们可以截获并修改 $is_purchasable 的值,从而改变产品的购买行为。

单个产品不可购买的实现(初始方法)

最初,如果只需要将一个产品设置为不可购买,可以使用如下代码:

/**
 * 使单个WooCommerce产品不可购买。
 *
 * @param bool       $is_purchasable 当前可购买状态。
 * @param WC_Product $product        产品对象。
 * @return bool
 */
add_filter('woocommerce_is_purchasable', 'my_single_product_not_purchasable', 10, 2);
function my_single_product_not_purchasable($is_purchasable, $product) {
    // 假设产品ID为24的产品不可购买
    if ($product->get_id() == 24) {
        return false; // 如果是产品ID 24,则设置为不可购买
    }
    return $is_purchasable; // 否则,返回产品的原始可购买状态
}

这段代码通过检查产品ID是否为 24 来决定其可购买性。如果匹配,则返回 false,表示该产品不可购买。对于其他产品,它会返回 $is_purchasable 的原始值。

然而,当需要将多个产品设置为不可购买时,这种方法会变得冗长且难以维护。

针对多个产品ID实现不可购买性

为了更高效地管理多个不可购买的产品,我们可以利用PHP数组来存储这些产品的ID,并使用 in_array() 函数来检查当前产品ID是否在列表中。

Nanonets
Nanonets

基于AI的自学习OCR文档处理,自动捕获文档数据

下载

以下是实现这一功能的完整代码:

<?php
/**
 * 使指定WooCommerce产品列表不可购买。
 *
 * 此函数通过 'woocommerce_is_purchasable' 过滤器,
 * 检查当前产品是否在预定义的不可购买产品ID列表中。
 * 如果是,则将产品设置为不可购买。
 *
 * @param bool       $is_purchasable 当前产品的可购买状态。
 * @param WC_Product $product        WC_Product 产品对象。
 * @return bool 返回修改后的可购买状态。
 */
add_filter('woocommerce_is_purchasable', 'my_custom_non_purchasable_products', 10, 2);

function my_custom_non_purchasable_products($is_purchasable, $product) {
    // 定义一个包含所有不可购买产品ID的数组
    // 请将以下示例ID替换为您实际需要设置为不可购买的产品ID
    $non_purchasable_product_ids = array(
        20,  // 示例产品ID 1
        21,  // 示例产品ID 2
        22,  // 示例产品ID 3
        23,  // 示例产品ID 4
        24,  // 示例产品ID 5
        25,  // 您可以根据需要添加更多产品ID
        26
    );

    // 检查当前产品的ID是否在不可购买产品列表中
    if ( in_array( $product->get_id(), $non_purchasable_product_ids ) ) {
        return false; // 如果产品ID在列表中,则设置为不可购买
    }

    // 如果产品ID不在列表中,则返回其原始的可购买状态
    return $is_purchasable;
}

代码解析

  1. add_filter('woocommerce_is_purchasable', 'my_custom_non_purchasable_products', 10, 2);

    • 这行代码将我们的自定义函数 my_custom_non_purchasable_products 挂载到 woocommerce_is_purchasable 过滤器上。
    • 10 是优先级,表示在其他函数之前或之后运行(数字越小,优先级越高)。
    • 2 表示我们的函数接受两个参数 ($is_purchasable 和 $product)。
  2. function my_custom_non_purchasable_products($is_purchasable, $product)

    • 这是我们的自定义回调函数,它接收当前的可购买状态和产品对象作为参数。
  3. $non_purchasable_product_ids = array(20, 21, 22, 23, 24, 25, 26);

    • 这是核心部分。您需要在此处列出所有您希望设置为不可购买的WooCommerce产品ID。请确保这些ID是正确的,并且用逗号分隔。
  4. if ( in_array( $product-youjiankuohaophpcnget_id(), $non_purchasable_product_ids ) ) { ... }

    • $product->get_id():这是获取当前产品ID的标准方法(推荐使用 get_id() 而非 $product->id,因为后者可能在未来版本中被弃用)。
    • in_array():这是一个PHP内置函数,用于检查一个值是否存在于数组中。在这里,它检查当前产品的ID是否在 $non_purchasable_product_ids 数组中。
    • 如果 in_array() 返回 true(即产品ID在列表中),则条件成立。
  5. return false;

    • 如果当前产品ID在 $non_purchasable_product_ids 数组中,我们强制将其可购买状态设置为 false。这意味着该产品将无法被添加到购物车。
  6. return $is_purchasable;

    • 如果当前产品ID不在不可购买列表中,我们不干预其状态,而是返回 $is_purchasable 的原始值。这样可以确保其他产品保持其默认的可购买行为。

代码放置位置

将上述PHP代码添加到您的WordPress网站的以下位置之一:

  1. 子主题的 functions.php 文件 (推荐): 这是最常见且最安全的方法。如果您使用的是第三方主题,创建一个子主题可以确保在主题更新时您的自定义代码不会丢失。
  2. 自定义插件: 如果您有多个自定义功能,或者希望此功能在更换主题后依然有效,创建一个轻量级的自定义插件是更好的选择。

重要提示切勿直接修改父主题的 functions.php 文件,因为在主题更新时,您的所有更改都将被覆盖。

注意事项与最佳实践

  • 产品ID准确性:确保您在 $non_purchasable_product_ids 数组中输入的产品ID是正确的。错误的ID将导致预期的产品仍然可购买,或者错误的产品变得不可购买。
  • 用户体验:当产品不可购买时,WooCommerce通常会将“添加到购物车”按钮替换为“阅读更多”或自定义文本。请确保这种变化对您的用户来说是清晰和直观的。您还可以考虑添加一个自定义消息,解释产品为何不可购买以及如何联系您。
  • 缓存:在实施此类代码更改后,请务必清除您的网站缓存(包括任何WordPress插件缓存、CDN缓存和服务器级缓存),以确保更改立即生效。
  • 测试:在将代码部署到生产环境之前,务必在开发或 staging 环境中进行全面测试,以验证其功能是否符合预期。
  • 可维护性:对于非常多的不可购买产品,或者需要动态管理列表的情况,可以考虑将产品ID存储在数据库选项中,而不是硬编码在数组里,这样更方便通过后台界面进行管理。

总结

通过利用 woocommerce_is_purchasable 过滤器和PHP的 in_array() 函数,您可以轻松地将多个WooCommerce产品设置为不可购买。这种方法提供了一种灵活且高效的方式来控制产品的销售流程,以满足特定的业务需求。遵循本教程中的步骤和最佳实践,您将能够成功地在您的WooCommerce商店中实现这一功能。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

499

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

166

2023.10.07

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

386

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2111

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

357

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

259

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

329

2023.10.09

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.4万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号