Clean Architecture در یک سرویس ساده Node.js 🧱
یکی از مشکلهای همیشگی پروژههای وب این است که بعد از چند ماه، همهچیز توی یک فایل یا یک لایه قاطی میشود: route منطق بیزینسی دارد، مستقیم به DB وصل میشود و تست گرفتن هم کابوس میشود.
اینجا جایی است که ایدهٔ Clean Architecture بهدرد میخورد: جداکردن منطق بیزینسی از زیرساخت (مثل Express، DB، HTTP، و غیره) تا کد قابلتست و قابلتوسعه بماند. 🎯
در سادهترین حالت، فقط همین اصل را رعایت کنید:
Use Case / Domain لایهٔ مرکزی ➜ Framework و DB در لبهها
یعنی:
• Route فقط ورودی/خروجی HTTP را مدیریت کند ✅
• منطق اصلی در یک Service یا Use Case مستقل باشد ✅
• Service هیچ وابستگی مستقیم به Express یا driver خاص DB نداشته باشد ✅
یک نمونهٔ خیلی ساده در Node.js + Express:
حالا لایهٔ زیرساخت (Express + یک repo ساده):
چند نکتهٔ عملی از تجربهٔ پروژههای واقعی 🌱
• منطق اصلی را همیشه در Service / Use Case نگه دارید، نه داخل controller / route.
• وابستگیها را بهسمت لبهها ببرید؛ Domain نباید Express، HTTP status code یا driver خاص DB را بشناسد.
• این ساختار روی Next.js API Routes، Nest.js، Laravel و Django هم کاملاً قابلپیادهسازی است.
برای مطالعهٔ عمیقتر ایدهها:
Layered Architecture - Martin Fowler
Refactoring.Guru - Design Patterns
همانقدر که پروژه بزرگتر میشود، همین جداسازی ساده بین Domain و Infrastructure میتواند نجاتدهنده باشد. دفعهٔ بعدی که یک feature جدید مینویسید، از همین الگوی کوچک شروع کنید و قدمبهقدم کد را تمیزتر نگه دارید. 🚀
🔖 #Web #وب #Frontend #Backend #Clean_Architecture #Node_js #Express #Design_Patterns #Web_Development #Backend #Refactoring
👤 Developix
💎 Channel: @DevelopixWeb
یکی از مشکلهای همیشگی پروژههای وب این است که بعد از چند ماه، همهچیز توی یک فایل یا یک لایه قاطی میشود: route منطق بیزینسی دارد، مستقیم به DB وصل میشود و تست گرفتن هم کابوس میشود.
اینجا جایی است که ایدهٔ Clean Architecture بهدرد میخورد: جداکردن منطق بیزینسی از زیرساخت (مثل Express، DB، HTTP، و غیره) تا کد قابلتست و قابلتوسعه بماند. 🎯
در سادهترین حالت، فقط همین اصل را رعایت کنید:
Use Case / Domain لایهٔ مرکزی ➜ Framework و DB در لبهها
یعنی:
• Route فقط ورودی/خروجی HTTP را مدیریت کند ✅
• منطق اصلی در یک Service یا Use Case مستقل باشد ✅
• Service هیچ وابستگی مستقیم به Express یا driver خاص DB نداشته باشد ✅
یک نمونهٔ خیلی ساده در Node.js + Express:
// userService.js (لایه Domain / Use Case)
class UserService {
constructor(userRepo) {
this.userRepo = userRepo; // وابستگی به interface، نه به Express
}
async registerUser(data) {
const { email, password } = data;
if (!email || !password) {
throw new Error("Invalid data");
}
const exists = await this.userRepo.findByEmail(email);
if (exists) {
throw new Error("Email already used");
}
// اینجا میتوانید hashing، ruleها و ... را قرار دهید
return this.userRepo.create({ email, password });
}
}
module.exports = UserService;
حالا لایهٔ زیرساخت (Express + یک repo ساده):
// userRepo.js (لایه Infrastructure)
const users = [];
module.exports = {
async findByEmail(email) {
return users.find(u => u.email === email) || null;
},
async create(user) {
users.push(user);
return user;
}
};
// routes.js
const express = require("express");
const UserService = require("./userService");
const userRepo = require("./userRepo");
const router = express.Router();
const userService = new UserService(userRepo);
router.post("/register", async (req, res) => {
try {
const user = await userService.registerUser(req.body);
res.status(201).json(user);
} catch (err) {
res.status(400).json({ error: err.message });
}
});
module.exports = router;
چند نکتهٔ عملی از تجربهٔ پروژههای واقعی 🌱
• منطق اصلی را همیشه در Service / Use Case نگه دارید، نه داخل controller / route.
• وابستگیها را بهسمت لبهها ببرید؛ Domain نباید Express، HTTP status code یا driver خاص DB را بشناسد.
• این ساختار روی Next.js API Routes، Nest.js، Laravel و Django هم کاملاً قابلپیادهسازی است.
برای مطالعهٔ عمیقتر ایدهها:
Layered Architecture - Martin Fowler
Refactoring.Guru - Design Patterns
همانقدر که پروژه بزرگتر میشود، همین جداسازی ساده بین Domain و Infrastructure میتواند نجاتدهنده باشد. دفعهٔ بعدی که یک feature جدید مینویسید، از همین الگوی کوچک شروع کنید و قدمبهقدم کد را تمیزتر نگه دارید. 🚀
🔖 #Web #وب #Frontend #Backend #Clean_Architecture #Node_js #Express #Design_Patterns #Web_Development #Backend #Refactoring
👤 Developix
💎 Channel: @DevelopixWeb
❤1
ساختن یک API کوچک و تمیز با Node.js و Express از اون کارهاییه که مستقیم توی پروژههای واقعی به کار میاد؛ از اتصال React/Vue گرفته تا ساخت پنل ادمین یا حتی یه سرویس موبایل.
این مدل API رو میشه دقیقاً بر اساس داک رسمی Express جلو برد:
https://expressjs.com/en/starter/hello-world.html
ایدهمون 👇
یه REST API خیلی ساده برای مدیریت tasks میسازیم که از سمت Frontend (مثلاً React) قابل مصرف باشه:
• گرفتن لیست tasks
• اضافه کردن task جدید
نکته خوبش اینه که هم با ساختار یک Express app آشنا میشی، هم میفهمی چطور JSON رو هندل کنی و پاسخ استاندارد بدی.
اول باید Node.js نصب باشه. بعد توی یه فولدر خالی این کامندها رو بزن:
حالا فایل
حالا:
• با
• توی مرورگر برو به
• برای تست
این ساختار کوچیک، پایه خیلی از پروژههای جدیتره:
• میتونی بعداً auth اضافه کنی.
• میتونی به جای آرایه، از MongoDB یا PostgreSQL استفاده کنی.
• میتونی همین API رو به یه React یا Vue app وصل کنی و یه Todo ساده ولی تمیز بسازی.
امتحانش کن، سرور رو بالا بیار و یه بار واقعی باهاش دیتا رد و بدل کن؛ از اون چیزهاییست که بعدش کار با Backend خیلی طبیعیتر به نظر میرسه. اگر مفید بود، برای بقیه همتیمیها هم بفرست تا همه روی یک استک مشترک تمرین کنید.
🔖 #Web #وب #Frontend #Backend #Node_js #Express #REST_API #Backend #Frontend #JavaScript #Web_Development #Tutorial
👤 Developix
💎 Channel: @DevelopixWeb
این مدل API رو میشه دقیقاً بر اساس داک رسمی Express جلو برد:
https://expressjs.com/en/starter/hello-world.html
ایدهمون 👇
یه REST API خیلی ساده برای مدیریت tasks میسازیم که از سمت Frontend (مثلاً React) قابل مصرف باشه:
• گرفتن لیست tasks
• اضافه کردن task جدید
نکته خوبش اینه که هم با ساختار یک Express app آشنا میشی، هم میفهمی چطور JSON رو هندل کنی و پاسخ استاندارد بدی.
اول باید Node.js نصب باشه. بعد توی یه فولدر خالی این کامندها رو بزن:
npm init -y
npm install express cors
حالا فایل
index.js رو بساز و این کد رو بذار داخلش:const express = require("express");
const cors = require("cors");
const app = express();
const PORT = 3000;
app.use(cors());
app.use(express.json());
let tasks = [
{ id: 1, title: "Learn Express", done: false },
{ id: 2, title: "Build a simple API", done: false }
];
// GET /api/tasks
app.get("/api/tasks", (req, res) => {
res.json(tasks);
});
// POST /api/tasks
app.post("/api/tasks", (req, res) => {
const { title } = req.body;
if (!title) {
return res.status(400).json({ error: "title is required" });
}
const newTask = {
id: tasks.length + 1,
title,
done: false
};
tasks.push(newTask);
res.status(201).json(newTask);
});
app.listen(PORT, () => {
console.log(`Server is running on http://localhost:${PORT}`);
});حالا:
• با
node index.js سرور رو بالا بیار.• توی مرورگر برو به
http://localhost:3000/api/tasks، باید یه آرایه JSON ببینی.• برای تست
POST از Postman یا افزونه REST Client یا حتی fetch در Frontend استفاده کن.این ساختار کوچیک، پایه خیلی از پروژههای جدیتره:
• میتونی بعداً auth اضافه کنی.
• میتونی به جای آرایه، از MongoDB یا PostgreSQL استفاده کنی.
• میتونی همین API رو به یه React یا Vue app وصل کنی و یه Todo ساده ولی تمیز بسازی.
امتحانش کن، سرور رو بالا بیار و یه بار واقعی باهاش دیتا رد و بدل کن؛ از اون چیزهاییست که بعدش کار با Backend خیلی طبیعیتر به نظر میرسه. اگر مفید بود، برای بقیه همتیمیها هم بفرست تا همه روی یک استک مشترک تمرین کنید.
🔖 #Web #وب #Frontend #Backend #Node_js #Express #REST_API #Backend #Frontend #JavaScript #Web_Development #Tutorial
👤 Developix
💎 Channel: @DevelopixWeb
❤3