jQuery - मूल बातें
jQuery जावास्क्रिप्ट क्षमताओं का उपयोग करके बनाया गया एक ढांचा है। तो, आप जावास्क्रिप्ट में उपलब्ध सभी कार्यों और अन्य क्षमताओं का उपयोग कर सकते हैं। यह अध्याय सबसे बुनियादी अवधारणाओं की व्याख्या करेगा लेकिन अक्सर jQuery में उपयोग किया जाता है।
तार
जावास्क्रिप्ट में एक स्ट्रिंग एक अपरिवर्तनीय वस्तु है जिसमें कोई नहीं, एक या कई वर्ण होते हैं। जावास्क्रिप्ट स्ट्रिंग के मान्य उदाहरण निम्नलिखित हैं -
"This is JavaScript String"
'This is JavaScript String'
'This is "really" a JavaScript String'
"This is 'really' a JavaScript String"
नंबर
जावास्क्रिप्ट में नंबर डबल-सटीक 64-बिट प्रारूप IEEE 754 मान हैं। वे अपरिवर्तनीय हैं, जैसे कि तार। जावास्क्रिप्ट संख्या के मान्य उदाहरण निम्नलिखित हैं -
5350
120.27
0.26
बूलियन
जावास्क्रिप्ट में एक बूलियन या तो हो सकता है true या false। यदि कोई संख्या शून्य है, तो यह गलत है। यदि एक खाली स्ट्रिंग झूठे को परिभाषित करती है।
जावास्क्रिप्ट बूलियन के मान्य उदाहरण निम्नलिखित हैं -
true // true
false // false
0 // false
1 // true
"" // false
"hello" // true
वस्तुओं
जावास्क्रिप्ट वस्तु अवधारणा को बहुत अच्छी तरह से समर्थन करता है। आप वस्तु शाब्दिक रूप से निम्नानुसार एक वस्तु बना सकते हैं -
var emp = {
name: "Zara",
age: 10
};
आप निम्न के रूप में डॉट नोटेशन का उपयोग करके किसी ऑब्जेक्ट के गुणों को लिख और पढ़ सकते हैं -
// Getting object properties
emp.name // ==> Zara
emp.age // ==> 10
// Setting object properties
emp.name = "Daisy" // <== Daisy
emp.age = 20 // <== 20
सरणियों
आप सरणी शाब्दिक का उपयोग करके सरणियों को इस प्रकार परिभाषित कर सकते हैं -
var x = [];
var y = [1, 2, 3, 4, 5];
एक सरणी में एक है length संपत्ति जो पुनरावृत्ति के लिए उपयोगी है -
var x = [1, 2, 3, 4, 5];
for (var i = 0; i < x.length; i++) {
// Do something with x[i]
}
कार्यों
जावास्क्रिप्ट में एक फ़ंक्शन का नाम या अनाम हो सकता है। फ़ंक्शन कीवर्ड का उपयोग करके एक नामित फ़ंक्शन को परिभाषित किया जा सकता है -
function named(){
// do some stuff here
}
एक अनाम फ़ंक्शन को एक सामान्य फ़ंक्शन के समान तरीके से परिभाषित किया जा सकता है, लेकिन इसका कोई नाम नहीं होगा।
एक अनाम फ़ंक्शन को एक चर को सौंपा जा सकता है या नीचे दिखाए गए तरीके से पारित किया जा सकता है।
var handler = function (){
// do some stuff here
}
JQuery अनाम कार्यों का उपयोग अक्सर निम्नानुसार करता है -
$(document).ready(function(){
// do some stuff here
});
बहस
जावास्क्रिप्ट चर तर्क एक प्रकार का सरणी है जिसमें लंबाई संपत्ति है। निम्नलिखित उदाहरण इसे बहुत अच्छी तरह से समझाते हैं -
function func(x){
console.log(typeof x, arguments.length);
}
func(); //==> "undefined", 0
func(1); //==> "number", 1
func("1", "2", "3"); //==> "string", 3
तर्कों ऑब्जेक्ट में एक शांत संपत्ति भी है , जो उस फ़ंक्शन को संदर्भित करता है जो आप अंदर हैं। उदाहरण के लिए -
function func() {
return arguments.callee;
}
func(); // ==> func
प्रसंग
जावास्क्रिप्ट प्रसिद्ध खोजशब्द thisहमेशा वर्तमान संदर्भ को संदर्भित करता है। एक समारोह के भीतरthis संदर्भ बदल सकता है, इस पर निर्भर करता है कि फ़ंक्शन को कैसे कहा जाता है -
$(document).ready(function() {
// this refers to window.document
});
$("div").click(function() {
// this refers to a div DOM element
});
आप फ़ंक्शन-बिल्ट-इन विधियों का उपयोग करके फ़ंक्शन कॉल के लिए संदर्भ निर्दिष्ट कर सकते हैं call() तथा apply() तरीकों।
उनके बीच का अंतर यह है कि वे कैसे तर्क पारित करते हैं। कॉल सभी तर्कों को फ़ंक्शन के तर्कों के रूप में पास करता है, जबकि एक सरणी को तर्कों के रूप में स्वीकार करता है।
function scope() {
console.log(this, arguments.length);
}
scope() // window, 0
scope.call("foobar", [1,2]); //==> "foobar", 1
scope.apply("foobar", [1,2]); //==> "foobar", 2
क्षेत्र
एक चर का दायरा आपके कार्यक्रम का क्षेत्र है जिसमें इसे परिभाषित किया गया है। जावास्क्रिप्ट चर में केवल दो स्कोप होंगे।
Global Variables - एक वैश्विक चर में वैश्विक गुंजाइश होती है जिसका अर्थ है कि यह आपके जावास्क्रिप्ट कोड में हर जगह परिभाषित है।
Local Variables- एक स्थानीय चर केवल एक फ़ंक्शन के भीतर दिखाई देगा जहां इसे परिभाषित किया गया है। फ़ंक्शन पैरामीटर हमेशा उस फ़ंक्शन के लिए स्थानीय होते हैं।
एक समारोह के शरीर के भीतर, एक स्थानीय चर एक ही नाम के साथ एक वैश्विक चर पर पूर्वता लेता है -
var myVar = "global"; // ==> Declare a global variable
function ( ) {
var myVar = "local"; // ==> Declare a local variable
document.write(myVar); // ==> local
}
वापस कॉल करें
कॉलबैक एक सादा जावास्क्रिप्ट फंक्शन है जिसे किसी विधि या विकल्प के रूप में पारित किया जाता है। कुछ कॉलबैक केवल घटनाएं हैं, जो उपयोगकर्ता को एक निश्चित राज्य के ट्रिगर होने पर प्रतिक्रिया करने का मौका देने के लिए कहा जाता है।
jQuery की घटना प्रणाली उदाहरण के लिए हर जगह ऐसे कॉलबैक का उपयोग करती है -
$("body").click(function(event) {
console.log("clicked: " + event.target);
});
अधिकांश कॉलबैक तर्क और एक संदर्भ प्रदान करते हैं। इवेंट-हैंडलर उदाहरण में, कॉलबैक को एक तर्क, एक ईवेंट के साथ कहा जाता है।
कुछ कॉलबैक में कुछ वापस करने की आवश्यकता होती है, अन्य उस रिटर्न वैल्यू को वैकल्पिक बनाते हैं। फ़ॉर्म सबमिट करने से रोकने के लिए, सबमिट ईवेंट हैंडलर गलत तरीके से वापस आ सकता है -
$("#myform").submit(function() {
return false;
});
बंद
क्लोज़र तब बनाए जाते हैं जब एक वैरिएबल जिसे वर्तमान स्कोप के बाहर परिभाषित किया जाता है, को कुछ आंतरिक स्कोप के भीतर से एक्सेस किया जाता है।
निम्नलिखित उदाहरण दिखाता है कि चर कैसे counter बनाएँ, वेतन वृद्धि और प्रिंट कार्यों के भीतर दिखाई देता है, लेकिन उनके बाहर नहीं -
function create() {
var counter = 0;
return {
increment: function() {
counter++;
},
print: function() {
console.log(counter);
}
}
}
var c = create();
c.increment();
c.print(); // ==> 1
यह पैटर्न आपको उन तरीकों से ऑब्जेक्ट बनाने की अनुमति देता है जो डेटा पर काम करते हैं जो बाहरी दुनिया को दिखाई नहीं देते हैं। इस बात पर ध्यान दिया जाना चाहिए किdata hiding ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग का बहुत आधार है।
प्रॉक्सी पैटर्न
एक प्रॉक्सी एक वस्तु है जिसका उपयोग किसी अन्य वस्तु तक पहुंच को नियंत्रित करने के लिए किया जा सकता है। यह उसी इंटरफ़ेस को इस अन्य ऑब्जेक्ट के रूप में लागू करता है और किसी भी तरीके के इनवोकेशन पर जाता है। इस अन्य वस्तु को अक्सर वास्तविक विषय कहा जाता है।
इस वास्तविक विषय के स्थान पर एक प्रॉक्सी को तत्काल किया जा सकता है और इसे दूरस्थ रूप से एक्सेस करने की अनुमति दी जा सकती है। हम jQuery के सेटअरे विधि को एक क्लोजर में सहेज सकते हैं और इसे इस प्रकार से लिख सकते हैं -
(function() {
// log all calls to setArray
var proxied = jQuery.fn.setArray;
jQuery.fn.setArray = function() {
console.log(this, arguments);
return proxied.apply(this, arguments);
};
})();
इसके बाद के संस्करण एक समारोह को छिपाने के लिए अपने कोड लपेटता प्रॉक्सी चर। प्रॉक्सी तब सभी कॉल को मेथड में लाती है और कॉल को ओरिजिनल मेथड पर डेलिगेट करती है। एप्लिकेशन (यह, तर्क) का उपयोग करके गारंटी देता है कि कॉलर मूल और अनुमानित विधि के बीच अंतर को नोटिस करने में सक्षम नहीं होगा।
अंतर्निहित कार्य
जावास्क्रिप्ट अंतर्निहित कार्यों के एक उपयोगी सेट के साथ आता है। इन विधियों का उपयोग स्ट्रिंग्स, संख्याओं और तिथियों में हेरफेर करने के लिए किया जा सकता है।
निम्नलिखित जावास्क्रिप्ट कार्य हैं -
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | charAt() निर्दिष्ट सूचकांक पर चरित्र लौटाता है। |
2 | concat() दो तार के पाठ को जोड़ता है और एक नया स्ट्रिंग लौटाता है। |
3 | forEach() सरणी में प्रत्येक तत्व के लिए एक फ़ंक्शन को कॉल करता है। |
4 | indexOf() निर्दिष्ट मूल्य की पहली घटना के कॉलिंग स्ट्रींग ऑब्जेक्ट के भीतर सूचकांक लौटाता है, या नहीं मिला तो -1। |
5 | length() स्ट्रिंग की लंबाई लौटाता है। |
6 | pop() किसी सरणी से अंतिम तत्व निकालता है और उस तत्व को वापस करता है। |
7 | push() सरणी के अंत में एक या अधिक तत्व जोड़ता है और सरणी की नई लंबाई लौटाता है। |
8 | reverse() किसी सरणी के तत्वों के क्रम को उलट देता है - पहला अंतिम बन जाता है, और अंतिम पहले बन जाता है। |
9 | sort() एक सरणी के तत्वों को सॉर्ट करता है। |
10 | substr() वर्णों की निर्दिष्ट संख्या के माध्यम से निर्दिष्ट स्थान पर एक स्ट्रिंग शुरुआत में वर्ण लौटाता है। |
1 1 | toLowerCase() कॉलिंग स्ट्रिंग मान लौटाता है जो निम्न स्थिति में परिवर्तित होता है। |
12 | toString() संख्या के मूल्य का स्ट्रिंग प्रतिनिधित्व लौटाता है। |
13 | toUpperCase() कॉलिंग स्ट्रिंग मान को अपरकेस में लौटाता है। |
द डॉक्यूमेंट ऑब्जेक्ट मॉडल
द डॉक्यूमेंट ऑब्जेक्ट मॉडल HTML के विभिन्न तत्वों की एक पेड़ संरचना है जो निम्नानुसार है -
<html>
<head>
<title>The jQuery Example</title>
</head>
<body>
<div>
<p>This is a paragraph.</p>
<p>This is second paragraph.</p>
<p>This is third paragraph.</p>
</div>
</body>
</html>
यह निम्नलिखित परिणाम देगा -
उपरोक्त वृक्ष संरचना के बारे में महत्वपूर्ण बिंदु निम्नलिखित हैं -
<Html> अन्य सभी तत्वों का पूर्वज है; दूसरे शब्दों में, सभी अन्य तत्व <html> के वंशज हैं।
<Head> और <body> तत्व न केवल वंशज हैं, बल्कि <html> के बच्चे भी हैं।
इसी तरह, <head> और <body> के पूर्वज होने के अलावा, <html> उनके माता-पिता भी हैं।
<P> तत्व <div> के बच्चे (और वंशज) हैं, <शरीर> और <html> के वंशज हैं, और एक-दूसरे के भाई-बहन हैं।
JQuery अवधारणाओं को सीखने के दौरान, DOM पर समझ होना मददगार होगा, अगर आपको DOM के बारे में जानकारी नहीं है तो मैं DOM ट्यूटोरियल पर हमारे सरल ट्यूटोरियल के माध्यम से जाने का सुझाव दूंगा ।