January 23, 2026 (2mo ago)

Model View Controller डायग्राम के लिए एक व्यावहारिक मार्गदर्शिका

साधारण उपमाओं और वास्तविक दुनिया के उदाहारणों के साथ Model View Controller डायग्राम को समझें। जानिए कैसे MVC कोड को स्केलेबल और मेंटेन करने योग्य बनाता है।

← Back to blog
Cover Image for Model View Controller डायग्राम के लिए एक व्यावहारिक मार्गदर्शिका

साधारण उपमाओं और वास्तविक दुनिया के उदाहारणों के साथ Model View Controller डायग्राम को समझें। जानिए कैसे MVC कोड को स्केलेबल और मेंटेन करने योग्य बनाता है।

A Model View Controller डायग्राम सिर्फ़ एक तकनीकी आरेख से ज़्यादा है; यह आपके एप्लिकेशन की आर्किटेक्चर के लिए एक ब्लूप्रिंट है। यह दर्शाता है कि कैसे एक जटिल सिस्टम को तीन अलग और जुड़े हुए हिस्सों में बाँटा जा सकता है: Model (डेटा और कोर लॉजिक), View (जो उपयोगकर्ता देखता है), और Controller (बीच का दूत)। यह विभाजन कोड को अधिक स्केलेबल, टेस्टेबल और मेंटेन करने में आसान बनाता है।1

Deconstructing the MVC Architectural Pattern

इस पैटर्न को सजीव बनाने के लिए, एक रेस्तरां की कल्पना कीजिए।

  • Model रसोई है: यह सामग्री (डेटा) और नुस्खे (बिजनेस नियम) रखता है।
  • View मेन्यू और टेबल सेटिंग है: यह मेहमान को विकल्प और तैयार डिश प्रस्तुत करता है।
  • Controller वेटर है: यह View से ऑर्डर लेता है, Model से उन्हें तैयार करने के लिए कहता है, और परिणाम View को लौटाता है।

यह "जिम्मेदारियों का पृथक्करण" MVC का एक मुख्य लाभ है और टीमों को कड़े एक-दूसरे से जुड़े कोड से बचने में मदद करता है जो बदलने या परीक्षण करने में मुश्किल होता है।2

व्यवहार में, MVC डायग्राम एक साझा भाषा के रूप में काम करते हैं जो डेवलपर्स, प्रोडक्ट मैनेजर्स और स्टेकहोल्डर्स को इस बात पर सहमत कराते हैं कि एप्लिकेशन कैसे काम करता है। साफ़ डायग्राम्स ऑनबोर्डिंग को तेज़ करते हैं और टीमों के बीच गलतफहमी कम करते हैं।3

Breaking Down the Core MVC Components

The Model: The Brain of the Operation

Model डेटा, स्टेट और बिजनेस नियमों का प्रबंधन करता है। यह सत्य का एकल स्रोत है और इसे प्रस्तुति विवरणों जैसे HTML या CSS के बारे में कुछ भी नहीं जानना चाहिए। इसकी जिम्मेदारियों में वैलिडेशन, परसिस्टेंस, और उन ऑपरेशनों को एक्सपोज़ करना शामिल है जिनकी सिस्टम के बाकी हिस्सों को आवश्यकता होती है।

The View: The Face of the Application

View का केवल एक ही काम है प्रस्तुति करना। यह Model से (आम तौर पर Controller के माध्यम से) डेटा प्राप्त करता है, UI रेंडर करता है, और उपयोगकर्ता इंटरैक्शनों को कैप्चर करता है। View को सीधे एप्लिकेशन डेटा बदलना नहीं चाहिए; इसे केवल उपयोगकर्ता क्रियाओं के बारे में Controller को सूचित करना चाहिए।

The Controller: The Traffic Director

Controller उपयोगकर्ता इनपुट की व्याख्या करता है, Model अपडेट्स का समन्वय करता है, और तय करता है कि View कैसे रिस्पॉन्ड करे। Controllers को हल्का रखें: उन्हें भारी काम models या service क्लासेस को सौंप देना चाहिए और जटिल बिजनेस लॉजिक एम्बेड करने से बचना चाहिए।

Roles and Responsibilities (Quick Reference)

ComponentPrimary ResponsibilityCommon Pitfalls to Avoid
Modelडेटा का प्रबंधन, बिजनेस नियम लागू करनाUI लॉजिक या HTML रेंडरिंग मिलाना
Viewडेटा रेंडर करना और इनपुट कैप्चर करनाडेटा में बदला करना या बिजनेस लॉजिक रखना
Controllerइनपुट और मॉडल अपडेट्स का समन्वयभारी डेटा प्रोसेसिंग या DB क्वेरीज़ सीधे करना

How MVC Handles a User Request — Step by Step

एक सामान्य संपर्क-फ़ॉर्म सबमिशन को फ़ॉलो करके देखें कि MVC कैसे काम करता है:

  1. उपयोगकर्ता View के साथ इंटरैक्ट करता है (फ़ॉर्म भरता है और "Submit" पर क्लिक करता है)।
  2. View जमा किए गए इनपुट के साथ Controller को सूचित करता है।
  3. Controller वैलिडेट करता है और प्रोसेसिंग Model को सौंप देता है।
  4. Model वैलिडेट करता है, डेटा सहेजता है, और स्टेट अपडेट करता है।
  5. View नए स्टेट को दिखाने के लिए फिर से रेंडर होता है (उदाहरण के लिए, "Thanks for your message!" की पुष्टि)।

यह एक-तरफा फ़्लो कपलिंग को कम करता है और सिस्टम के बारे में तर्क करना सरल बनाता है। View को सीधे Model से बात करने से रोकना छिपी हुई निर्भरताओं और "स्पेगेटी कोड" को रोके रखता है।2

Putting MVC into Practice with Modern Code

एक सामान्य Node.js + Express बैकएंड के साथ React फ्रंटएंड साफ़ तौर पर MVC पर मैप होता है। एक साधारण फ़ोल्डर संरचना है:

/project-root ├── /src │ ├── /controllers # Handles incoming requests and orchestrates responses │ ├── /models # Manages data and business rules │ └── /views_or_components # React components or server-side views

Example controller (TypeScript + Express):

// src/controllers/userController.ts
import { Request, Response } from 'express';
import { User } from '../models/userModel';

export const getUserProfile = (req: Request, res: Response) => {
  const userId = req.params.id;
  const user = User.findById(userId);

  if (user) {
    res.status(200).json(user);
  } else {
    res.status(404).send('User not found');
  }
};

Example model (conceptual):

// src/models/userModel.ts
const users = [
  { id: '1', name: 'Alex Doe', email: 'alex@example.com' },
  { id: '2', name: 'Jane Smith', email: 'jane@example.com' },
];

export class User {
  static findById(id: string) {
    return users.find(user => user.id === id);
  }
}

React component (View):

// src/components/UserProfile.tsx
import React, { useState, useEffect } from 'react';

const UserProfile = ({ userId }) => {
  const [user, setUser] = useState(null);

  useEffect(() => {
    fetch(`/api/users/${userId}`)
      .then(res => res.json())
      .then(data => setUser(data));
  }, [userId]);

  if (!user) return <div>Loading...</div>;

  return (
    <div>
      <h1>{user.name}</h1>
      <p>Email: {user.email}</p>
    </div>
  );
};

यह संरचना हर लेयर को केंद्रित और टेस्टेबल रखती है, और यह टीमों को बिना उलझी निर्भरताओं के कोडबेस को स्केल करने में मदद करती है। MVC मूल बातें जानने के लिए Codecademy का अवलोकन देखें।1

Comparing MVC with Other Design Patterns

MVC एक क्लासिक मॉडल है, लेकिन कभी-कभी UI जटिलता और परीक्षण लक्ष्यों के आधार पर MVP या MVVM बेहतर बैठते हैं।

  • MVP (Model–View–Presenter): Presenter प्रस्तुति लॉजिक को संभालता है और एक पैसिव View को संचालित करता है। तब अच्छा है जब आप UI टेस्टेबिलिटी को अधिकतम करना चाहते हैं।
  • MVVM (Model–View–ViewModel): ViewModel बाइंड करने योग्य डेटा और कमांड्स एक्सपोज़ करता है; View उनसे बाइंड होता है। डेटा बाइंडिंग और रिएक्टिव अपडेट्स के कारण यह आधुनिक UI फ्रेमवर्क्स में लोकप्रिय है।5

प्रत्येक पैटर्न अलग ट्रेड-ऑफ़्स के लिए ऑप्टिमाइज़ करता है: अलगाव और स्पष्टता (MVC), परीक्षणक्षमता (MVP), या UI प्रतिक्रियाशीलता और बायलरप्लेट में कमी (MVVM)।

Common MVC Mistakes and How to Fix Them

सही MVC डायग्राम होने के बावजूद, टीमें ऐसी एंटी-पैटर्न्स की ओर जा सकती हैं जो तकनीकी ऋण जमा कर देती हैं।

Fat Controllers

जब controllers में बिजनेस लॉजिक, गणनाएँ, या सीधे DB का काम होता है, तो वे परीक्षण और पुन: उपयोग के लिए कठिन हो जाते हैं। जटिल लॉजिक को models या समर्पित सर्विस क्लासेस में स्थानांतरित करें और controllers को समन्वयक के रूप में रखें।

Anemic Models

जब models केवल डेटा रखते हैं लेकिन व्यवहार नहीं, तो बिजनेस नियम controllers और सेवाओं में फैल जाते हैं। मॉडल्स में व्यवहार वापस लाएं और उन्हें उनकी इनवेरिएंट्स और ऑपरेशनों के लिए ज़िम्मेदार बनाएं। Martin Fowler की anemic domain model पर चर्चा सहायक पढ़ाई है।4

View को सीधे Model से बात करने न दें; सभी इंटरैक्शन Controller के माध्यम से ही होने चाहिए ताकि जिम्मेदारियों का स्पष्ट पृथक्करण बना रहे।2

FAQ — Common MVC Questions

Is MVC still relevant with frameworks like React?

हां। React View लेयर को कवर करता है, लेकिन अभी भी एप्लिकेशन स्टेट और बिजनेस नियमों (Model) के लिए एक जगह और स्टेट परिवर्तन को UI से जोड़ने का एक तरीका (Controller या समकक्ष) चाहिए। इन भूमिकाओं को अलग रखने से React कंपोनेंट्स भारी नहीं हो जाते।

What’s the biggest mistake teams make when adopting MVC?

सबसे सामान्य गलती fat controllers बनाना है। वैलिडेशन और बिजनेस लॉजिक को models या सेवाओं को सौंपकर controllers को पतला रखें।

How does an MVC diagram help team collaboration?

एक साफ़ डायग्राम एक साझा ब्लूप्रिंट है। यह अस्पष्टता को कम करता है, ऑनबोर्डिंग को तेज़ करता है, और टीमों को एक-दूसरे की जिम्मेदारियों पर टकराए बिना समानांतर में काम करने देता है।


At Clean Code Guy, we help teams apply these principles to build software that lasts. Explore our guides and services at https://cleancodeguy.com.

3.
GeeksforGeeks, “MVC Design Pattern,” https://www.geeksforgeeks.org/mvc-design-pattern/
4.
Martin Fowler, “Anemic Domain Model,” https://martinfowler.com/bliki/AnemicDomainModel.html
5.
React documentation, “React – A JavaScript library for building user interfaces,” https://react.dev
← Back to blog
🙋🏻‍♂️

AI कोड लिखता है।
आप इसे टिकाऊ बनाते हैं।

AI त्वरण के युग में, क्लीन कोड केवल एक अच्छी प्रथा नहीं है — यह उन प्रणालियों के बीच का अंतर है जो स्केल होती हैं और कोडबेस जो अपने वजन के तहत ढह जाते हैं।