Laravel 5.0 – Event Annotations
原文 ? http://mattstauffer.co/blog/laravel-5.0-event-annotations Posted on October 10, 2014 | By Matt Stauffer (This is part of a series of posts on New Features in Laravel 5.0. Check back soon for more.) Laravel 5.0 Form Requests Laravel
Posted on October 10, 2014 | By Matt Stauffer
(This is part of a series of posts on New Features in Laravel 5.0. Check back soon for more.)
- Laravel 5.0 – Form Requests
- Laravel 5.0 – ValidatesWhenResolved
- Laravel 5.0 – Directory structure and namespace
- Laravel 5.0 – Route Caching
- Laravel 5.0 – Cloud File Drivers
- Laravel 5.0 – Method Injection
- Laravel 5.0 – Route Annotations
- Laravel 5.0 – Event Annotations
- Laravel 5.0 – Middleware (and how it’s replacing Filters) (coming soon)
In 5.0, Laravel is moving more and more of the top-level, bootstrapped, procedural bindings and definitions into a more Object-Oriented, separation-of-concerns-minded structure. Filters are now objects, controllers are now namespaced, the PSR-4-loaded application logic is now separate from the framework configuration, and more.
We saw in thelast postthat annotations are one of the ways Laravel 5.0 is making this change. Where routes used to be bound one after another in routes.php, they now can be bound with annotations on the controller class and method definitions.
Setting the stage#
Another part of Laravel that has traditionally been bound with a list of calls one after another is event listeners, and this is the next target of the annotation syntax.
Consider the following code:
Event::listen('user.signup', function($user) { $intercom = App::make('intercom'); $intercom->addUser($user); });
Somewhere in your code—in a service provider, maybe, or maybe just in a global file somewhere—you’ve bound a listener (the closure above) to the “user.signup” event.
Of course, you’re probably noticing that all that closure does is call a single method—so we could refactor it to this:
Event::listen('user.signup', 'Intercom@addUser');
Introducing Event Annotations#
Now, let’s drop the need for the binding entirely, and replace it with an annotation.
<?php namespace App; class Intercom { /** * @Hears("user.signup") */ public function addUser(User $user) { return $this->api_wrapper->sendSomeAddThing( $user->email, $user->name ); } }
As you can see, the @Hears
annotation can take a string event name, but it can also take an array of event names (in annotations, arrays are surrounded by {} instead of []). Now, run artisan event:scan
and you’ll get a file namedstorage/framework/events.scanned.php
, with the following contents:
<?php $events->listen(array ( 0 => 'user.signup', ), 'App\Intercom@addUser');
Instantly bound.
Conclusion#
There are positives and negatives to working with your event system this way.
The primary negative I see is that you could look at this annotation as being framework-specific; if that’s the case, you’re now placing framework-specific code directly into your domain. If you imagine this Intercom class being something you’re passing around between several sites, its binding may be specific to this site–in which case you’d be better off using the classic style of binding. However, that’s not always the case.
Note that this negative is different from the same situation in Route Annotations, which are only being applied to Controllers–which are not domain objects.
The positives I can see at first glance are that first, you’re defining the method’s act of listening on the method itself, rather than elsewhere; and second, that you’re defining the listener in a way that it can be programmatically accessed (meaning you could, at any point, replace artisan event:scan
with a program of your own devising that outputs something other than a Laravel events.scanned
file). There are likely smarter folks than me that’ll weigh in on this.
原文地址:Laravel 5.0 – Event Annotations, 感谢原作者分享。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

Laravel邮件发送失败时的退信代码获取方法在使用Laravel开发应用时,经常会遇到需要发送验证码的情况。而在实�...

Laravel计划任务运行无响应排查在使用Laravel的计划任务调度时,不少开发者会遇到这样的问题:schedule:run...

在dcatadmin(laravel-admin)中如何实现自定义点击添加数据的表格功能在使用dcat...

Laravel框架中Redis连接的共享与select方法的影响在使用Laravel框架和Redis时,开发者可能会遇到一个问题:通过配置...

在Laravel多租户扩展包stancl/tenancy中自定义租户数据库连接使用Laravel多租户扩展包stancl/tenancy构建多租户应用时,...

LaravelEloquent模型检索:轻松获取数据库数据EloquentORM提供了简洁易懂的方式来操作数据库。本文将详细介绍各种Eloquent模型检索技巧,助您高效地从数据库中获取数据。1.获取所有记录使用all()方法可以获取数据库表中的所有记录:useApp\Models\Post;$posts=Post::all();这将返回一个集合(Collection)。您可以使用foreach循环或其他集合方法访问数据:foreach($postsas$post){echo$post->

Django和Laravel都是全栈框架,Django适合Python开发者和复杂业务逻辑,Laravel适合PHP开发者和优雅语法。1.Django基于Python,遵循“电池齐全”哲学,适合快速开发和高并发。2.Laravel基于PHP,强调开发者体验,适合小型到中型项目。
