Zend Framework - Anwendungsstruktur
Lassen Sie uns in diesem Kapitel die Struktur der Zend Framework-Anwendung verstehen. Die Struktur dermyapp Anwendung ist wie folgt -
├── composer.json
├── composer.lock
├── CONDUCT.md
├── config
│ ├── application.config.php
│ ├── autoload
│ │ ├── development.local.php
│ │ ├── development.local.php.dist
│ │ ├── global.php
│ │ ├── local.php.dist
│ │ ├── README.md
│ │ └── zend-developer-tools.local-development.php
│ ├── development.config.php
│ ├── development.config.php.dist
│ └── modules.config.php
├── CONTRIBUTING.md
├── data
│ └── cache
│ └── module-classmap-cache.application.module.cache.php ├── docker-compose.yml
├── Dockerfile
├── LICENSE.md
├── module
│ └── Application
│ ├── config
│ ├── src
│ ├── test
│ └── view
├── phpcs.xml
├── phpunit.xml.dist
├── public
│ ├── css
│ │ ├── bootstrap.css
│ │ ├── bootstrap.css.map
│ │ ├── bootstrap.min.css
│ │ ├── bootstrap.min.css.map
│ │ ├── bootstrap-theme.css
│ │ ├── bootstrap-theme.css.map
│ │ ├── bootstrap-theme.min.css
│ │ ├── bootstrap-theme.min.css.map
│ │ └── style.css
│ ├── fonts
│ │ ├── glyphicons-halflings-regular.eot
│ │ ├── glyphicons-halflings-regular.svg
│ │ ├── glyphicons-halflings-regular.ttf
│ │ ├── glyphicons-halflings-regular.woff
│ │ └── glyphicons-halflings-regular.woff2
│ ├── img
│ │ ├── favicon.ico
│ │ └── zf-logo-mark.svg
│ ├── index.php
│ ├── js
│ │ ├── bootstrap.js
│ │ ├── bootstrap.min.js
│ │ └── jquery-3.1.0.min.js
│ └── web.config
├── README.md
├── TODO.md
├── Vagrantfile
└── vendor
├── autoload.php
├── bin
│ ├── phpunit -> ../phpunit/phpunit/phpunit
│ ├── templatemap_generator.php -> ../zendframework/zend-
view/bin/templatemap_generator.php
│ └── zf-development-mode -> ../zfcampus/zf-development-mode/bin/zf-
development-mode
├── composer
│ ├── autoload_classmap.php
│ ├── autoload_namespaces.php
│ ├── autoload_psr4.php
│ ├── autoload_real.php
│ ├── ClassLoader.php
│ ├── installed.json
│ └── LICENSE
├── container-interop
│ └── container-interop
├── doctrine
│ └── instantiator
├── myclabs
│ └── deep-copy
├── phpdocumentor
│ ├── reflection-common
│ ├── reflection-docblock
│ └── type-resolver
├── phpspec
│ └── prophecy
├── phpunit
│ ├── php-code-coverage
│ ├── php-file-iterator
│ ├── php-text-template
│ ├── php-timer
│ ├── php-token-stream
│ ├── phpunit
│ └── phpunit-mock-objects
├── sebastian
│ ├── code-unit-reverse-lookup
│ ├── comparator
│ ├── diff
│ ├── environment
│ ├── exporter
│ ├── global-state
│ ├── object-enumerator
│ ├── recursion-context
│ ├── resource-operations
│ └── version
├── symfony
│ └── yaml
├── webmozart
│ └── assert
├── zendframework
│ ├── zend-component-installer
│ ├── zend-config
│ ├── zend-console
│ ├── zend-dom
│ ├── zend-escaper
│ ├── zend-eventmanager
│ ├── zend-http
│ ├── zend-loader
│ ├── zend-modulemanager
│ ├── zend-mvc
│ ├── zend-router
│ ├── zend-servicemanager
│ ├── zend-stdlib
│ ├── zend-test
│ ├── zend-uri
│ ├── zend-validator
│ └── zend-view
└── zfcampus
└── zf-development-mode
73 directories, 55 files
Die Zend Framework-Anwendung besteht aus verschiedenen Ordnern. Sie sind wie folgt -
Application- Dieses Verzeichnis enthält Ihre Anwendung. Es enthält das MVC-System sowie Konfigurationen, verwendete Dienste und Ihre Bootstrap-Datei.
Config - Dieses Verzeichnis enthält die Konfigurationsdateien einer Anwendung.
Data - In diesem Verzeichnis können Anwendungsdaten gespeichert werden, die flüchtig und möglicherweise vorübergehend sind.
Module - Mit Modulen kann ein Entwickler eine Reihe verwandter Controller in einer logisch organisierten Gruppe gruppieren.
Public- Dies ist der Dokumentenstamm der Anwendung. Es startet die Zend-Anwendung. Es enthält auch die Assets der Anwendung wie JavaScript, CSS, Bilder usw.
Vendor - Dieses Verzeichnis enthält Composer-Abhängigkeiten.
Struktur der Anwendungsmodule
Dies ist das Hauptverzeichnis Ihrer Anwendung. Zend Framework 2 führt ein leistungsstarkes und flexibles Modulsystem ein, um die Anwendung effizient zu organisieren. DasApplicationDas Modul der Skeleton-Anwendung (myapp) bietet Bootstrapping-, Fehler- und Routing-Konfiguration für die gesamte Anwendung. Die Struktur derApplication Modul ist wie unten gezeigt -
├── module
│ └── Application
│ ├── config
│ │ └── module.config.php
│ ├── src
│ │ ├── Controller
│ │ │ └── IndexController.php
│ │ └── Module.php
│ ├── test
│ │ └── Controller
│ │ └── IndexControllerTest.php
│ └── view
│ ├── application
│ │ └── index
│ │ └── index.phtml
│ ├── error
│ │ ├── 404.phtml
│ │ └── index.phtml
│ └── layout
│ └── layout.phtml
Lassen Sie uns jedes dieser Modulverzeichnisse im Detail behandeln -
Application- Dies ist das Stammverzeichnis des Moduls. Der Name des Ordners stimmt mit dem Namen des Moduls überein und der Name wird auch als PHP-Namespace aller im Modul definierten Klassen verwendet. Es enthält das MVC-System sowie Konfigurationen, verwendete Dienste und Ihre Bootstrap-Datei.
Config - Unabhängige Konfiguration des Moduls.
Src - Hauptgeschäftslogik der Anwendung.
View- Enthält HTML-Dateien (Design / Präsentation). Zum Beispiel index.phtml.
src/Module.php- Es ist das Herzstück des Moduls. Es fungiert als „Front-Controller“ für das Modul. Der Zend-Prozesssrc/Module.php Datei vor der Verarbeitung von PHP-Klassen in diesem Modul.
Application/config/module.config.php - Es ist für die Routerkonfiguration und das automatische Laden von Dateien implementiert.
Application/view/layout- Layouts repräsentieren die gemeinsamen Teile mehrerer Ansichten. Zum Beispiel Seitenkopf und Fußzeile. Standardmäßig sollten Layouts in der gespeichert werdenviews/layoutsfolder.
Alle Module haben dieselbe oder eine ähnliche Struktur wie das oben genannte Anwendungsmodul .