Dies sind Beispiele für MVC -Dateistrukturen, die Sie mit Phalcon> = 3.0.x verwenden können
Weitere Unterlagen finden Sie in den Phalcon -Dokumenten.
中文简体
Dies ist eine sehr einfache MVC -Struktur, die ein Modell, zwei Controller und eine Ansicht enthält. In diesem Beispiel wird keine Namespaces implementiert. Dienste werden in public/index.php definiert, ohne dass DiFactoryDefault :
simple
├── apps
│ ├── controllers
│ │ ├── IndexController.php
│ │ └── ProductsController.php
│ ├── models
│ │ └── Products.php
│ └── views
│ └── products
│ └── index.phtml
└── public
└── index.php
Dies ist eine sehr einfache MVC -Struktur, die ein Modell, zwei Controller und eine Ansicht enthält. In diesem Beispiel wird keine Namespaces implementiert. Die Dienste werden in public/index.php definiert, ohne DiFactoryDefault zu verwenden. In diesem Beispiel wird Volt als Template Engine verwendet:
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
Eine weitere sehr einfache MVC -Struktur enthält ein Modell, drei Controller und eine Ansicht. Routen sind in app/config/routes.php definiert. Einige Routen weisen auf Controller in einem Unterverzeichnis von 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
Einfache MVC -Struktur ohne PhalconMvcApplication . Diese Anwendung verwendet keine Namespaces. Dies ist ein Beispiel dafür, wie Sie PhalconMvcApplication überschreiben können, indem Sie eine ähnliche Funktionalität implementieren. Es definiert auch Dienste, ohne DiFactoryDefault in public/index.php zu verwenden:
simple-without-application/
├── apps
│ ├── controllers
│ │ ├── IndexController.php
│ │ └── ProductsController.php
│ ├── models
│ │ └── Products.php
│ └── views
│ └── products
│ └── index.phtml
└── public
└── index.php
Dies ist eine Einzelmodul-MVC-Struktur ohne Namespaces. Sie finden die Verzeichnisse des Moduls unter den apps/ Verzeichnissen. In diesem Beispiel werden keine Namespaces verwendet. Alle Dienste werden in public/index.php initialisiert. In dieser Datei können Sie auch eine Anwendungsklasse finden, die Dienste und Autoloader initialisiert, die diese Aufgaben nach Methoden gruppieren.
single
├── apps
│ ├── controllers
│ │ ├── IndexController.php
│ │ └── ProductsController.php
│ ├── models
│ │ └── Products.php
│ └── views
│ ├── index.phtml
│ └── products
│ ├── index.phtml
│ └── test.phtml
└── public
└── index.php
Dies ist eine Einzelmodul-MVC-Struktur unter Verwendung von Namespaces. Sie finden die Verzeichnisse des Moduls unter den apps/ Verzeichnissen. In diesem Beispiel wird Namespaces verwendet. Alle Dienste werden in public/index.php initialisiert. In dieser Datei können Sie auch eine Anwendungsklasse finden, die Dienste und Autoloader initialisiert, die diese Aufgaben nach Methoden gruppieren.
single-namespaces/
├── apps
│ ├── controllers
│ │ ├── IndexController.php
│ │ └── ProductsController.php
│ ├── models
│ │ └── Products.php
│ └── views
│ └── products
│ └── index.phtml
└── public
└── index.php
Eine einzelne modulige MVC-Struktur, die von Phalcon Developer Tools erzeugt wird. Anstatt jeden Dienst einzeln zu initialisieren, verwendet er 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
Dies ist eine Einzelmodul-MVC-Struktur. Alle Dateien und Verzeichnisse werden zusammengefasst (einschließlich Ansichten):
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
Dies ist eine Einzelmodul-MVC-Struktur, die eine nicht standardmäßige Methode zur Registrierung von Diensten zeigt:
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
Dies ist eine Multi-Modul-MVC-Struktur. Dieses Beispiel implementiert zwei Module: Frontend und Backend. Standardmäßig wird Frontend serviert, wenn keine Route zum Backend gefragt wird. Sie können definieren, welche Routen ein oder ein anderes Modul in public/index.php verwenden:
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
Dies ist eine Multi-Modul-MVC-Struktur. Dieses Beispiel implementiert zwei Module: Frontend und Backend. Standardmäßig wird Frontend serviert, wenn keine Route zum Backend gefragt wird. Sie können definieren, welche Routen ein oder ein anderes Modul in public/index.php verwenden. Volt wird als Vorlagenmotor verwendet:
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
Dies ist eine Multi-Modul-MVC-Struktur mit einem gemeinsamen Ansichtenverzeichnis:
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
Dies ist eine Multi-Modul-MVC-Struktur, die von Phalcon-Entwickler-Tools erzeugt wird:
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
Dies ist eine Multi-Modul-MVC-Struktur mit implementierter Modellschichtmuster:
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
Eine mikro-rameworkähnliche Anwendung:
micro
└── index.php
Eine mikro-rameworkähnliche Anwendung, die von Phalcon Developer Tools generiert wird:
micro-factory-default/
├── config
│ └── config.php
├── index.html
├── public
│ └── index.php
└── views
├── 404.phtml
└── index.phtml
Eine mikro-rameworkähnliche Anwendung, bei der Ansichten unter Verwendung von PhalconMvcViewSimple gemacht werden:
micro-simple-views
├── config
│ ├── config.php
│ └── services.php
├── index.php
└── views
├── 404.volt
├── 500.volt
└── index.volt
Beispiele für Phalcon MVC sind Open -Source -Software, die unter der neuen BSD -Lizenz lizenziert sind. Weitere Informationen finden Sie in der lizenz.txt -Datei.
Copyright (C) 2011-2016, Phalcon Framework-Team