phalette/pidic
最新稳定版本:0.1
Composer 安装命令:
composer require phalette/pidic
包简介
Nette Dependency Injection/Container for Phalcon
README 文档
README
Website 🚀 contributte.org | Contact 👨🏻💻 f3l1x.io | Twitter 🐦 @contributte
Disclaimer
| ⚠️ | This project is no longer being maintained. |
|---|
| Composer | phalette/pidic |
|---|---|
| Version | |
| PHP | |
| License |
About
PiDiC is an adapter over Nette\Di\Container.
Install
$ composer require phalette/pidic:dev-master
Dependencies
- PHP >= 5.5.0
- Nette\Di >= 2.3.0
- Phalcon >= 2.0.0
Configuration
use Nette\DI\Compiler; use Phalette\Pidic\Configurator; use Phalette\Pidic\Environment; use Phalette\Pidic\Extensions\PhalconDefaultsExtension; use Phalette\Pidic\Extensions\PhalconExtension; use Phalette\Pidic\PiDi; $configurator = new Configurator(); $configurator->setMode(Environment::DEVELOPMENT); $configurator->setCacheDir(__DIR__ . '/cache'); $configurator->onCompile[] = function (Compiler $compiler) { $compiler->addExtension('phalcon', new PhalconExtension()); $compiler->addExtension('phalconDefaults', new PhalconDefaultsExtension()); }; $container = $configurator->createContainer(); $pidi = $container->getService('pidi');
Learn by working example
This is based on official tutorial.
use Nette\DI\Compiler; use Phalette\Pidic\Configurator; use Phalette\Pidic\Environment; use Phalette\Pidic\Extensions\PhalconDefaultsExtension; use Phalette\Pidic\Extensions\PhalconExtension; use Phalette\Pidic\PiDi; use Phalcon\Loader; use Phalcon\Mvc\View; use Phalcon\Mvc\Application; use Phalcon\DI\FactoryDefault; use Phalcon\Mvc\Url as UrlProvider; use Phalcon\Db\Adapter\Pdo\Mysql as DbAdapter; try { // Register an autoloader $loader = new Loader(); $loader->registerDirs(array( '../app/controllers/', '../app/models/' ))->register(); // Create a DI $configurator = new Configurator(); $configurator->setMode(Environment::DEVELOPMENT); $configurator->setCacheDir(__DIR__ . '/cache'); $configurator->onCompile[] = function (Compiler $compiler) { $compiler->addExtension('phalcon', new PhalconExtension()); $compiler->addExtension('phalconDefaults', new PhalconDefaultsExtension()); }; $container = $configurator->createContainer(); $di = $container->getService('pidi'); // Setup the view component $di->set('view', function () { $view = new View(); $view->setViewsDir('../app/views/'); return $view; }); // Setup a base URI so that all generated URIs include the "tutorial" folder $di->set('url', function () { $url = new UrlProvider(); $url->setBaseUri('/tutorial/'); return $url; }); // Handle the request $application = new Application($di); echo $application->handle()->getContent(); } catch (\Exception $e) { echo "PhalconException: ", $e->getMessage(); }
PhalconExtension
It sets self-instance over static Phalcon\Di::setDefault(). Every object extending from Phalcon\Di\InjectionAwareInterface can access PiDiC from $this->getDI().
PhalconDefaultsExtension
This extension replace Phalcon\DI\FactoryDefault. It register to the container 22 base services (more in docs).
Phalcon\Di
PiDiC implements Phalcon\DiInterface and then you can change DI without any changes.
How to work with DI in Phalcon, you can read here.
Nette\DI
Please read articles at Nette documentation:
But the main article is:
Development
This package was maintained by these authors.
Consider to support contributte development team. Also thank you for using this package.
统计信息
- 总下载量: 56.93k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 4
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: BSD-3-Clause
- 更新时间: 2015-09-27