Single Responsibility Principle(SRP)
ეს პრინციპი ამბობს, რომ თითოეულ კლასს უნდა ჰქონდეს ერთი პასუხისმგებლობა. იგი ხაზს უსვამს, რომ კლასმა უნდა შეასრულოს ერთი კონკრეტული ფუნქცია და არ ჰქონდეს ძალიან ბევრი მიზეზი შესაცვლელად.
მაგალითი: მომხმარებლის ინფორმაციის მართვა და ელ.ფოსტის შეტყობინებების გაგზავნა.
class UserManager {
public function createUser($userData) {
// Logic for creating a user
}
}
class EmailService {
public function sendEmail($emailData) {
// Logic for sending an email
}
}
Open/Closed Principle(OCP)
ეს პრინციპი ხელს უწყობს ფუნქციების გაფართოებას ახალი კოდის დამატებით, ვიდრე არსებული კოდის შეცვლით.
მაგალითი: გადახდის სხვადასხვა მეთოდის მართვა ელექტრონული კომერციის აპლიკაციაში.
interface PaymentProcessor {
public function processPayment();
}
class CreditCardPaymentProcessor implements PaymentProcessor {
public function processPayment() {
// Logic for processing credit card payment
}
}
class PayPalPaymentProcessor implements PaymentProcessor {
public function processPayment() {
// Logic for processing PayPal payment
}
}
Liskov Substitution Principle(LSP)
ეს პრინციპი ამტკიცებს, რომ მიღებული კლასის ობიექტები უნდა იყოს ჩანაცვლებადი საბაზისო კლასის ობიექტებით პროგრამის სისწორეზე გავლენის გარეშე.
მაგალითი: გეომეტრიული ფორმების მართვა.
abstract class Shape {
abstract public function area();
}
class Rectangle extends Shape {
public function area() {
return $this->width * $this->height;
}
}
class Square extends Shape {
public function area() {
return $this->side * $this->side;
}
}
Interface Segregation Principle(ISP)
ეს პრინციპი გვირჩევს ინტერფეისების დაშლას უფრო პატარებად, რათა თავიდან აიცილოთ კლასების იძულება განახორციელონ მეთოდები, რომლებიც მათ არ სჭირდებათ.
მაგალითი: ინტერფეისები მონაცემთა განახლებისა და ჩვენებისთვის.
interface UpdateableFeature {
public function updateFeature();
}
interface DisplayableFeature {
public function displayFeature();
}
Dependency Inversion Principle(DIP)
ეს პრინციპი გვთავაზობს დამოკიდებულების ინექციის გამოყენებას დამოკიდებულებების სამართავად.
მაგალითი: დამოკიდებულების ინექციის გამოყენება დამოკიდებულებების სამართავად.
class OrderProcessor {
private $dbConnection;
private $emailService;
public function __construct(DatabaseConnection $dbConnection, EmailService $emailService) {
$this->dbConnection = $dbConnection;
$this->emailService = $emailService;
}
}
გახსოვდეთ, რომ PHP-ში პრინციპების გამოყენება SOLID უნდა მოხდეს მოქნილად, თქვენი პროექტის კონკრეტული მიზნისა და PHP-ის გაგების საფუძველზე SOLID.