यह फ़ाइल वास्तव में क्या करती है?
jqueryval
एक फ़ाइल नहीं है यह एक बंडल का संदर्भ है।
एमवीसी 4 में एक बंडल स्क्रिप्ट, शैलियों या अन्य फ़ाइलों को एक बंडल में एक साथ बंडल का संग्रह है।
आपके पास फ़ाइल App_Start
फ़ोल्डर में होगी, जिसमें कौन सी फ़ाइल को बंडल में जोड़ा गया है, इसकी सेटिंग्स शामिल हैं।
bundles.Add(new ScriptBundle("~/bundles/jqueryval").Include(
"~/Scripts/jquery.unobtrusive*",
"~/Scripts/jquery.validate*"));
आप ~/bundles/jqueryval
ऊपर देख सकते हैं बंडल जो इसे में निर्दिष्ट फ़ाइलों को जोड़ती है की आभासी मार्ग है। तो बाद में जब आप इसे देखते हैं:
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}
उपर्युक्त में उस संदर्भ के तहत बंडल की गई स्क्रिप्ट शामिल होंगी।
क्या मुझे इसे रखना चाहिए? क्या मुझे इन सभी जेएस फाइलों का संदर्भ देना चाहिए जो में शुरू में BundleConfig.cs में परिभाषित किए गए थे?
jqueryval
बंडल के मामले में आप पाएंगे कि अविभाज्य और सत्यापन स्क्रिप्ट शामिल हैं बहुत उपयोगी हैं।
वे स्क्रिप्ट हैं जो आपके डोम को अच्छे और साफ रखने के लिए अविभाज्य सत्यापन का प्रबंधन करने का ख्याल रखेंगे।
यदि आपको आवश्यकता नहीं है या अविभाज्य सत्यापन का उपयोग करना चाहते हैं तो आप बंडल ऑफ कोर्स को हटा सकते हैं। यदि आप करते हैं तो मुझे विश्वास है कि आप भी false
करने के लिए आवश्यक क्षेत्रों की स्थापना अपनी परियोजना सुनिश्चित करने के लिए, अपने web.config
अपडेट करनी होगी फ़ाइलें, इस के समान की तलाश में नहीं किया जाएगा:
<add key="ClientValidationEnabled" value="false" />
<add key="UnobtrusiveJavaScriptEnabled" value="false" />
लाभ और सटीक अंतर घुसपैठ और अविभाज्य सत्यापन का उपयोग करने के बीच इस आलेख में बहुत अच्छी तरह से समझाया गया है: Brad Wilson: Unobtrusive Client Validation in ASP.NET MVC 3
सामान्यतः, मुझे लगता है कि आपको केवल वही शामिल करना अच्छा होगा जो आपको चाहिए। यदि आपको बंडल में निर्दिष्ट सभी फ़ाइलों की आवश्यकता नहीं है, तो उन फ़ाइलों को हटाएं, बंडल को एक साथ छोड़ दें या अपने स्वयं के कस्टम बंडल बनाएं।
परीक्षण और त्रुटि। यदि आप उन्हें हटाते हैं और अपने ब्राउज़र डीबगर कंसोल में यादृच्छिक अपवाद पाते हैं, तो कुछ फ़ाइलों/बंडलों को वापस जोड़ने का प्रयास करें।
सामान्य तौर पर, यह भी bundling शैली-पत्रक के साथ काम करता है:
bundles.Add(new StyleBundle("~/Content/themes/base/css").Include(
"~/Content/themes/base/jquery.ui.core.css",
"~/Content/themes/base/jquery.ui.resizable.css",
"~/Content/themes/base/jquery.ui.selectable.css",
"~/Content/themes/base/jquery.ui.accordion.css",
"~/Content/themes/base/jquery.ui.autocomplete.css",
"~/Content/themes/base/jquery.ui.button.css",
"~/Content/themes/base/jquery.ui.dialog.css",
"~/Content/themes/base/jquery.ui.slider.css",
"~/Content/themes/base/jquery.ui.tabs.css",
"~/Content/themes/base/jquery.ui.datepicker.css",
"~/Content/themes/base/jquery.ui.progressbar.css",
"~/Content/themes/base/jquery.ui.theme.css"));
डेवलपर के लिए लाभ केवल एक व्यक्ति के बंडल संदर्भ के लिए कई फ़ाइलों के बजाय हो रही है।
क्लाइंट को लाभ यह है कि स्क्रिप्ट/सीएसएस फ़ाइलों को प्राप्त करने के लिए ब्राउजर को कितने व्यक्तिगत लोड करना पड़ता है।
यदि आपके उदाहरण के लिए आपके पास 5 फाइल संदर्भ हैं तो क्लाइंट ब्राउज़र सभी 5 अलग-अलग डाउनलोड करेगा और प्रत्येक ब्राउज़र में एक सीमा है कि कितनी फाइलें एक साथ डाउनलोड की जा सकती हैं। इसका अर्थ यह है कि यदि किसी ग्राहक के पास धीमा कनेक्शन होता है तो वे फ़ाइलों को लोड होने से पहले कुछ सेकंड प्रतीक्षा कर सकते हैं।
हालांकि, अगर आपके पास एक ही बंडल में रहने के लिए कॉन्फ़िगर की गई सभी 5 फ़ाइलें हैं, तो ब्राउज़र केवल 1 फ़ाइल डाउनलोड करता है, बंडल वाला एक।
इसके अलावा बंडल को (या बंडलों में फाइलें) को छोटा कर दिया जाता है, इसलिए आप न केवल स्क्रिप्ट डाउनलोड करने के लिए समय पर बचत कर रहे हैं बल्कि आप डाउनलोड आकार पर भी बचत करते हैं।
जब आप इसका परीक्षण करते हैं, तो डीबग मोड में नोट कोई अंतर नहीं है, आपको RegisterBundles
विधि के नीचे BundleConfig.cs
फ़ाइल में बंडल तालिका के अनुकूलन को सक्षम करने की आवश्यकता है।
BundleTable.EnableOptimizations = true;
आपको बंडलों का उपयोग करने की आवश्यकता नहीं है, फिर भी आप स्वतंत्र रूप से अलग-अलग स्क्रिप्ट/सीएसएस फ़ाइलों का संदर्भ दे सकते हैं। यह चीजों को आसान बनाता है हालांकि आपको इसकी आवश्यकता होती है।
टैंक, मुझे पता है बंडल का उपयोग कैसे करें, मैं सिर्फ अगर मैं बनाने के पृष्ठ पर jqueryval का उपयोग करना चाहिए पता नहीं है , और jquery unobstrustive आदि – Baconbeastnz
@Baconbeastnz: क्षमा करें, मैं मुख्य रूप से आपके प्रश्न का उत्तर देने की कोशिश कर रहा था 'यह फ़ाइल वास्तव में क्या करती है? '। अगर आपको उनका उपयोग करना चाहिए, तो यह निर्भर करता है कि आपको उनकी आवश्यकता है या नहीं। मैं आपको केवल वही शामिल करने की सलाह दूंगा जो आपको वास्तव में चाहिए। इसलिए यदि आपको केवल कुछ स्क्रिप्ट की आवश्यकता है तो अपने स्वयं के बंडल बनाएं और उन्हें अपने दृश्य में संदर्भित करें। मैंने बंडलों के लाभ को रेखांकित किया है, इसलिए मैं उन्हें पूर्व-परिभाषित लोगों या अपने स्वयं के कस्टम लोगों का उपयोग करने की सलाह दूंगा। – Nope
बहुत उपयोगी स्पष्टीकरण। इससे मेरी समस्या को हल करने में मदद मिली –