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

如何使用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是否在列表中。

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

get_id(), $non_purchasable_product_ids ) ) {        return false; // 如果产品ID在列表中,则设置为不可购买    }    // 如果产品ID不在列表中,则返回其原始的可购买状态    return $is_purchasable;}

代码解析

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)。

function my_custom_non_purchasable_products($is_purchasable, $product)

这是我们的自定义回调函数,它接收当前的可购买状态和产品对象作为参数。

$non_purchasable_product_ids = array(20, 21, 22, 23, 24, 25, 26);

这是核心部分。您需要在此处列出所有您希望设置为不可购买的WooCommerce产品ID。请确保这些ID是正确的,并且用逗号分隔。

if ( in_array( $product->get_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在列表中),则条件成立。

return false;

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

return $is_purchasable;

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

代码放置位置

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

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

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

注意事项与最佳实践

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

总结

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

以上就是如何使用PHP过滤器使多个WooCommerce产品不可购买的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1337599.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月12日 23:21:29
下一篇 2025年12月12日 23:21:44

相关推荐

  • CSS 多列布局的适用场景是什么?

    CSS 多列布局的应用价值 问题: CSS 多列布局 (Multi-column Layout) 是否还有存在的价值? 答案: 是的,CSS 多列布局仍然有其独特的应用场景。 具体来说,多列布局在以下情况下会非常有用: 立即学习“前端免费学习笔记(深入)”; 小说阅读中的横向滚动: 对于小说等长文内…

    2025年12月24日
    000
  • 多列布局在现代 CSS 布局中还有用武之地吗?

    Multi-column Layout在现代CSS布局中的实用性 CSS中的多列布局(Multi-column Layout)曾经是一种常见的布局技术,用于创建多列文本布局。近年来,随着弹性盒布局(Flexbox)和网格布局(Grid)的广泛应用,多列布局似乎逐渐失去了昔日的光辉。那么,在现代CSS…

    2025年12月24日
    000
  • CSS多列布局,仍在用武之地吗?

    CSS多列布局Multi-column Layout:依然有其用武之地 虽然CSS网格布局(CSS Grid Layout)和弹性盒布局(Flexbox)已经成为现代网页布局的主流,但多列布局(Multi-column Layout)仍然在某些特定场景下拥有一席之地。 独特的使用场景 尽管在大多数情…

    2025年12月24日
    000
  • 现代网页设计中,CSS 多列布局是否依然实用?

    CSS多列布局:在现代网页设计中还有用武之地吗? CSS多列布局(Multi-column Layout)是一种将内容分成多列显示的技术。在早期的网络发展阶段,它曾经被广泛用于创建多栏式布局,但近年来随着响应式设计的兴起,其使用率有所下降。 它是否有自己独特的使用场景? 虽然多列布局在响应式设计中并…

    2025年12月24日
    000
  • 网页设计服务终极指南

    对于任何追求在线成功的企业来说,拥有一个迷人且实用的网站至关重要。在 Arham Web Works,我们了解创建网页设计的复杂性,不仅能吸引访问者,还能将他们转化为忠实的客户。我们的网页设计方法是全面的,将美学吸引力与无缝功能相结合。本指南将深入探讨网页设计服务的关键方面,展示为什么我们的专业知识…

    2025年12月24日
    200
  • 网页设计css样式代码大全,快来收藏吧!

    减少很多不必要的代码,html+css可以很方便的进行网页的排版布局。小伙伴们收藏好哦~ 一.文本设置    1、font-size: 字号参数  2、font-style: 字体格式 3、font-weight: 字体粗细 4、颜色属性 立即学习“前端免费学习笔记(深入)”; color: 参数 …

    2025年12月24日
    000
  • css中id选择器和class选择器有何不同

    之前的文章《什么是CSS语法?详细介绍使用方法及规则》中带了解CSS语法使用方法及规则。下面本篇文章来带大家了解一下CSS中的id选择器与class选择器,介绍一下它们的区别,快来一起学习吧!! id选择器和class选择器介绍 CSS中对html元素的样式进行控制是通过CSS选择器来完成的,最常用…

    2025年12月24日
    000
  • css怎么设置文件编码

    在css中,可以使用“@charset”规则来设置编码,语法格式“@charset “字符编码类型”;”。“@charset”规则可以指定样式表中使用的字符编码,它必须是样式表中的第一个元素,并且不能以任何字符开头。 本教程操作环境:windows7系统、CSS3&&…

    2025年12月24日
    000
  • php约瑟夫问题如何解决

    “约瑟夫环”是一个数学的应用问题:一群猴子排成一圈,按1,2,…,n依次编号。然后从第1只开始数,数到第m只,把它踢出圈,从它后面再开始数, 再数到第m只,在把它踢出去…,如此不停的进行下去, 直到最后只剩下一只猴子为止,那只猴子就叫做大王。要求编程模拟此过程,输入m、n, 输出最后那个大王的编号。…

    好文分享 2025年12月24日
    000
  • CSS的Word中的列表详解

    在word中,列表也是使用频率非常高的元素。在css中,列表和列表项都是块级元素。也就是说,一个列表会形成一个块框,其中的每个列表项也会形成一个独立的块框。所以,盒模型中块框的所有属性,都适用于列表和列表项。 除此之外,列表还有 3 个特有的属性 list-style-type、list-style…

    2025年12月24日
    000
  • CSS新手整理的有关CSS使用技巧

    [导读]  1、不要使用过小的图片做背景平铺。这就是为何很多人都不用 1px 的原因,这才知晓。宽高 1px 的图片平铺出一个宽高 200px 的区域,需要 200*200=40, 000 次,占用资源。  2、无边框。推荐的写法是     1、不要使用过小的图片做背景平铺。这就是为何很多人都不用 …

    好文分享 2025年12月23日
    000
  • CSS中实现图片垂直居中方法详解

    [导读] 在曾经的 淘宝ued 招聘 中有这样一道题目:“使用纯css实现未知尺寸的图片(但高宽都小于200px)在200px的正方形容器中水平和垂直居中。”当然出题并不是随意,而是有其现实的原因,垂直居中是 淘宝 工作中最 在曾经的 淘宝UED 招聘 中有这样一道题目: “使用纯CSS实现未知尺寸…

    好文分享 2025年12月23日
    000
  • CSS派生选择器

    [导读] 派生选择器通过依据元素在其位置的上下文关系来定义样式,你可以使标记更加简洁。在 css1 中,通过这种方式来应用规则的选择器被称为上下文选择器 (contextual selectors),这是由于它们依赖于上下文关系来应 派生选择器 通过依据元素在其位置的上下文关系来定义样式,你可以使标…

    好文分享 2025年12月23日
    000
  • CSS 基础语法

    [导读] css 语法 css 规则由两个主要的部分构成:选择器,以及一条或多条声明。selector {declaration1; declaration2;     declarationn }选择器通常是您需要改变样式的 html 元素。每条声明由一个属性和一个 CSS 语法 CSS 规则由两…

    2025年12月23日
    300
  • CSS 高级语法

    [导读] 选择器的分组你可以对选择器进行分组,这样,被分组的选择器就可以分享相同的声明。用逗号将需要分组的选择器分开。在下面的例子中,我们对所有的标题元素进行了分组。所有的标题元素都是绿色的。h1,h2,h3,h4,h5 选择器的分组 你可以对选择器进行分组,这样,被分组的选择器就可以分享相同的声明…

    好文分享 2025年12月23日
    000
  • CSS id 选择器

    [导读] id 选择器id 选择器可以为标有特定 id 的 html 元素指定特定的样式。id 选择器以 ” ” 来定义。下面的两个 id 选择器,第一个可以定义元素的颜色为红色,第二个定义元素的颜色为绿色: red {color:re id 选择器 id 选择器可以为标有特…

    好文分享 2025年12月23日
    000
  • 有关css的绝对定位

    [导读] 定位(左边和顶部) css定位属性将是网虫们打开幸福之门的钥匙: h4 { position: absolute; left: 100px; top: 43px }这项css规则让浏览器将 的起始位置精 确地定在距离浏览器左边100象素,距离其 定位(左边和顶部) css定位属性将是网虫们…

    好文分享 2025年12月23日
    000
  • 响应式HTML5按钮适配不同屏幕方法【方法】

    实现响应式HTML5按钮需五种方法:一、CSS媒体查询按max-width断点调整样式;二、用rem/vw等相对单位替代px;三、Flexbox控制容器与按钮伸缩;四、CSS变量配合requestAnimationFrame优化的JS动态适配;五、Tailwind等框架的响应式工具类。 如果您希望H…

    2025年12月23日
    000
  • html5能否禁用搜索框自动填充_html5autocomplete关闭方法【教程】

    禁用HTML5搜索框自动填充有五种方法:一、设autocomplete=”off”;二、随机化name/id值;三、用无效autocomplete值如”nope”;四、JS动态设置autocomplete;五、设autocomplete=”…

    2025年12月23日
    000
  • html5怎么导视频_html5用video标签导出或Canvas转DataURL获视频【导出】

    HTML5无法直接导出video标签内容,需借助Canvas捕获帧并结合MediaRecorder API、FFmpeg.wasm或服务端协同实现。MediaRecorder适用于WebM格式前端录制;FFmpeg.wasm支持MP4等格式及精细编码控制;服务端方案适合高负载场景。 如果您希望在网页…

    2025年12月23日
    300

发表回复

登录后才能评论
关注微信