Sposób tworzenia instancji helperów (przynajmniej dla nowego modułu Backend (~ dev50)) odbywa się za pośrednictwem helperFactory:
/**
* Return helper object
*
* @param string $name
* @return \Magento\Core\Helper\AbstractHelper
*/
public function helper($name)
{
return $this->_helperFactory->get($name);
}
Co jest w zasadzie tylko wyspecjalizowanym typem fabryki modeli. Np .: Magento \ Core \ Block \ Context line 143 (dev50) jako część konstruktora:
\Magento\Core\Model\Factory\Helper $helperFactory
Fabryka pomocników zwróci żądany model na podstawie nazwy klasy i zapewni, że jest to instanceof
klasa abstrakcyjna pomocnika:
/**
* Get helper singleton
*
* @param string $className
* @param array $arguments
* @return \Magento\Core\Helper\AbstractHelper
* @throws \LogicException
*/
public function get($className, array $arguments = array())
{
$className = str_replace('_', '\\', $className);
/* Default helper class for a module */
if (strpos($className, '\Helper\\') === false) {
$className .= '\Helper\Data';
}
$helper = $this->_objectManager->get($className, $arguments);
if (false === ($helper instanceof \Magento\Core\Helper\AbstractHelper)) {
throw new \LogicException(
$className . ' doesn\'t extends Magento\App\Helper'
);
}
return $helper;
}
Gdybyś sam to zaimplementował , wygląda na to, że rdzeń Magento ładuje go na jeden z dwóch sposobów:
Rzuć własną fabrykę:
$objectManager = \Magento\Core\Model\ObjectManager::getInstance();
$helperFactory = $objectManager->get('\Magento\Core\Model\Factory\Helper');
$helper = $helperFactory->get('\PulseStorm\Commercebug\Helper\Data');
Lub po prostu złap go bezpośrednio:
$helper = \Magento\Core\Model\ObjectManager::getInstance()->get('Magento\Core\Helper\Data');