[扩展推荐] Eventy: 在 Laravel 应用添加类似 WordPress 的钩子机制

file

Eventy 是 Tor Morten Jensen 为 Laravel 开发的一个类 WordPress 钩子机制的扩展包。

这个扩展包有着轻量级的 API,能够帮助你快速的构建一个和 WordPress 一致的钩子机制。WordPress 钩子机制是一种不需要修改模板就能定制 WordPress 主题的强大方式。例如,你的用户可以轻松的修改 <title></title> 标签(使用 wp_title)的内容,而不需要修改模板。

操作

操作即在你所希望的地方可以执行的既定代码。

如下就是创建操作的一些基础 API:

Eventy::action('my.hook', 'awesome');

添加操作监听者的最佳位置就是服务提供者中的 boot() 方法:

public function boot()
{
    Eventy::addAction('my.hook', function($what) {
        echo 'You are '. $what;
    }, 20, 1);
}

Eventy::addAction()方法接收参数依次为,操作名称,回调函数,优先级,预期的变量数量。优先级数字越小,执行越早。

过滤器

就像 WordPress 的过滤器一样,Eventy 库提供了一个过滤器来修改传递的值。每当过滤器被调用时,它将在运行各种回调后返回它的值:

$value = Eventy::filter('my.hook', 'awesome');

第一个参数 是过滤器名称,第二个参数是值。如果过滤器没有附加监听,那么它将会返回 awesome 的值。

签名方法和动作一样,包含预期参数的优先级与数量:

Eventy::addFilter('my.hook', function($what) {
    $what = 'not '. $what;
    return $what;
}, 20, 1); // returns `not awesome`

你甚至可以将动作与过滤器结合在一起使用:

Eventy::addAction('my.hook', function($what) {
    $what = Eventy::filter('my.hook', 'awesome');
    echo 'You are '. $what;
});

模板

使用项目中 readme 相同的示例,以下是这个包的模板语法:

{{-- for example, `echo "awesome"` --}}
@action('my.hook', 'awesome')

You are @filter('my.hook', 'awesome')

了解更多

你可以从项目的 GitHub 仓库 了解更多关于 Eventy 的信息,并使用 composer require tormjens/eventy 命令来安装它。

本文中的所有译文仅用于学习和交流目的,转载请务必注明文章译者、出处、和本文链接
我们的翻译工作遵照 CC 协议,如果我们的工作有侵犯到您的权益,请及时联系我们。

原文地址:https://laravel-news.com/eventy

译文地址:https://learnku.com/laravel/t/15206/exte...

本帖已被设为精华帖!
本文为协同翻译文章,如您发现瑕疵请点击「改进」按钮提交优化建议
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 3
Summer

如果你在编写一款开源的 CMS 应用,并且想支持 Wordpress 一样的钩子机制,以允许开发者在你的 CMS 上开发插件,可以瞧一瞧此扩展。

1年前 评论
Explorer

@Summer
The method siguature is the same as actions, including the priority and number of expected arguments:
这一段的 siguature 感觉是原文拼写错了,应该是 signature 才对

1年前 评论

@Summer 你好站长,请问有类似教程吗,想开发一套可扩展cms系统

5个月前 评论

请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!