आवश्यकताएँ - एएमडी मॉड्यूल
आवश्यकताएँ जेएसजेएस में एक मॉड्यूल एक स्कॉप्ड ऑब्जेक्ट है और वैश्विक नामस्थान में उपलब्ध नहीं है। इसलिए, वैश्विक नाम स्थान प्रदूषित नहीं होगा। आवश्यकता के सिंटैक्स निर्भरता के क्रम का ट्रैक रखने के बारे में चिंता किए बिना मॉड्यूल को तेजी से लोड करने की अनुमति देता है। आप एक ही पृष्ठ में एक ही मॉड्यूल के कई संस्करण लोड कर सकते हैं।
मॉड्यूल परिभाषित करना
मॉड्यूल का उपयोग कर परिभाषित किया गया है define()समारोह; इसी फ़ंक्शन का उपयोग मॉड्यूल को लोड करने के लिए भी किया जाता है।
सरल नाम / मूल्य जोड़े
यदि मॉड्यूल सिर्फ नाम और मूल्य जोड़े का एक संग्रह है, तो आप निम्नलिखित सिंटैक्स का उपयोग कर सकते हैं -
define({
state: "karnataka",
city: "bangalore"
});
कार्य को परिभाषित करना
एक मॉड्यूल निर्भरता के बिना, फ्रेमवर्क के लिए एक फ़ंक्शन का उपयोग भी कर सकता है। यह निम्नलिखित सिंटैक्स का उपयोग करके किया जा सकता है -
define(function () {
//Do setup work here
return {
state: "karnataka",
city: "bangalore"
}
});
निर्भरता के साथ कार्य को परिभाषित करना
यदि मॉड्यूल पर निर्भरता हो रही है, तो पहले तर्क की नियुक्ति (निर्भरता के नाम का सरणी), दूसरा तर्क (फ़ंक्शन को परिभाषित करना) और मॉड्यूल को परिभाषित करने वाली वापसी वस्तु को निम्नलिखित सिंटैक्स में दिखाया गया है -
define(["./mnc", "./startup"],
function(mnc, startup) {
return {
state: "karnataka",
city: "bangalore",
addCompany: function() {
mnc.decrement(this);
startup.add(this);
}
}
}
);
एक समारोह के रूप में एक मॉड्यूल को परिभाषित करना
एक मॉड्यूल के लिए केवल वस्तुओं को वापस करना अनिवार्य नहीं है, एक फ़ंक्शन से कोई भी वैध मूल्य भी वापस किया जा सकता है। निम्नलिखित सिंटैक्स का उपयोग एक फ़ंक्शन के रूप में एक मॉड्यूल को परिभाषित करने के लिए किया जाता है -
define(["./mnc", "./startup"],
function(mnc, startup) {
return function(title) {
return title ? (window.title = title) :
startup.storeName + ' ' + mnc.name;
}
}
);
एक नाम के साथ एक मॉड्यूल को परिभाषित करना
कुछ मामलों में आपको पहले तर्क के रूप में मॉड्यूल के लिए एक नाम शामिल करना पड़ सकता है define()। यह निम्नलिखित सिंटैक्स का उपयोग करके किया जा सकता है -
define("js2/title",
["js1/mnc", "js1/startup"],
function(mnc, startup) {
//Define js2/title object in here.
}
);
मॉड्यूल लोड हो रहा है