MVC फ्रेमवर्क - दृश्य

जैसा कि प्रारंभिक परिचयात्मक अध्यायों में देखा गया है, देखें अनुप्रयोग के उपयोगकर्ता इंटरफ़ेस के साथ शामिल घटक है। ये व्यू आमतौर पर मॉडल डेटा से बंधे होते हैं और इनमें HTML, aspx, cshtml, vbhtml आदि जैसे एक्सटेंशन होते हैं। अपने पहले MVC एप्लिकेशन में, हमने अंतिम उपयोगकर्ता को डेटा प्रदर्शित करने के लिए कंट्रोलर के साथ व्यूज़ का उपयोग किया था। ब्राउज़र के लिए इन स्थिर और गतिशील सामग्री को प्रस्तुत करने के लिए, MVC फ्रेमवर्क दृश्य इंजन का उपयोग करता है। देखें इंजन मूल रूप से सिंटैक्स कार्यान्वयन है, जो ब्राउज़र के अंतिम HTML को प्रस्तुत करने के लिए जिम्मेदार हैं।

MVC फ्रेमवर्क दो बिल्ट-इन व्यू इंजन के साथ आता है -

Razor Engine- रेजर एक मार्कअप सिंटैक्स है जो सर्वर पेज C # या VB कोड को वेब पेजों में सक्षम बनाता है। वेब पेज लोड होने पर डायनामिक कंटेंट बनाने के लिए इस सर्वर साइड कोड का उपयोग किया जा सकता है। रेजर ASPX इंजन की तुलना में एक उन्नत इंजन है और MVC के बाद के संस्करणों में लॉन्च किया गया था।

ASPX Engine- ASPX या वेब फॉर्म्स इंजन डिफॉल्ट व्यू इंजन है जो शुरुआत से ही MVC फ्रेमवर्क में शामिल है। इस इंजन के साथ एक कोड लिखना ASP.NET वेब फॉर्म में एक कोड लिखने के समान है।

रेजर और ASPX दोनों इंजनों की तुलना करने वाले छोटे कोड स्निपेट निम्नलिखित हैं।

उस्तरा

@Html.ActionLink("Create New", "UserAdd")

ASPX

<% Html.ActionLink("SignUp", "SignUp") %>

इन दोनों में से, रेजर एक उन्नत दृश्य इंजन है क्योंकि यह कॉम्पैक्ट सिंटैक्स, टेस्ट संचालित विकास दृष्टिकोण और बेहतर सुरक्षा सुविधाओं के साथ आता है। हम अपने सभी उदाहरणों में रेजर इंजन का उपयोग करेंगे क्योंकि यह सबसे अधिक इस्तेमाल किया जाने वाला व्यू इंजन है।

इन व्यू इंजनों को निम्नलिखित दो प्रकारों में कोडित और कार्यान्वित किया जा सकता है -

  • दृढ़ता से टाइप किया हुआ
  • गतिशील टाइप किया हुआ

ये दृष्टिकोण क्रमशः शुरुआती-बाध्यकारी और देर से-बाध्यकारी के समान हैं, जिसमें मॉडल दृश्य को दृढ़ता से या गतिशील रूप से बांधेंगे।

जोरदार टाइप के दृश्य

इस अवधारणा को समझने के लिए, हम एक नमूना MVC एप्लिकेशन बनाते हैं (पिछले अध्यायों में दिए चरणों का पालन करें) और एक नियंत्रक श्रेणी फ़ाइल जोड़ें ViewDemoController

अब, नियंत्रक फ़ाइल में निम्न कोड की प्रतिलिपि बनाएँ -

using System.Collections.Generic; 
using System.Web.Mvc;  

namespace ViewsInMVC.Controllers { 
   
   public class ViewDemoController : Controller { 
      
      public class Blog { 
         public string Name; 
         public string URL; 
      }  
      
      private readonly List topBlogs = new List { 
         new Blog { Name = "Joe Delage", URL = "http://tutorialspoint/joe/"}, 
         new Blog {Name = "Mark Dsouza", URL = "http://tutorialspoint/mark"}, 
         new Blog {Name = "Michael Shawn", URL = "http://tutorialspoint/michael"} 
      };  
      
      public ActionResult StonglyTypedIndex() { 
         return View(topBlogs); 
      }  
      
      public ActionResult IndexNotStonglyTyped() { 
         return View(topBlogs); 
      }   
   } 
}

उपरोक्त कोड में, हमारे पास दो कार्य विधियां परिभाषित हैं: StronglyTypedIndex तथा IndexNotStonglyTyped। अब हम इन क्रिया विधियों के लिए दृश्य जोड़ेंगे।

StonglyTypedIndex एक्शन विधि पर राइट-क्लिक करें और Add View पर क्लिक करें। अगली विंडो में, 'एक जोरदार-टाइप दृश्य बनाएं' चेकबॉक्स जांचें। यह मॉडल वर्ग और पाड़ टेम्पलेट विकल्पों को भी सक्षम करेगा। मचान टेम्पलेट विकल्प से सूची का चयन करें। जोड़ें पर क्लिक करें।

निम्न स्क्रीनशॉट के समान एक व्यू फ़ाइल बनाई जाएगी। जैसा कि आप नोट कर सकते हैं, इसमें शीर्ष पर ViewDemoController का ब्लॉग मॉडल वर्ग शामिल है। आप इस दृष्टिकोण के साथ अपने कोड में IntelliSense का उपयोग करने में भी सक्षम होंगे।

गतिशील टाइप किए गए दृश्य

डायनामिक टाइप किए गए दृश्य बनाने के लिए, IndexNotStonglyTyped एक्शन पर राइट-क्लिक करें और Add View पर क्लिक करें।

इस बार, 'एक जोरदार-टाइप दृश्य बनाएँ' चेकबॉक्स का चयन न करें।

परिणामी दृश्य में निम्नलिखित कोड होंगे -

@model dynamic 
            
@{ 
   ViewBag.Title = "IndexNotStonglyTyped"; 
}

<h2>Index Not Stongly Typed</h2>  
<p> 
   <ul> 
      
      @foreach (var blog in Model) { 
         <li> 
            <a href = "@blog.URL">@blog.Name</a> 
         </li>    
      } 
   
   </ul> 
</p>

जैसा कि आप उपरोक्त कोड में देख सकते हैं, इस बार इसने पिछले मामले की तरह ब्लॉग मॉडल को व्यू में नहीं जोड़ा। इसके अलावा, आप इस बार IntelliSense का उपयोग नहीं कर पाएंगे क्योंकि इस बार बाइंडिंग रन-टाइम पर की जाएगी।

मजबूत टाइप किए गए दृश्यों को एक बेहतर दृष्टिकोण माना जाता है क्योंकि हम पहले से ही जानते हैं कि डेटा को डायनामिक टाइप किए गए दृश्यों के विपरीत मॉडल के रूप में पारित किया जा रहा है जिसमें डेटा रनटाइम पर बंध जाता है और लिंक मॉडल में कुछ परिवर्तन होने पर रनटाइम त्रुटियों का कारण बन सकता है।