⊗jsSpAXFt 244 of 294 menu

AJAX में fetch के साथ काम करने की मूल बातें

आइए अब देखते हैं कि AJAX का उपयोग करके पेज के एक हिस्से को कैसे लोड किया जाए। मान लीजिए कि हमारे पेज index.html पर एक div और एक बटन स्थित है (यहाँ body की सामग्री दिखाई गई है):

<div></div> <button>click me</button>

मान लीजिए कि हमारे पास एक पेज ajax.html भी है, जिस पर तीन पैराग्राफ स्थित हैं (बिना पेज टैग के, बस पैराग्राफ):

<p>1</p> <p>2</p> <p>3</p>

आइए ऐसा करें कि index.html पेज पर बटन पर क्लिक करने पर div में ajax.html पेज की सामग्री लोड हो जाए।

इसके लिए सबसे पहले हमारे एलिमेंट्स के लिंक वेरिएबल में प्राप्त करें:

let div = document.querySelector('div'); let button = document.querySelector('button');

आइए बटन पर क्लिक हैंडलर लगाएं:

button.addEventListener('click', function() { // यहाँ हम AJAX रिक्वेस्ट करेंगे });

आइए अब AJAX रिक्वेस्ट करें। इसके लिए fetch फंक्शन का उपयोग किया जाता है, जो पैरामीटर के रूप में उस पेज का एड्रेस प्राप्त करता है, जिसकी सामग्री हम प्राप्त करना चाहते हैं। आइए हमारे सर्वर पर ajax.html पेज का एड्रेस निर्दिष्ट करें:

button.addEventListener('click', function() { let result = fetch('/ajax.html'); });

fetch अपने परिणाम के रूप में एक प्रोमिस वापस करेगा। बात यह है कि AJAX के माध्यम से पेज का अनुरोध - यह एक अतुल्यकालिक ऑपरेशन है, क्योंकि इसमें कुछ समय लगेगा, जिसके बाद पेज हमें जवाब देगा।

आइए प्रोमिस का परिणाम प्राप्त करें:

button.addEventListener('click', function() { let promise = fetch('/ajax.html'); promise.then(function(response) { // सर्वर का उत्तर response वेरिएबल में है }); });

अनावश्यक वेरिएबल को हटाकर इसे सरल बनाएं:

button.addEventListener('click', function() { fetch('/ajax.html').then(function(response) { }); });

एरो फंक्शन का उपयोग करके इसे सरल बनाएं:

button.addEventListener('click', function() { fetch('/ajax.html').then(response => { }); });

इसे अधिक पठनीय रूप में प्रस्तुत करें:

button.addEventListener('click', function() { fetch('/ajax.html').then( response => { } ); });

response वेरिएबल में काफी जटिल ऑब्जेक्ट क्लास Response है:

button.addEventListener('click', function() { fetch('/ajax.html').then(response => { console.log(response); // Response क्लास का ऑब्जेक्ट }); });

इस ऑब्जेक्ट का गहन अध्ययन हम अगले पाठों में करेंगे, और अभी हमें सबसे सरल चीज चाहिए - अनुरोध किए गए पेज का टेक्स्ट प्राप्त करना। इसके लिए इस ऑब्जेक्ट में text मेथड मौजूद है। हालाँकि, यह मेथड पेज का टेक्स्ट नहीं लौटाता, बल्कि इसके टेक्स्ट के साथ एक प्रोमिस लौटाता है:

button.addEventListener('click', function() { fetch('/ajax.html').then( response => { console.log(response.text()); // Promise आउटपुट करेगा } ); });

पेज के टेक्स्ट तक पहुँचने के लिए, आवश्यक है कि response.text से प्राप्त प्रोमिस को एक बार और प्रोसेस किया जाए:

button.addEventListener('click', function() { fetch('/ajax.html').then( response => { return response.text(); } ).then( text => { console.log(text); // पेज का टेक्स्ट } ); });

तो, आखिरकार हमने अनुरोध किए गए पेज का टेक्स्ट प्राप्त कर लिया है और उदाहरण के लिए, इसे अपने div में लिख सकते हैं:

button.addEventListener('click', function() { fetch('/ajax.html').then( response => { return response.text(); } ).then( text => { div.innerHTML = text; } ); });

तीन बटन और एक div दिए गए हैं। सर्वर पर तीन पेज दिए गए हैं। ऐसा करें कि प्रत्येक बटन div में संबंधित पेज लोड करे।

मान लीजिए कि सर्वर पर पाँच पेज हैं। मान लीजिए कि बटन पर पहली बार क्लिक करने पर पहला पेज लोड हो, दूसरी बार क्लिक करने पर - दूसरा, और इसी तरह आगे, जब तक पेज खत्म नहीं हो जाते।

हिन्दी
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
हम साइट के कार्य, विश्लेषण और व्यक्तिगतकरण के लिए कुकीज़ का उपयोग करते हैं। डेटा प्रसंस्करण गोपनीयता नीति के अनुसार किया जाता है।
सभी स्वीकार करें कॉन्फ़िगर करें अस्वीकार करें