n5s/wp-hook-kit 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

n5s/wp-hook-kit

最新稳定版本:1.0.0

Composer 安装命令:

composer require n5s/wp-hook-kit

包简介

A lightweight WordPress hook helper library. Register hooks before WordPress loads, run callbacks only once, and more.

README 文档

README

Tests Coverage PHPStan

A lightweight WordPress hook helper library. Register hooks before WordPress loads, run callbacks only once, and more.

Installation

composer require n5s/wp-hook-kit

Usage

use n5s\WpHookKit\Hook;

// Basic usage - works even before WordPress is loaded
Hook::addFilter('the_content', fn($content) => $content . '<p>Footer</p>');
Hook::addAction('init', fn() => register_post_type('book', []));

// Run a callback only once (removes itself after first execution)
Hook::addFilterOnce('the_title', fn($title) => $title . ' - Launch Sale!');
Hook::addActionOnce('wp_footer', fn() => echo '<!-- First visit -->');

// Side effects - run code without modifying the filtered value
Hook::addFilterSideEffect('the_content', function($content) {
    error_log('Content rendered: ' . strlen($content) . ' chars');
});

// Combine both: side effect that runs once
Hook::addFilterSideEffectOnce('template_include', function($template) {
    log_first_template_load($template);
});

// Register same callback on multiple hooks
Hook::addFilters(['the_title', 'the_content'], 'esc_html');
Hook::addActions(['wp_head', 'wp_footer'], fn() => do_something());

All methods accept the standard WordPress parameters: $hook, $callback, $priority = 10, $accepted_args = 1.

Why?

Early registration: Register hooks before WordPress fully loads. The library writes directly to $wp_filter when add_filter() isn't available yet. Unlocks the power of bringing features without the "plugin" way hassle when it's not needed (library, composer autoloaded files, etc.).

Once variants: Because sometimes, you might not want your callback to be executed every time a hook is called.

Side effects: Runs your callback and returns the original value unchanged. Useful to trigger actions when an actual action isn't available, observe filter behavior, etc.

Acknowledgments

This package is gathering multiple package implementations inside a single library, credits goes to:

License

MIT

统计信息

  • 总下载量: 17
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-12-23