0

0

在WooCommerce商店和归档页面产品价格后添加自定义内容

霞舞

霞舞

发布时间:2025-07-18 21:02:11

|

332人浏览过

|

来源于php中文网

原创

在woocommerce商店和归档页面产品价格后添加自定义内容

本教程详细介绍了如何在WooCommerce商店和产品归档页面(非单品页)的产品价格下方,通过使用WordPress和WooCommerce的动作钩子,插入自定义PHP内容。文章将提供具体的代码示例,并解释其工作原理,帮助开发者轻松实现页面内容的灵活扩展。

概述:利用动作钩子扩展WooCommerce显示

在WooCommerce中,我们经常需要对默认的产品显示布局进行调整,例如在产品价格下方添加额外的信息,如作者电话、商品库存状态或自定义标签等。WooCommerce提供了丰富的动作钩子(Action Hooks),允许开发者在特定位置注入自定义代码,而无需直接修改核心模板文件。这种方法不仅安全,而且在主题或插件更新时能够保持修改的有效性。

本教程的目标是在WooCommerce的商店主页、分类页和标签归档页等产品列表页面中,于每个产品价格的下方添加一段自定义的PHP内容。这里以输出产品作者的电话信息为例,但其原理适用于任何希望添加的HTML或PHP内容。

实现步骤:在functions.php中添加代码

要实现这一功能,我们需要将自定义代码添加到WordPress主题的functions.php文件中。强烈建议使用子主题(Child Theme)的functions.php文件,以避免在主题更新时丢失您的修改。

LANUX蓝脑商务网站系统
LANUX蓝脑商务网站系统

LANUX V1.0 蓝脑商务网站系统 适用于网店、公司宣传自己的品牌和产品。 系统在代码、页面方面设计简约,浏览和后台管理操作效率高。 此版本带可见即可得的html编辑器, 方便直观添加和编辑要发布的内容。 安装: 1.解压后,更换logo、分类名称、幻灯片的图片及名称和链接、联系我们等等页面。 2.将dbconfig.php里面的数据库配置更改为你的mysql数据库配置 3.将整个文件夹上传至

下载
  1. 访问主题文件: 通过WordPress后台的“外观” -> “主题文件编辑器”,或使用FTP/cPanel文件管理器,导航到您的主题(或子主题)目录下的functions.php文件。

  2. 添加自定义函数和钩子: 将以下代码片段添加到functions.php文件的末尾:

    '; // 可以添加自定义的HTML标签和类名以便后续样式控制
        the_author_meta( 'phone' ); // 假设作者的电话存储在'phone'元字段中
        echo '

    '; // 您也可以输出其他内容,例如: // echo '更多信息'; // echo do_shortcode('[your_custom_shortcode]'); // 如果需要输出短代码 } // 将自定义函数挂载到 'woocommerce_after_shop_loop_item' 动作钩子 // 'woocommerce_after_shop_loop_item' 钩子在每个产品在循环中显示后触发 // 10 是优先级,数字越小越先执行 // 0 是接受的参数数量 add_action( 'woocommerce_after_shop_loop_item', 'woocommerce_after_product_price_custom_content', 10, 0 ); ?>

代码解析

  • woocommerce_after_product_price_custom_content() 函数: 这是一个自定义的PHP函数,它包含了您希望在产品价格下方显示的所有逻辑和内容。

    • the_author_meta( 'phone' );:这是一个WordPress函数,用于获取并显示当前文章(或产品,因为WooCommerce产品本质上是自定义文章类型)作者的指定元数据。这里的'phone'是元数据键名,您需要确保您的用户(或产品作者)资料中存在名为phone的自定义字段,并且其中存储了电话号码。
    • echo '

      '; 和 echo '

      ';:这些是HTML标签,用于包裹输出的内容,方便您后续通过CSS进行样式设计。您可以根据需要修改或删除这些标签。
  • add_action() 函数: 这是WordPress的核心函数,用于将自定义函数与特定的动作钩子关联起来。

    • 'woocommerce_after_shop_loop_item':这是WooCommerce提供的一个动作钩子。它在每个产品项在产品循环(即商店页面、分类页面、标签页面等)中被完全渲染之后触发。这意味着您的自定义内容将出现在产品价格以及任何其他默认内容之后。
    • 'woocommerce_after_product_price_custom_content':这是您定义的自定义函数的名称。
    • 10:这是函数的优先级。数字越小,函数执行得越早。默认优先级是10。
    • 0:这是函数接受的参数数量。woocommerce_after_shop_loop_item 钩子不传递任何参数,因此这里设置为0。

注意事项与扩展

  1. 子主题的重要性: 再次强调,务必在子主题的functions.php中添加代码。如果直接修改父主题,主题更新将覆盖您的所有修改。
  2. 自定义内容: the_author_meta( 'phone' ); 只是一个示例。您可以替换为任何有效的PHP代码或HTML内容。例如:
    • 显示自定义字段:echo get_post_meta( get_the_ID(), '_my_custom_field', true );
    • 显示静态文本:echo '免费送货!';
    • 根据条件显示内容:
      if ( get_post_meta( get_the_ID(), '_is_featured_product', true ) ) {
          echo '? 热门商品';
      }
  3. 样式调整: 添加内容后,您可能需要通过CSS来调整其显示样式,例如字体大小、颜色、边距等。您可以使用在代码中添加的HTML类名(如product-author-phone)来定位和美化这些内容。将CSS代码添加到主题的style.css文件中(同样,子主题优先)。
  4. 钩子的选择: 理解不同WooCommerce钩子的作用至关重要。woocommerce_after_shop_loop_item 适用于产品列表页面的每个产品项之后。如果您需要在单品页面添加内容,则需要使用不同的钩子,例如woocommerce_single_product_summary或woocommerce_after_add_to_cart_button等。
  5. 性能考虑: 避免在自定义函数中执行过于复杂的数据库查询或耗时操作,这可能会影响网站性能。

总结

通过利用WooCommerce提供的动作钩子,我们可以非常灵活且安全地在不修改核心模板文件的情况下,向商店和归档页面添加自定义内容。本教程以在产品价格后添加作者电话为例,展示了woocommerce_after_shop_loop_item钩子的强大功能。掌握这种扩展方式,将大大提升您定制WooCommerce网站的能力。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2589

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1619

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1506

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1417

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1447

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.16

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 19.4万人学习

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

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