Start with Magento, you might have dozens of questions about it. Besides the common keywords that are easy-to-meet like Magento 2 extensions, Magento 2 modules, Magento 2 apps, etc… you could have seen “Magento 2 plugins”.
Although it’s not new, there are some things that can make you confused. In this blog, we will clear all common questions about Magento 2 plugins. Let’s read and understand that.
1. WHAT ARE MAGENTO 2 PLUGINS?
Magento 2 plugin, or interceptors, is a class that alters the behavior of public class functions by intercepting function calls and executing code before, after, or around them. For every class or interface, this allows you to replace or extend the functionality of original, public methods.
The plugin is pretty similar to an extension or module. Both are added to the default Magento and often developed by the third party.
This interceptor method helps to avoid conflicts among extensions that can happen when changing the behavior of the same class or function.
By using Magento 2 plugins, you can change the behavior of a class without having to update the class itself.
2. HOW MANY TYPES OF MAGENTO 2 PLUGINS?
There are 3 types of Magento 2 plugins: Before Plugin, After Plugin, Around Plugin.
- Before method is run first before the call to an observed method. Note that these methods must be named the same as the observed method with the prefix ‘before’.
By returning a modified argument, you can utilize before methods to modify the arguments of an observed method. The method should return an array of parameters if there are any. It should return a null result if the method does not change the parameter for the observed method.
- After method is run after the observed method is completed. These methods must be named after the observed procedure and have the prefix ‘after’.
By altering the initial result and returning it at the end of the method, you can change the outcome of an observed method.
Note: If the observed method declares a parameter to be optional, the after method should do the same.
- Around method is run before and after its observed method. The name of the around method must be the same as the observed method, with the prefix ‘around’.
You can override an observed method by using these methods.
Note: When not essential, avoid utilizing around method plugins because they raise stack traces and have a negative impact on performance.
3. THE ELEMENTS OF PLUGIN
To start writing a plugin, you need to know how many elements there are to create a plugin and how to use them. Read the explanation below to more fully understand:
- Type name: a class or interface that the plugin observes.
- Plugin name: An arbitrary name for a plugin that identifies it. Also used to integrate the plugin’s configurations.
- Plugin type: The name of a plugin’s virtual type or class. When specifying this element, use the following naming convention:
\Vendor\Module\Plugin\<ClassName>
Extra elements that you can use:
- sortOrder: Sort order will be used to run plugins that call the same method.
- Disable: Set this element to true to make a plugin deactivated. False is the default setting.
4. SEVERAL MAGENTO 2 PLUGIN EXAMPLES
With 3 types of interceptors in Magento 2, we give 3 examples for each type below.
Before plugin example:
/** * Modify name before get hello message * * @param Index $subject * @param string $name * @return array */ public function beforeGetHelloMessage( Index $subject, string $name ): array { $name = 'ltc'; return [$name]; }
Around plugin example:
/** * Check and modify name and msg after call proceed * * @param Index $subject * @param callable $sproceed * @param string $name * @return mixed */ public function aroundGetHelloMessage( Index $subject, callable $proceed, string $name ){ if ($name === ‘ltc') { $name = ‘lucthanca’; } $result = $proceed($name); sresult['msg'] .= " Welcome to BssCommerce!"; return $result; }
After plugin example:
/** * Add more text in message * * @param Index $subject * @param array $result * @param string $name * @return array */ public function afterGetHelloMessage( Index $subject, array $result, string $name ): array { $result['msg'] .= " How are you today?”"; return $result; }
5. PLUGINS VS OBSERVERS VS PREFERENCES IN MAGENTO 2 – DIFFERENCES
A. WHAT IS THE DIFFERENCE BETWEEN OBSERVERS AND PLUGINS IN MAGENTO 2?
Firstly, you need to know what Observers in Magento are. Observers are a sort of Magento class that can change business logic, influence general behavior, and improve performance. Observers are activated whenever the event manager dispatches the event they’ve been configured to watch.
Besides the common point that both plugins and observers can be utilized to run our custom script, after certain Magento 2 – events or public methods are executed. We can compile all the main differences below:
- Observers can edit both private and protected methods, but plugins can only modify public methods.
- Although there is a sort order for plugins, there is none for observers.
- Only events that have already been delivered in Magento can be added to the observer list. In this case, plugins are more flexible.
- Plugins are required when we need to change Magento core functionality (for example, adding more data to the order collection object). We can’t use Observer in this instance.
- Because Magento creates at least three objects in response to a trigger event, observers are slower than plugins.
B. MAGENTO 2 DIFFERENCE BETWEEN PLUGIN AND PREFERENCE
The Object Manager uses preference to specify the default implementation. It can be used to rewrite a class from another module to point at the implementation, making the class global. You can use the preference from di.xml to override a public or protected method from a core class. The default implementation is defined by the preference node.
The basic and simple way to distinguish between Magento 2 plugins and preferences is: Preference is used for overriding class, Plugin is used for adding functionality before, after, and around methods.
6. WHAT ARE THE LIMITATIONS OF PLUGIN MAGENTO 2?
Although Plugin in Magento 2 is flexible and used in many cases, it also has limitations that you should notice. Magento 2 plugin will not be used on the following:
- Final methods
- Final classes
- Non-public methods
- Class methods (such as static methods)
- __construct and __destruct
- Virtual types
- Objects that are instantiated before Magento\Framework\Interception is bootstrapped
- Objects that implement Magento\Framework\ObjectManager\NoninterceptableInterface
7. 3+ SUGGESTIONS OF MAGENTO 2 PLUGINS FOR YOUR WEBSITE
A. MAGENTO 2 SEO EXTENSION
One of the most common ways to measure website quality is by tracking the site ranking on Google. So, hundreds of thousands of businesses have focused on optimizing search engines. This way benefits both businesses’ reputation and revenue.
However, optimizing your website the traditional way without a support tool is not easy. You should “put in your pocket” Magento 2 SEO extension to save both time and effort.
This is a tool kit that is integrated with 10+ functions that make your website friendly with users and step closer to Top 1 in SERPs.
This tool kit maximizes your SEO effectively through the factors such as Rich Snippets, Advanced Breadcrumbs, HTML Sitemap, XML Sitemap, Robot Meta Tag, Canonical Tag, HREFLANG Tag, 301 Redirects, Meta Tag Template, Image ALT Tags, SEO External Links, SEO Toolbar and SEO Report and Audit.