0

0

WordPress多站点网站数量动态统计教程

碧海醫心

碧海醫心

发布时间:2025-09-02 20:22:17

|

423人浏览过

|

来源于php中文网

原创

WordPress多站点网站数量动态统计教程

本教程旨在指导WordPress多站点管理员如何在主站首页实现一个动态的网站数量计数器。我们将利用WordPress内置的get_sites函数及其count参数来获取网站总数,并通过wp_head动作钩子确保计数器在每次页面加载时实时更新,从而准确反映多站点网络中网站的增减情况。

wordpress多站点环境中,管理和监控各个子站点的状态是常见的需求。其中一个基本而实用的功能,便是在主站点上显示当前多站点网络中活跃子站点的总数。这个计数器不仅能直观地展示网络的规模,还能在子站点创建或关闭时实时更新,提供准确的数据。本文将详细介绍如何利用wordpress核心功能实现这一动态计数器。

核心功能:获取多站点网络中的网站数量

WordPress提供了一个强大的函数get_sites(),用于查询多站点网络中的站点信息。这个函数非常灵活,可以根据多种参数进行过滤和排序。对于我们当前的需求——仅仅获取站点的总数——get_sites()函数提供了一个专门的参数count。

当count参数被设置为true时,get_sites()函数将不再返回一个WP_Site对象数组,而是直接返回一个整数,表示符合查询条件的站点总数。这大大简化了获取站点数量的逻辑,避免了不必要的循环遍历。

示例:

$args = array(
    'count' => true // 设置为true,直接返回站点数量
);
$number_of_sites = get_sites( $args );
// $number_of_sites 现在包含多站点网络中的站点总数

实现实时更新机制

为了确保主站首页的计数器能够随着子站点的创建或删除而实时更新,我们需要将其与WordPress的某个事件挂钩。WordPress的动作钩子(Action Hooks)是实现这一目标的关键。

使用 wp_head 动作钩子

wp_head是一个在每个页面加载时都会触发的动作钩子,它位于HTML文档的zuojiankuohaophpcnhead>标签内部。这意味着,每次用户访问主站首页时,与wp_head关联的代码都会执行一次,从而重新计算并显示最新的站点数量。

虽然wp_head钩子通常用于输出<head>标签内的内容,但我们也可以利用它来执行计算逻辑。在本教程的简化示例中,我们将直接在wp_head中输出计数。

高级选项:AJAX

闪念贝壳
闪念贝壳

闪念贝壳是一款AI 驱动的智能语音笔记,随时随地用语音记录你的每一个想法。

下载

对于需要更高性能或无页面刷新更新的场景,可以考虑使用AJAX(Asynchronous JavaScript and XML)。通过AJAX,可以在不重新加载整个页面的情况下,向服务器发送请求获取最新的站点数量,并动态更新页面上的计数器。这通常涉及WordPress的AJAX API,需要编写前端JavaScript和后端PHP处理函数。虽然AJAX提供了更流畅的用户体验,但其实现复杂度也相对较高。对于初学者和基本需求,wp_head方法足够有效。

实战:在主题中添加动态计数器

现在,我们将结合get_sites()函数和wp_head动作钩子,在您的WordPress主题中实现这个动态计数器。

步骤:

  1. 打开主题的 functions.php 文件: 导航到您的WordPress安装目录,找到 wp-content/themes/您的活动主题名称/functions.php 文件。
  2. 添加以下代码: 将以下代码块添加到 functions.php 文件的末尾。
/**
 * WordPress多站点网站数量计数器
 * 在wp_head钩子中执行,获取并输出当前多站点网络中的网站总数。
 */
add_action('wp_head', 'your_multisite_counter_display', 99);

function your_multisite_counter_display() {
    // 定义查询参数,指定只获取计数
    $args = array(
        'count' => true
    );

    // 调用get_sites函数获取网站总数
    $number_of_sites = get_sites( $args );

    // 输出网站数量。在实际应用中,您可能需要将其包装在HTML元素中,
    // 并通过JavaScript将其放置到页面指定位置。
    // 这里为演示目的,将计数作为HTML注释输出,不会直接显示在页面上。
    echo '<!-- 当前多站点网络中的网站总数: ' . $number_of_sites . ' -->';

    // 如果您希望直接在页面上可见,可以取消注释以下行,并根据您的主题布局调整。
    // 但请注意,wp_head钩子输出的内容通常位于HTML文档的<head>或<body>的顶部。
    // echo '<p>当前网站数量:<strong>' . $number_of_sites . '</strong></p>';
}

代码解析:

  • add_action('wp_head', 'your_multisite_counter_display', 99);
    • add_action 是WordPress用于注册动作钩子的函数。
    • 'wp_head' 指定了我们希望在<head>标签内执行代码。
    • 'your_multisite_counter_display' 是我们将要定义的函数的名称。
    • 99 是优先级参数。默认优先级是10。较高的数字意味着该函数会更晚执行。在此处设置为99是为了确保它在大多数其他wp_head相关的脚本之后执行,但通常默认值也无妨。
  • function your_multisite_counter_display() { ... }
    • 这是实际执行计数逻辑的函数。
    • $args = array('count' => true); 定义了get_sites的参数,明确要求返回计数。
    • $number_of_sites = get_sites( $args ); 执行查询并获取网站总数。
    • echo '<!-- 当前多站点网络中的网站总数: ' . $number_of_sites . ' -->';
      • 这里将网站数量作为HTML注释输出。这种方式不会直接显示在页面上,但可以在页面源代码中查看。
      • 如果您希望直接在页面上可见,通常更推荐通过短代码(Shortcode)或在主题模板文件中直接调用函数来插入内容,以更好地控制显示位置。

扩展与注意事项

  • 更灵活的显示位置: 如果您希望在页面的特定位置(例如页脚、侧边栏或文章内容中)显示计数器,直接在wp_head中echo可能不合适。更好的做法是创建一个短代码(Shortcode),或者将计数逻辑封装在一个函数中,然后在主题模板文件中调用该函数。
    • 短代码示例:
      function get_multisite_site_count_shortcode() {
          // 确保在多站点环境下运行
          if ( ! is_multisite() ) {
              return '';
          }
          $args = array( 'count' => true );
          $number_of_sites = get_sites( $args );
          return '当前网站数量:<strong>' . $number_of_sites . '</strong>';
      }
      add_shortcode('multisite_count', 'get_multisite_site_count_shortcode');
      // 然后在文章或页面编辑器的内容中使用 [multisite_count] 即可显示计数。
      // 或者在主题模板文件中使用 echo do_shortcode('[multisite_count]');
  • 过滤特定类型的站点: get_sites()函数接受更多参数,允许您过滤特定状态的站点。例如,您可能只希望统计公开的、未归档的站点:
    $args = array(
        'count'    => true,
        'public'   => 1, // 只统计公开站点
        'archived' => 0  // 不统计已归档站点
    );
    $number_of_sites = get_sites( $args );

    更多参数请参考WordPress官方文档中WP_Site_Query的构造函数参数:https://www.php.cn/link/1fd6b8f9b13318adc358fca5d1ea1b5b

  • 性能考量: 尽管get_sites(['count' => true])是一个相对高效的操作,因为它避免了加载完整的站点对象。但在极端高流量的网站上,每次页面加载都执行数据库查询仍然可能带来轻微的性能开销。如果实时性要求不是非常严格,可以考虑将计数结果缓存一段时间(例如,使用set_transient()函数),每隔几分钟或几小时更新一次。
  • 代码位置: 建议将此类功能代码放入自定义插件而不是主题的functions.php中。这样即使更换主题,功能也能保持不变。

总结

通过利用WordPress多站点环境下的get_sites()函数和wp_head动作钩子,我们可以轻松地在主站点上实现一个动态、实时的网站数量计数器。这不仅能提供直观的网络规模展示,也为多站点

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

166

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

170

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

124

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

260

2024.09.24

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1949

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2119

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1171

2024.11.28

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共137课时 | 13.5万人学习

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号