Ответы:
registration.php
является своего рода точкой входа вашего модуля. Это эквивалент app/etc/modules/[Namespace]_[Module].xml
из Magento 1.
Но теперь, является частью самого модуля.
это позволяет создавать модули в app/code
папке, а также в vendor
папке.
Независимо от того, где вы его добавите, этот файл будет подхвачен Magento, и ваш модуль будет принят во внимание.
config.php
только модуле появляются имена и их состояние (включено / выключено). Там нет пути к модулю. Как я уже сказал в ответе, registration.php
позволяет иметь модули снаружиapp/code
я заметил, что две вещи были изменены с версией Magento. 1.0.0-бета (октябрь) до Magento вер. 2.0.0-rc2
1. добавлен новый файл в корневую папку модуля с именем registration.php, например: -app \ code \ Sugarcode \ Test \ registration.php
<?php
/**
* Copyright © 2015 Magento. All rights reserved.
* See COPYING.txt for license details.
*/
\Magento\Framework\Component\ComponentRegistrar::register(
\Magento\Framework\Component\ComponentRegistrar::MODULE,
'Sugarcode_Test',
__DIR__
);
2. event.xml был изменен ранее. Мы упоминаем имя метода в теге наблюдателя в event.xml. Теперь метод был удален, но нужно упомянуть только тот экземпляр, который является
<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../../../../../../lib/internal/Magento/Framework/Event/etc/events.xsd">
<event name="sales_order_grid_collection_load_before">
<observer name="sales_order_grid_test" instance="Sugarcode\Test\Observer\Addtest" />
</event>
</config>
и в папке / ModuleName / Observer вам нужно создать файл с функцией
public function execute()
то есть
<?php
namespace Sugarcode\Test\Observer;
class Addtest
{
public function execute(\Magento\Framework\Event\Observer $observer)
{
$obj=$observer->getEvent()->getOrderGridCollection();
$obj->getSelect()->joinLeft(
['testt' => 'testtable'],
"(main_table.entity_id = testt.id)",
[
'testt.title as title'
]
);
//$this->printlogquery(true);
//return $obj;
}
}