jQuery - अजाक्स
AJAX अतुल्यकालिक जावास्क्रिप्ट और एक्सएमएल के लिए एक संक्षिप्त रूप से खड़ा है और यह तकनीक हमें ब्राउज़र पेज रीफ्रेश किए बिना सर्वर से डेटा लोड करने में मदद करती है।
यदि आप AJAX के साथ नए हैं, तो मैं आपको आगे बढ़ने से पहले हमारे Ajax ट्यूटोरियल के माध्यम से जाने की सलाह दूंगा ।
JQuery एक महान उपकरण है जो अगली पीढ़ी के वेब एप्लिकेशन को विकसित करने के लिए AJAX विधियों का एक समृद्ध सेट प्रदान करता है।
लोड हो रहा है सरल डेटा
JQuery AJAX का उपयोग करके किसी भी स्थिर या गतिशील डेटा को लोड करना बहुत आसान है। JQuery प्रदान करता हैload() कार्य करने की विधि -
वाक्य - विन्यास
यहाँ के लिए सरल वाक्यविन्यास है load() विधि -
[selector].load( URL, [data], [callback] );
यहाँ सभी मापदंडों का वर्णन है -
URL- सर्वर-साइड संसाधन का URL जिसमें अनुरोध भेजा जाता है। यह एक CGI, ASP, JSP या PHP स्क्रिप्ट हो सकता है जो डेटा को गतिशील रूप से या डेटाबेस से बाहर उत्पन्न करता है।
data- यह वैकल्पिक पैरामीटर एक ऑब्जेक्ट का प्रतिनिधित्व करता है, जिसके गुणों को अनुरोध पर पारित होने के लिए ठीक से एन्कोडेड मापदंडों में क्रमबद्ध किया गया है। यदि निर्दिष्ट किया गया है, तो अनुरोध का उपयोग करके किया जाता हैPOSTतरीका। यदि छोड़ा गया है,GET विधि का उपयोग किया जाता है।
callback- प्रतिक्रिया डेटा के मिलान सेट के तत्वों में लोड होने के बाद एक कॉलबैक फ़ंक्शन का आह्वान किया गया। इस फ़ंक्शन के लिए दिया गया पहला पैरामीटर सर्वर से प्राप्त प्रतिक्रिया पाठ है और दूसरा पैरामीटर स्थिति कोड है।
उदाहरण
एक छोटी JQuery कोडिंग के साथ निम्नलिखित HTML फ़ाइल पर विचार करें -
<html>
<head>
<title>The jQuery Example</title>
<script type = "text/javascript"
src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
</script>
<script type = "text/javascript" language = "javascript">
$(document).ready(function() {
$("#driver").click(function(event){
$('#stage').load('/jquery/result.html');
});
});
</script>
</head>
<body>
<p>Click on the button to load /jquery/result.html file −</p>
<div id = "stage" style = "background-color:cc0;">
STAGE
</div>
<input type = "button" id = "driver" value = "Load Data" />
</body>
</html>
यहाँ load() निर्दिष्ट URL पर एक अजाक्स अनुरोध आरंभ करता है /jquery/result.htmlफ़ाइल। इस फ़ाइल को लोड करने के बाद, सभी सामग्री आईडी चरण के साथ टैग किए गए <div> के अंदर आबाद हो जाएगी । मान लें, हमारी /jquery/result.html फ़ाइल में केवल एक HTML रेखा है -
<h1>THIS IS RESULT...</h1>
जब आप दिए गए बटन पर क्लिक करते हैं, तो result.html फ़ाइल लोड हो जाती है।
JSON डेटा प्राप्त करना
एक स्थिति होगी जब सर्वर आपके अनुरोध के खिलाफ JSON स्ट्रिंग लौटाएगा। JQuery उपयोगिता समारोहgetJSON() लौटे JSON स्ट्रिंग को पार्स करता है और आगे की कार्रवाई करने के लिए पहले पैरामीटर के रूप में कॉलबैक फ़ंक्शन के लिए परिणामी स्ट्रिंग उपलब्ध करता है।
वाक्य - विन्यास
यहाँ के लिए सरल वाक्यविन्यास है getJSON() विधि -
[selector].getJSON( URL, [data], [callback] );
यहाँ सभी मापदंडों का वर्णन है -
URL - जीईटी विधि के माध्यम से संपर्क किए गए सर्वर-साइड संसाधन का URL।
data - एक ऐसी वस्तु जिसका गुण URL के लिए संलग्न होने के लिए एक क्वेरी स्ट्रिंग का निर्माण करने के लिए नाम / मूल्य जोड़े के रूप में काम करता है, या एक पूर्वनिर्मित और एन्कोडेड क्वेरी स्ट्रिंग।
callback- अनुरोध पूरा होने पर एक समारोह। JSON स्ट्रिंग के रूप में प्रतिक्रिया निकाय को पचाने से उत्पन्न डेटा मान इस कॉलबैक के पहले पैरामीटर के रूप में पारित किया जाता है, और दूसरा के रूप में स्थिति।
उदाहरण
एक छोटी JQuery कोडिंग के साथ निम्नलिखित HTML फ़ाइल पर विचार करें -
<html>
<head>
<title>The jQuery Example</title>
<script type = "text/javascript"
src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
</script>
<script type = "text/javascript" language = "javascript">
$(document).ready(function() {
$("#driver").click(function(event){
$.getJSON('/jquery/result.json', function(jd) {
$('#stage').html('<p> Name: ' + jd.name + '</p>');
$('#stage').append('<p>Age : ' + jd.age+ '</p>');
$('#stage').append('<p> Sex: ' + jd.sex+ '</p>');
});
});
});
</script>
</head>
<body>
<p>Click on the button to load result.json file −</p>
<div id = "stage" style = "background-color:#eee;">
STAGE
</div>
<input type = "button" id = "driver" value = "Load Data" />
</body>
</html>
यहाँ JQuery उपयोगिता विधि getJSON() निर्दिष्ट URL पर एक अजाक्स अनुरोध आरंभ करता है result.jsonफ़ाइल। इस फ़ाइल को लोड करने के बाद, सभी सामग्री कॉलबैक फ़ंक्शन को पारित कर दी जाएगी, जो अंततः आईडी चरण के साथ टैग किए गए <div> के अंदर पॉपुलेटेड होगी । मान लें, हमारी result.json फ़ाइल में json स्वरूपित सामग्री निम्नलिखित है -
{
"name": "Zara Ali",
"age" : "67",
"sex": "female"
}
जब आप दिए गए बटन पर क्लिक करते हैं, तो result.json फ़ाइल लोड हो जाती है।
सर्वर को डेटा पास करना
कई बार आप उपयोगकर्ता से इनपुट एकत्र करते हैं और आप उस इनपुट को आगे की प्रक्रिया के लिए सर्वर में भेज देते हैं। JQuery AJAX ने सर्वर का उपयोग करके एकत्रित डेटा को पारित करना काफी आसान बना दियाdata किसी भी उपलब्ध अजाक्स विधि का पैरामीटर।
उदाहरण
यह उदाहरण प्रदर्शित करता है कि उपयोगकर्ता इनपुट को वेब सर्वर स्क्रिप्ट में कैसे पारित किया जा सकता है जो उसी परिणाम को वापस भेजेगा और हम इसे प्रिंट करेंगे -
<html>
<head>
<title>The jQuery Example</title>
<script type = "text/javascript"
src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
</script>
<script type = "text/javascript" language = "javascript">
$(document).ready(function() {
$("#driver").click(function(event){
var name = $("#name").val();
$("#stage").load('/jquery/result.php', {"name":name} );
});
});
</script>
</head>
<body>
<p>Enter your name and click on the button:</p>
<input type = "input" id = "name" size = "40" /><br />
<div id = "stage" style = "background-color:cc0;">
STAGE
</div>
<input type = "button" id = "driver" value = "Show Result" />
</body>
</html>
इसमें कोड लिखा हुआ है result.php स्क्रिप्ट -
<?php
if( $_REQUEST["name"] ){
$name = $_REQUEST['name'];
echo "Welcome ". $name;
}
?>
अब आप दिए गए इनपुट बॉक्स में किसी भी टेक्स्ट को दर्ज कर सकते हैं और फिर इनपुट बॉक्स में जो आपने दर्ज किया है उसे देखने के लिए "शो रिजल्ट" बटन पर क्लिक करें।
JQuery AJAX के तरीके
आपने JQuery का उपयोग करके AJAX की मूल अवधारणा देखी है। निम्न तालिका उन सभी महत्वपूर्ण JQuery AJAX विधियों को सूचीबद्ध करती है, जिनका उपयोग आप अपनी प्रोग्रामिंग आवश्यकता के आधार पर कर सकते हैं -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | jQuery.ajax (विकल्प) HTTP अनुरोध का उपयोग करके एक दूरस्थ पृष्ठ लोड करें। |
2 | jQuery.ajaxSetup (विकल्प) AJAX अनुरोधों के लिए वैश्विक सेटिंग सेट करें। |
3 | jQuery.get (url, [data], [callback], [type]) HTTP GET अनुरोध का उपयोग करके एक दूरस्थ पृष्ठ लोड करें। |
4 | jQuery.getJSON (url, [data], [callback]) HTTP GET अनुरोध का उपयोग करके JSON डेटा लोड करें। |
5 | jQuery.getScript (url, [कॉलबैक]) HTTP GET अनुरोध का उपयोग करके एक जावास्क्रिप्ट फ़ाइल लोड और निष्पादित करता है। |
6 | jQuery.post (url, [data], [callback], [type]) HTTP POST अनुरोध का उपयोग करके एक दूरस्थ पृष्ठ लोड करें। |
7 | लोड (यूआरएल, [डेटा], [कॉलबैक]) HTML को दूरस्थ फ़ाइल से लोड करें और इसे DOM में इंजेक्ट करें। |
8 | क्रमबद्ध करें( ) डेटा के एक स्ट्रिंग में इनपुट तत्वों के एक सेट को सीरियल करता है। |
9 | serializeArray () .Serialize () विधि की तरह सभी रूपों और फॉर्म तत्वों को सीरियल करता है लेकिन आपके साथ काम करने के लिए JSON डेटा संरचना देता है। |
JQuery AJAX घटनाएँ
आप AJAX कॉल प्रगति के जीवन चक्र के दौरान विभिन्न JQuery विधियों को कॉल कर सकते हैं। विभिन्न घटनाओं / चरणों के आधार पर निम्नलिखित विधियाँ उपलब्ध हैं -
आप सभी AJAX घटनाओं के माध्यम से जा सकते हैं ।
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | ajaxComplete (कॉलबैक) जब भी AJAX अनुरोध पूरा होता है, तो किसी फ़ंक्शन को निष्पादित करें। |
2 | ajaxStart (कॉलबैक) जब भी AJAX अनुरोध शुरू होता है और कोई भी सक्रिय नहीं होता है, तो किसी कार्य को निष्पादित किया जाना चाहिए। |
3 | ajaxError (कॉलबैक) जब भी AJAX अनुरोध विफल होता है, तो किसी फ़ंक्शन को निष्पादित करें। |
4 | ajaxSend (कॉलबैक) AJAX अनुरोध भेजे जाने से पहले निष्पादित किए जाने वाले फ़ंक्शन को संलग्न करें। |
5 | ajaxStop (कॉलबैक) जब भी सभी AJAX अनुरोध समाप्त हो गए हैं, तब किसी कार्य को निष्पादित करें। |
6 | ajaxSuccess (कॉलबैक) जब भी AJAX अनुरोध सफलतापूर्वक पूरा होता है, तो किसी फ़ंक्शन को निष्पादित करें। |