av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

PHP設計模式篇:選擇適用于當前項目類型和規模的最佳模式

瀏覽:3日期:2022-09-16 11:00:23

在代碼和項目中使用常見模式是有好處的,可以讓代碼更易于管理,同時也便于其他開發者理解你的項目。

如果你的項目使用了框架,那么在代碼和項目結構上,都會遵循框架的約束,自然也就繼承了框架中的各種模式, 這時你所需要考慮的是讓上層代碼也能夠遵循最合適的模式。反之,如果沒有使用框架,那么就需要你自己選擇 適用于當前項目類型和規模的最佳模式了。

Architectural pattern on WikipediaSoftware design pattern on WikipediaFactory

One of the most commonly used design patterns is the factory pattern. In this pattern, a class simply creates the object you want to use. Consider the following example of the factory pattern:

<?phpclass Automobile{ private $vehicle_make; private $vehicle_model; public function __construct($make, $model) {$this->vehicle_make = $make;$this->vehicle_model = $model; } public function get_make_and_model() {return $this->vehicle_make . ’ ’ . $this->vehicle_model; }}class AutomobileFactory{ public static function create($make, $model) {return new Automobile($make, $model); }}// have the factory create the Automobile object$veyron = AutomobileFactory::create(’Bugatti’, ’Veyron’);print_r($veyron->get_make_and_model()); // outputs 'Bugatti Veyron'

This code uses a factory to create the Automobile object. There are two possible benefits to building your code this way, the first is that if you need to change, rename, or replace the Automobile class later on you can do so and you will only have to modify the code in the factory, instead of every place in your project that uses the Automobile class. The second possible benefit is that if creating the object is a complicated job you can do all of the work in the factory, instead of repeating it every time you want to create a new instance.

Using the factory pattern isn’t always necessary (or wise). The example code used here is so simple that a factory would simply be adding unneeded complexity. However if you are making a fairly large or complex project you may save yourself a lot of trouble down the road by using factories.

Factory pattern on WikipediaSingleton

When designing web applications, it often makes sense conceptually and architecturally to allow access to one and only one instance of a particular class. The singleton pattern enables us to do this.

<?php class Singleton{ static $instance; private function __construct() { } public static function getInstance() {if (!isset(self::$instance)) { self::$instance = new self();}return self::$instance; }}$instance1 = Singleton::getInstance();$instance2 = Singleton::getInstance();echo $instance1 === $instance2; // outputs 1

The code above implements the singleton pattern using a statically scoped variable and the?getInstance()?method. Note that the constructor is declared as private to prevent instantiation outside of the class via?new?keyword.

The singleton pattern is useful when we need to make sure we only have a single instance of a class for the entire request lifecycle in a web application. This typically occurs when we have global objects (such as a Configuration class) or a shared resource (such as an event queue).

You should be wary when using the singleton pattern, as by its very nature it introduces global state into your application, reducing testability. In most cases, dependency injection can (and should) be used in place of a singleton class. Using dependency injection means that we do not introduce unnecessary coupling into the design of our application, as the object using the shared or global resource requires no knowledge of a concretely defined class.

Singleton pattern on WikipediaFront Controller

The front controller pattern is where you have a single entrance point for you web application (e.g. index.php) that handles all of the requests. This code is responsible for loading all of the dependencies, processing the request and sending the response to the browser. The front controller pattern can be beneficial because it encourages modular code and gives you a central place to hook in code that should be run for every request (such as input sanitization).

Front Controller pattern on WikipediaModel-View-Controller

The model-view-controller (MVC) pattern and its relatives HMVC and MVVM let you break up code into logical objects that serve very specific purposes. Models serve as a data access layer where data it fetched and returned in formats usable throughout your application. Controllers handle the request, process the data returned from models and load views to send in the response. And views are display templates (markup, xml, etc) that are sent in the response to the web browser.

MVC is the most common architectural pattern used in the popular?PHP frameworks.

Learn more about MVC and its relatives:

MVCHMVCMVVM
標簽: PHP
相關文章:
主站蜘蛛池模板: 日本三级播放 | 亚洲一区精品在线 | 国产精品久久久久久婷婷天堂 | 国产精品中文字幕一区二区三区 | 欧美一区二区三区视频在线观看 | 亚洲在线一区二区 | 国产精品视频免费观看 | 成人久久18免费网站图片 | 国产亚洲精品精品国产亚洲综合 | 91精品国产综合久久精品 | 国产精品成av人在线视午夜片 | 欧美aaa一级片 | 日韩av一区二区在线观看 | 美国黄色毛片 | 欧美日韩成人影院 | 盗摄精品av一区二区三区 | 亚洲品质自拍视频 | 亚洲免费在线观看视频 | 欧美日韩电影一区二区 | 亚洲欧美日韩在线 | 天天干天天玩天天操 | 日本 欧美 国产 | 国产欧美久久一区二区三区 | 在线视频国产一区 | yiren22综合网成人 | 青青操91 | av网站免费观看 | 欧美电影在线观看网站 | 亚洲精品一区在线 | 中文字幕视频在线 | 欧美久久精品一级黑人c片 91免费在线视频 | 欧美精品91 | 欧美在线视频一区二区 | 久久久成人一区二区免费影院 | 97中文视频 | 91精品国产综合久久精品 | 久久大| 久久y| 欧美性猛交一区二区三区精品 | 午夜精品一区二区三区免费视频 | 天天操天天天干 |