Estes são exemplos de estruturas de arquivos MVC que você pode empregar usando Phalcon> = 3.0.x
Para uma documentação adicional, consulte os documentos Phalcon.
中文简体
Esta é uma estrutura MVC muito simples, ele contém um modelo, dois controladores e uma visualização. Este exemplo não implementa namespaces. Os serviços são definidos em public/index.php sem usar DiFactoryDefault :
simple
├── apps
│ ├── controllers
│ │ ├── IndexController.php
│ │ └── ProductsController.php
│ ├── models
│ │ └── Products.php
│ └── views
│ └── products
│ └── index.phtml
└── public
└── index.php
Esta é uma estrutura MVC muito simples, ele contém um modelo, dois controladores e uma visualização. Este exemplo não implementa namespaces. Os serviços são definidos em public/index.php sem usar DiFactoryDefault . Este exemplo usa Volt como Modelo Engine:
simple-volt/
├── app
│ ├── config
│ │ ├── config.php
│ │ ├── loader.php
│ │ └── services.php
│ ├── controllers
│ │ ├── ControllerBase.php
│ │ └── IndexController.php
│ └── views
│ ├── index
│ │ ├── index.volt
│ │ └── test.volt
│ ├── index.volt
│ └── layouts
│ └── template.volt
├── index.html
└── public
└── index.php
Outra estrutura MVC muito simples, contém um modelo, três controladores e uma visão. As rotas são definidas em app/config/routes.php . Algumas rotas apontam para os controladores em um subdiretório de controllers/ :
simple-subcontrollers/
├── app
│ ├── config
│ │ ├── config.php
│ │ ├── loader.php
│ │ ├── routes.php
│ │ └── services.php
│ ├── controllers
│ │ ├── ControllerBase.php
│ │ ├── UsersController.php
│ │ └── admin
│ │ ├── ControllerBase.php
│ │ └── UsersController.php
│ └── views
│ ├── admin
│ │ └── users
│ │ └── index.volt
│ ├── index
│ │ └── index.volt
│ ├── index.volt
│ └── users
│ └── index.volt
├── index.html
└── public
└── index.php
Estrutura MVC simples sem empregar PhalconMvcApplication . Este aplicativo não usa namespaces. Este é um exemplo de como você pode substituir PhalconMvcApplication implementando uma funcionalidade semelhante. Ele também define serviços sem usar DiFactoryDefault em public/index.php :
simple-without-application/
├── apps
│ ├── controllers
│ │ ├── IndexController.php
│ │ └── ProductsController.php
│ ├── models
│ │ └── Products.php
│ └── views
│ └── products
│ └── index.phtml
└── public
└── index.php
Esta é uma estrutura MVC de módulo único sem espaços para nome. Você pode encontrar os diretórios do módulo nos apps/ diretório. Este exemplo não usa namespaces. Todos os serviços são inicializados em public/index.php . Além disso, neste arquivo, você também pode encontrar uma classe de aplicativo que inicialize serviços e automaticamente agrupando essas tarefas por métodos.
single
├── apps
│ ├── controllers
│ │ ├── IndexController.php
│ │ └── ProductsController.php
│ ├── models
│ │ └── Products.php
│ └── views
│ ├── index.phtml
│ └── products
│ ├── index.phtml
│ └── test.phtml
└── public
└── index.php
Esta é uma estrutura MVC de módulo único usando namespaces. Você pode encontrar os diretórios do módulo nos apps/ diretório. Este exemplo usa namespaces. Todos os serviços são inicializados em public/index.php . Além disso, neste arquivo, você também pode encontrar uma classe de aplicativo que inicialize serviços e automaticamente agrupando essas tarefas por métodos.
single-namespaces/
├── apps
│ ├── controllers
│ │ ├── IndexController.php
│ │ └── ProductsController.php
│ ├── models
│ │ └── Products.php
│ └── views
│ └── products
│ └── index.phtml
└── public
└── index.php
Uma estrutura MVC de módulo único, como é gerado pelas ferramentas de desenvolvedor Phalcon. Em vez de inicializar todos os serviços individualmente, ele usa DiFactoryDefault :
single-factory-default/
├── app
│ ├── config
│ │ └── config.php
│ ├── controllers
│ │ ├── ControllerBase.php
│ │ ├── IndexController.php
│ │ └── TestController.php
│ └── views
│ ├── index
│ │ └── index.phtml
│ └── index.phtml
├── index.html
└── public
└── index.php
Esta é uma estrutura MVC de módulo único. Todos os arquivos e diretórios são camelizados (incluindo visualizações):
single-camelized-dirs/
├── App
│ ├── Config
│ │ ├── Loader.php
│ │ └── Services.php
│ ├── Controllers
│ │ ├── IndexController.php
│ │ └── ProductsController.php
│ ├── Models
│ │ └── Products.php
│ └── Views
│ ├── Index
│ │ └── Index.phtml
│ └── Products
│ └── Index.phtml
└── public
└── index.php
Esta é uma estrutura MVC de módulo único que mostra uma maneira não padrão de registrar serviços:
single-service-provider/
├── app
│ ├── Bootstrap.php
│ ├── Http
│ │ ├── Controllers
│ │ │ ├── Controller.php
│ │ │ └── IndexController.php
│ │ └── routes.php
│ ├── Models
│ └── Providers
│ ├── AbstractServiceProvider.php
│ ├── ConfigServiceProvider.php
│ ├── DatabaseServiceProvider.php
│ ├── EscaperServiceProvider.php
│ ├── EventManagerServiceProvider.php
│ ├── ModelsMetadataServiceProvider.php
│ ├── MvcDispatcherServiceProvider.php
│ ├── PhpTemplateEngineServiceProvider.php
│ ├── ResponseServiceProvider.php
│ ├── RouterServiceProvider.php
│ ├── ServiceProviderInterface.php
│ ├── SessionServiceProvider.php
│ ├── TagServiceProvider.php
│ ├── UrlResolverServiceProvider.php
│ ├── ViewServiceProvider.php
│ └── VoltTemplateEngineServiceProvider.php
├── bootstrap
│ └── autoload.php
├── config
│ ├── application.php
│ └── providers.php
├── index.html
├── public
│ └── index.php
├── resources
│ └── views
│ ├── index
│ │ └── index.volt
│ ├── index.volt
│ └── partials
│ └── content.volt
└── storage
├── cache
│ ├── data
│ └── volt
└── logs
Esta é uma estrutura MVC de vários módulos. Este exemplo implementa dois módulos: front -end e back -end. Por padrão, o front -end é servido se não for solicitada uma rota para o back -end. Você pode definir quais rotas usam um módulo ou outro em public/index.php :
multiple/
├── apps
│ ├── backend
│ │ ├── Module.php
│ │ ├── controllers
│ │ │ ├── IndexController.php
│ │ │ ├── LoginController.php
│ │ │ └── ProductsController.php
│ │ ├── models
│ │ │ └── Products.php
│ │ └── views
│ │ ├── login
│ │ │ └── index.phtml
│ │ └── products
│ │ └── index.phtml
│ └── frontend
│ ├── Module.php
│ ├── controllers
│ │ ├── IndexController.php
│ │ ├── ProductsController.php
│ │ └── UsersController.php
│ ├── models
│ │ └── Products.php
│ └── views
│ ├── index
│ │ └── index.phtml
│ └── products
│ └── index.phtml
└── public
└── index.php
Esta é uma estrutura MVC de vários módulos. Este exemplo implementa dois módulos: front -end e back -end. Por padrão, o front -end é servido se não for solicitada uma rota para o back -end. Você pode definir quais rotas usam um módulo ou outro em public/index.php . Volt é usado como mecanismo de modelo:
multiple-volt/
├── apps
│ └── frontend
│ ├── Module.php
│ ├── config
│ │ └── config.php
│ ├── controllers
│ │ ├── ControllerBase.php
│ │ └── IndexController.php
│ └── views
│ ├── index
│ │ ├── index.volt
│ ├── index.volt
├── config
│ ├── modules.php
│ └── services.php
├── index.html
└── public
└── index.php
Esta é uma estrutura MVC de vários módulos com um diretório de visualizações comum:
multiple-shared-views/
├── apps
│ ├── common
│ │ └── views
│ │ ├── index
│ │ │ └── index.phtml
│ │ ├── index.phtml
│ │ └── products
│ │ └── index.phtml
│ └── modules
│ ├── backend
│ │ ├── Module.php
│ │ ├── controllers
│ │ │ ├── IndexController.php
│ │ │ └── ProductsController.php
│ │ └── models
│ │ └── Products.php
│ └── frontend
│ ├── Module.php
│ └── controllers
│ └── IndexController.php
└── public
└── index.php
Esta é uma estrutura MVC de vários módulos, como é gerado pelas ferramentas de desenvolvedor Phalcon:
multiple-factory-default/
├── apps
│ └── frontend
│ ├── Module.php
│ ├── config
│ │ └── config.php
│ ├── controllers
│ │ ├── ControllerBase.php
│ │ └── IndexController.php
│ └── views
│ ├── index
│ │ └── index.phtml
│ └── index.phtml
├── index.html
└── public
└── index.ph
Esta é uma estrutura MVC de vários módulos com o padrão de camada de serviço do modelo implementado:
multiple-service-layer-model/
├── apps
│ ├── config
│ │ ├── config.php
│ │ ├── modules.php
│ │ └── services.php
│ ├── models
│ │ ├── entities
│ │ │ └── User.php
│ │ ├── repositories
│ │ │ ├── Exceptions
│ │ │ │ └── InvalidRepositoryException.php
│ │ │ ├── Repositories.php
│ │ │ └── Repository
│ │ │ └── User.php
│ │ └── services
│ │ ├── Exceptions
│ │ │ └── InvalidServiceException.php
│ │ ├── Service
│ │ │ └── User.php
│ │ └── Services.php
│ └── modules
│ └── frontend
│ ├── Module.php
│ ├── controllers
│ │ ├── ControllerBase.php
│ │ └── IndexController.php
│ └── views
│ ├── index
│ │ └── index.phtml
│ └── index.phtml
├── database.sql
├── index.html
├── public
│ └── index.php
└── tests
├── Services
│ └── UserServiceTest.php
├── TestHelper.php
├── UnitTestCase.php
└── phpunit.xml
Um aplicativo semelhante a micro-quadrowork:
micro
└── index.php
Um aplicativo semelhante a micro-quadrowork, conforme gerado pelas ferramentas de desenvolvedor Phalcon:
micro-factory-default/
├── config
│ └── config.php
├── index.html
├── public
│ └── index.php
└── views
├── 404.phtml
└── index.phtml
Um aplicativo semelhante a micro-quadrowork, onde as visualizações são renderizadas usando PhalconMvcViewSimple :
micro-simple-views
├── config
│ ├── config.php
│ └── services.php
├── index.php
└── views
├── 404.volt
├── 500.volt
└── index.volt
Os exemplos da Phalcon MVC são o software de código aberto licenciado sob a nova licença BSD. Consulte o arquivo License.txt para obter mais.
Copyright (c) 2011-2016, equipe da estrutura Phalcon