Avançando um pouco mais neste minicurso de desenvolvimento de módulos para Magento 2, nós veremos como trabalhar com Controller.
Controllers são rotas, por assim dizer, que implementaremos no nosso módulo.
Routes.xml
Como você já sabe, o diretório etc/ é o local onde armazenamos as configurações do nosso módulo. E nele poderemos definir as configurações para o admin e para o frontend do nosso módulo. Então, nele nós definiremos a rota do nosso módulo. Como precisamos de uma rota no frontend da loja, crie o seguinte arquivo etc/frontend/routes.xml, conforme imagem:
E adicione o script:
<?xml version="1.0"?> <!-- /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ --> <config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:App/etc/routes.xsd"> <router id="standard"> <route id="newsletter" frontName="newsletter"> <module name="AbraaoMarques_NewsletterModal"/> </route> </router> </config>
Como estamos trabalhando com rotas no nível frontend, usamos o standard no id da tag <router> <router id="standard">
Na tag <route> nós temos o nosso id e frontName <route id="newsletter" frontName="newsletter">
. O frontName é a rota base do nosso módulo. Todas as rotas do nosso módulo será iniciado pelo ele.
Controller
Crie o arquivo: Controller/Moda/Index.php, conforme abaixo:
Todos os controllers, rotas, do seu módulo devem ser criados a partir do diretório Controller.
Adicione o script:
<?php namespace AbraaoMarques\NewsletterModal\Controller\Modal; use Magento\Framework\App\Action\Action; use Magento\Framework\App\Action\Context; use Magento\Framework\App\ResponseInterface; class Index extends Action { public function __construct( Context $context ) { parent::__construct($context); } /** * Execute action based on request and return result * * Note: Request will be added as operation argument in future * * @return \Magento\Framework\Controller\ResultInterface|ResponseInterface * @throws \Magento\Framework\Exception\NotFoundException */ public function execute() { var_dump("meu primeiro controller"); } }
É obrigatório que você estenda a classe Magento\Framework\App\Action\Action
na sua classe Controller para que ele funcione corretamente.
public function execute() { var_dump("meu primeiro controller"); }
O método acima é o responsável pela execução do nosso controller.
Ok, mas como acesso a minha rota? O Magento 2 trabalha com a seguinte estrutura para as rotas: frontName/diretorio-no-controller/class-de-controller busca o método public function execute()
dessa estrutura. Em nosso caso: newsletter/modal/index
E aí, ficou alguma dúvida? Assista ao vídeo tutorial no início desse artigo para maiores explicações!
Ainda com dúvidas? Posta aí!!!
Aquele abraço.
Muito bom! Fácil aprendizagem! Meus parabéns! Hoje em dia não acha sites ou cursos que ensinam assim! Muito obrigado! Continue assim!!!
Meu amigo, obrigado pelo seu comentário! Pode ter certeza que muito mais ainda virá!
Sucesso aí!
Aquele abraço!
Tem como disponibilizar um link para baixar esse módulo? Para fins de erros, pois aqui no meu não está abrindo a url da rota. Obrigado!
O link para download foi disponibilizado no último artigo deste curso de desenvolvimento de módulo para Magento 2.
Segue o link: http://4mage.com.br/magento-2-curso-model/
Aquele abraço!