चेरीपी - अजाक्स का उपयोग

वर्ष 2005 तक, सभी वेब एप्लिकेशन में प्रतिरूप एक HTTP अनुरोध प्रति पृष्ठ प्रबंधित करने के लिए था। एक पृष्ठ से दूसरे पृष्ठ के नेविगेशन को पूरा पृष्ठ लोड करने की आवश्यकता है। यह एक बड़े स्तर पर प्रदर्शन को कम करेगा।

इस प्रकार, वहाँ एक वृद्धि हुई थी rich client applications जो AJAX, XML और JSON को उनके साथ एम्बेड करता था।

ajax

अतुल्यकालिक जावास्क्रिप्ट और XML (AJAX) तेज और गतिशील वेब पेज बनाने की एक तकनीक है। AJAX सर्वर के साथ पर्दे के पीछे की छोटी मात्रा का आदान-प्रदान करके वेब पृष्ठों को अतुल्यकालिक रूप से अपडेट करने की अनुमति देता है। इसका मतलब है कि पूरे पृष्ठ को फिर से लोड किए बिना, वेब पेज के कुछ हिस्सों को अपडेट करना संभव है।

Google मानचित्र, जीमेल, यूट्यूब और फेसबुक AJAX अनुप्रयोगों के कुछ उदाहरण हैं।

Ajax जावास्क्रिप्ट का उपयोग करके HTTP अनुरोध भेजने के विचार पर आधारित है; अधिक विशेष रूप से AJAX उन कार्यों को करने के लिए XMLHttpRequest ऑब्जेक्ट और इसके API पर निर्भर करता है।

JSON

JSON एक तरह से क्रमबद्ध जावास्क्रिप्ट ऑब्जेक्ट्स को ले जाने का एक तरीका है जिससे जावास्क्रिप्ट एप्लिकेशन उनका मूल्यांकन कर सकते हैं और उन्हें जावास्क्रिप्ट ऑब्जेक्ट्स में बदल सकते हैं जिन्हें बाद में हेरफेर किया जा सकता है।

उदाहरण के लिए, जब उपयोगकर्ता JSON प्रारूप के साथ स्वरूपित किसी एल्बम ऑब्जेक्ट के लिए सर्वर का अनुरोध करता है, तो सर्वर आउटपुट को निम्नानुसार लौटाएगा -

{'description': 'This is a simple demo album for you to test', 'author': ‘xyz’}

अब डेटा एक जावास्क्रिप्ट साहचर्य सरणी है और विवरण क्षेत्र के माध्यम से पहुँचा जा सकता है -

data ['description'];

अनुप्रयोग के लिए AJAX लागू करना

उस एप्लिकेशन पर विचार करें जिसमें index.html और Jquery प्लगइन के साथ "मीडिया" नामक एक फ़ोल्डर और AJAX कार्यान्वयन के साथ एक फ़ाइल शामिल है। आइए फाइल के नाम पर "ajax_app.py" के रूप में विचार करें।

ajax_app.py

import cherrypy
import webbrowser
import os
import simplejson
import sys

MEDIA_DIR = os.path.join(os.path.abspath("."), u"media")

class AjaxApp(object):
   @cherrypy.expose
   def index(self):
      return open(os.path.join(MEDIA_DIR, u'index.html'))

   @cherrypy.expose
   def submit(self, name):
      cherrypy.response.headers['Content-Type'] = 'application/json'
      return simplejson.dumps(dict(title="Hello, %s" % name))
		
config = {'/media':
   {'tools.staticdir.on': True,
   'tools.staticdir.dir': MEDIA_DIR,}
}
			
def open_page():
webbrowser.open("http://127.0.0.1:8080/")
cherrypy.engine.subscribe('start', open_page)
cherrypy.tree.mount(AjaxApp(), '/', config=config)
cherrypy.engine.start()

वर्ग "AjaxApp" वेब पेज "index.html" पर पुनर्निर्देशित करता है, जो मीडिया फ़ोल्डर में शामिल है।

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 
   " http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
	
<html xmlns = "http://www.w3.org/1999/xhtml" lang = "en" xml:lang = "en">
   <head>
      <title>AJAX with jQuery and cherrypy</title>
      <meta http-equiv = " Content-Type" content = " text/html; charset = utf-8" />
      <script type = " text/javascript" src = " /media/jquery-1.4.2.min.js"></script>
		
      <script type = " text/javascript">
         $(function() {
         
            // When the testform is submitted...
            $("#formtest").submit(function() {
         
               // post the form values via AJAX...
               $.post('/submit', {name: $("#name").val()}, function(data) {
         
                  // and set the title with the result
                  $("#title").html(data['title']) ;
               });
               return false ;
            });
         });
      </script>
		
   </head>
	
   <body>
      <h1 id = "title">What's your name?</h1>
      <form id = " formtest" action = " #" method = " post">
         <p>
            <label for = " name">Name:</label>
            <input type = " text" id = "name" /> <br />
            <input type = " submit" value = " Set" />
         </p>
      </form>
   </body>
	
</html>

AJAX के लिए फ़ंक्शन <script> टैग में शामिल है।

उत्पादन

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करेगा -

उपयोगकर्ता द्वारा मान जमा किए जाने के बाद, AJAX की कार्यक्षमता को लागू किया जाता है और स्क्रीन को नीचे दिखाए गए रूप में भेज दिया जाता है -