官术网_书友最值得收藏!

Using services in Drupal 8

Before we go and use our service in the Controller we created, let's take a breather and run through the ways you can make use of services once they are registered.

There are essentially two ways—statically and injected. The first is done by a static call to the Service Container, whereas the second uses dependency injection to pass the object through the constructor (or in some rare cases, a setter method). However, let's check out how, why, and what is the real difference.

Statically, you would use the global Drupal class to instantiate a service:

$service = \Drupal::service('hello_world.salutation');  

This is how we use services in the .module files and classes which are not exposed to the Service Container and into which we cannot inject. Instances of the latter are rare though, most of the time we use the static calls only from within static contexts.

A few popular services also have shorthand methods on the \Drupal class: for example, \Drupal::entityTypeManager(). I recommend that you inspect the \Drupal class and take a look at the ones with shorthand methods available.

It is not best practice and, for me, it is personally unacceptable to use the static method of service instantiation inside a Controller, service, plugin or any other class where dependency injection is an option. The reason is that it defeats much of the purpose of using a service, as it couples the two, making it a nightmare to test. Inside hook implementations and other Drupal-specific procedural code, on the other hand, we have no choice, and it is normal to do so.

Just because a code is inside a .module file, it doesn't mean that it should be there. In general, these modules should only contain things such as hook implementations or any other implementations that require a certain naming convention to be respected. They should also be lean and have their work delegated to services.

The proper way to use services is to inject them where needed. Admittedly, this approach is a bit more time-consuming but, as you progress, it will become second nature. Also, since there are a few different ways to inject dependencies (based on the receiver), we will not cover them here. Instead, we will see how they work throughout this book, at the right time. We will take a look at a very important example right now in the next section.

主站蜘蛛池模板: 南郑县| 尚义县| 常州市| 五大连池市| 阿克苏市| 宁安市| 土默特左旗| 岳阳市| 桂林市| 札达县| 林周县| 大埔区| 安仁县| 虞城县| 阳信县| 海阳市| 连云港市| 阜平县| 廊坊市| 石柱| 盐亭县| 邹平县| 澄江县| 夏邑县| 浮山县| 乃东县| 平江县| 诏安县| 崇文区| 万安县| 商南县| 太湖县| 新津县| 特克斯县| 武夷山市| 福泉市| 博乐市| 扬中市| 新密市| 大邑县| 珠海市|