Magento 2

Adicionando uma classe ao corpo da página – Magento 2

Se você precisar adicionar programaticamente uma classe à tag body de suas lojas , precisará configurar um observador de eventos para o evento layout_load_before.

Dentro do seu observador, você desejará adicionar o Magento \ \ View \ Page \ Config como dependência.

Em seguida, use o método addBodyClass para adicionar sua classe.

Veja abaixo um exemplo mais detalhado.

No meu exemplo, estou adicionando a turma de login do cliente ao corpo quando um cliente está conectado.

Evento: layout_load_before

Arquivo: etc//events.xml

<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Event/etc/events.xsd">
    <event name="layout_load_before">
        <observer name="vendor_module_add_body_class" instance="Vendor\Module\Observer\AddClassToBody" />
    </event>
</config>

Arquivo: Observer/AddClassToBody.

<?php
namespace Vendor\Module\Observer;

use Magento\Customer\Model\Session as CustomerSession;
use Magento\Framework\View\Page\Config as PageConfig;
use Magento\Framework\Event\ObserverInterface;

class AddClassToBody implements ObserverInterface
{
    /** @var PageConfig */    protected $pageConfig;
   /** @var CustomerSession */    protected $customerSession;

    public function __construct(PageConfig $pageConfig, CustomerSession $customerSession)
    {
        $this->pageConfig = $pageConfig;
        $this->customerSession = $customerSession;
    }

    public function execute(\Magento\Framework\Event\Observer $observer)
    {
        if (!$this->customerSession->isLoggedIn()) {
            return;
        }

        $this->pageConfig->addBodyClass('customer-logged-in');
    }
}

Dica: Alguns nomes de classe no Magento não ajudam muito quando você usa use statement. Usarei frequentemente um alias para se referir às classe, veja abaixo:

Use statement ou Caminho da classe

Não há razão técnica para preferir um sobre o outro, exceto se houver conflitos de nome (como classes diferentes de “Contexto”). Mas isso pode ser resolvido com aliases e é o que eu costumo fazer:

use Magento \ Framework \ Model \ Context como ModelContext;
Eu suponho que no núcleo muitos métodos, especialmente os construtores, foram gerados por ferramentas como a ferramenta de conversão em primeiro lugar e depois não foram alterados para usar as importações “use”.

Então eu sugiro que em seu próprio código você sempre importe classes com “use” para tornar o código real menos detalhado e mais legível.

Exemplo:

Usar diretamente a classe Magento \ Customer \ Model \ Session no meu construtor é longo. Mas também, ao usar use statement, simplesmente colocar Sessão não significa muito.

Em vez disso, farei isso: use Magento \ Customer \ Model \ Session as CustomerSession ;. Imediatamente, fica claro o que a classe está fazendo.

Outro exemplo: use Magento \ Framework \ View \ Page \ Config as PageConfig ;. O Config não significa nada útil, no entanto, o PageConfig é muito mais significativo, pois fornece um pouco mais de contexto para o que a classe faz.

Tags: magento 2

Post Recentes

Por que devo sempre manter o Magento 2 atualizado?

Segurança: Atualizações frequentes geralmente incluem patches de segurança para corrigir vulnerabilidades identificadas. Ao manter o Magento atualizado, você reduz significativamente…

4 semanas atrás

Adicionar uma mensagem de Alerta ou Aviso do Admin do Magento 2

Como adicionar uma mensagem de Alerta ou Aviso do Admin do Magento 2 Injete o Magento\Framework\Message\ManagerInterface no construtor da sua…

1 mês atrás

Exibir mensagens erro/sucesso da Classe: Magento\Framework\Message\ManagerInterface

Para exibir as mensagens adicionadas na classe Magento\Framework\Message\ManagerInterface em um arquivo .phtml, você pode usar o seguinte código: <?php $objectManager…

1 mês atrás

Exportar as categorias do Magento 2 em um XML

Para criar um script no Magento 2 que exporte as categorias para um arquivo XML com o nome da categoria,…

2 meses atrás

Colocar um video como Background utilizando HTML + CSS

Para definir um vídeo MP4 como plano de fundo em um <div> usando HTML e CSS, você pode seguir estas…

4 meses atrás

Desativar o “lastname” no Magento 2

Como desativar o "lastname" no Magento 2 e Adobe Commerce Desativando a obrigatoriedade do campo Execute a SQL abaixo diretamente…

4 meses atrás