DesignPatternsPHP
Read the Docs of DesignPatternsPHP or Download as PDF/Epub
This is a collection of known design patterns and some sample code how to implement them in PHP. Every pattern has a small list of examples (most of them from Zend Framework, Symfony2 or Doctrine2 as I'm most familiar with this software).
I think the problem with patterns is that often people do know them but don't know when to apply which.
Installation
You should look at and run the tests to see what happens in the example.
To do this, you should install dependencies with Composer first:
[optional] Using Docker
You can optionally run tests using Docker for Mac or Windows or native one for Linux. Just run:
docker-compose up
Install dependencies
$ composer installRead more about how to install and use Composer on your local machine here.
If you are using Docker, you just have to run:
docker-compose run composer installRunning test suite
$ ./vendor/bin/phpunitPatterns
The patterns can be structured in roughly three different categories. Please click on the
Creational
- AbstractFactory
π - Builder
π - FactoryMethod
π - Multiton (is considered an anti-pattern!
βοΈ ) - Pool
π - Prototype
π - SimpleFactory
- Singleton
π (is considered an anti-pattern!βοΈ ) - StaticFactory
Structural
- Adapter
π - Bridge
π - Composite
π - DataMapper
π - Decorator
π - DependencyInjection
π - Facade
π - FluentInterface
π - Flyweight
π - Proxy
π - Registry
π
Behavioral
- ChainOfResponsibilities
π - Command
π - Iterator
π - Mediator
π - Memento
π - NullObject
π - Observer
π - Specification
π - State
π - Strategy
π - TemplateMethod
π - Visitor
π
More
- Delegation
π - ServiceLocator
π (is considered an anti-pattern!βοΈ ) - Repository
- EAV
π
Contribute
If you encounter any bugs or missing translations, please feel free to fork and send a pull request with your changes.
To establish a consistent code quality, please check your code using PHP_CodeSniffer against PSR2 standard using ./vendor/bin/phpcs -p --standard=PSR2 --ignore=vendor ..

Formed in 2009, the Archive Team (not to be confused with the archive.org Archive-It Team) is a rogue archivist collective dedicated to saving copies of rapidly dying or deleted websites for the sake of history and digital heritage. The group is 100% composed of volunteers and interested parties, and has expanded into a large amount of related projects for saving online and digital history.
