Django - अजाक्स

अजाक्स अनिवार्य रूप से प्रौद्योगिकियों का एक संयोजन है जो पेज लोड की संख्या को कम करने के लिए एक साथ एकीकृत किया जाता है। एंड-यूज़र अनुभव को आसान बनाने के लिए हम आम तौर पर अजाक्स का उपयोग करते हैं। Django में Ajax का उपयोग सीधे JQuery या दूसरों की तरह एक Ajax पुस्तकालय का उपयोग करके किया जा सकता है। मान लें कि आप JQuery का उपयोग करना चाहते हैं, तो आपको Apache या अन्य के माध्यम से अपने सर्वर पर लाइब्रेरी को डाउनलोड करने और सेवा करने की आवश्यकता है। फिर इसे अपने टेम्पलेट में उपयोग करें, जैसे आप किसी भी अजाक्स-आधारित एप्लिकेशन को विकसित करते समय कर सकते हैं।

Django में Ajax का उपयोग करने का दूसरा तरीका Django Ajax ढांचे का उपयोग करना है। सबसे अधिक इस्तेमाल किया जाने वाला django-dajax है जो पाइथन और लगभग कोई जावास्क्रिप्ट स्रोत कोड का उपयोग करके वेब अनुप्रयोगों में अतुल्यकालिक प्रस्तुति तर्क को आसानी से और सुपर-जल्दी विकसित करने के लिए एक शक्तिशाली उपकरण है। यह सबसे लोकप्रिय अजाक्स चौखटों में से चार का समर्थन करता है: प्रोटोटाइप, jQuery, Dojo और MooTools।

Django-dajax का उपयोग करना

सबसे पहले django-dajax को इनस्टॉल करना है। यह easy_install या पाइप का उपयोग करके किया जा सकता है -

$ pip install django_dajax
$ easy_install django_dajax

यह स्वचालित रूप से django-dajaxice को स्थापित करेगा, जिसे django-dajax द्वारा आवश्यक है। हमें फिर dajax और dajaxice दोनों को कॉन्फ़िगर करने की आवश्यकता है।

INSTALLED_APPS विकल्प में अपनी परियोजना सेटिंग में dajax और dajaxice जोड़ें -

INSTALLED_APPS += (
   'dajaxice',
   'dajax'
)

सुनिश्चित करें कि एक ही सेटिंग में आप फ़ाइल करेंगे, आपके पास निम्नलिखित हैं -

TEMPLATE_LOADERS = (
   'django.template.loaders.filesystem.Loader',
   'django.template.loaders.app_directories.Loader',
   'django.template.loaders.eggs.Loader',
)

TEMPLATE_CONTEXT_PROCESSORS = (
   'django.contrib.auth.context_processors.auth',
   'django.core.context_processors.debug',
   'django.core.context_processors.i18n',
   'django.core.context_processors.media',
   'django.core.context_processors.static',
   'django.core.context_processors.request',
   'django.contrib.messages.context_processors.messages'
)

STATICFILES_FINDERS = (
   'django.contrib.staticfiles.finders.FileSystemFinder',
   'django.contrib.staticfiles.finders.AppDirectoriesFinder',
   'dajaxice.finders.DajaxiceFinder',
)

DAJAXICE_MEDIA_PREFIX = 'dajaxice'

अब myapp / url.py फ़ाइल पर जाएं और सुनिश्चित करें कि आपके पास dajax URL सेट करने के लिए और dajax स्टेटिक्स js फ़ाइलों को लोड करने के लिए निम्नलिखित हैं -

from dajaxice.core import dajaxice_autodiscover, dajaxice_config
from django.contrib.staticfiles.urls import staticfiles_urlpatterns
from django.conf import settings

Then dajax urls:

urlpatterns += patterns('',
   url(r'^%s/' % settings.DAJAXICE_MEDIA_PREFIX, include('dajaxice.urls')),)
	
urlpatterns += staticfiles_urlpatterns()

अजाक्स (मतलब ताज़ा नहीं) का उपयोग करके, इसे स्टोर करने के लिए अपने ड्रीम्रियल मॉडल के आधार पर एक सरल फ़ॉर्म बनाएं।

सबसे पहले, हमें myapp / form.py में अपने Dreamreal फॉर्म की आवश्यकता है।

class DreamrealForm(forms.Form):
   website = forms.CharField(max_length = 100)
   name = forms.CharField(max_length = 100)
   phonenumber = forms.CharField(max_length = 50)
   email = forms.CharField(max_length = 100)

फिर हमें अपने आवेदन में एक ajax.py फ़ाइल की आवश्यकता है: myapp / ajax.py। यही हमारा तर्क है, यही वह जगह है जहाँ हम उस कार्य को करते हैं जो हमारे फॉर्म को बचाएगा और फिर पॉपअप लौटाएगा -

from dajaxice.utils import deserialize_form
from myapp.form import DreamrealForm
from dajax.core import Dajax
from myapp.models import Dreamreal

@dajaxice_register
def send_form(request, form):
   dajax = Dajax()
   form = DreamrealForm(deserialize_form(form))
   
   if form.is_valid():
      dajax.remove_css_class('#my_form input', 'error')
      dr = Dreamreal()
      dr.website = form.cleaned_data.get('website')
      dr.name = form.cleaned_data.get('name')
      dr.phonenumber = form.cleaned_data.get('phonenumber')
      dr.save()
      
      dajax.alert("Dreamreal Entry %s was successfully saved." % 
         form.cleaned_data.get('name'))
   else:
      dajax.remove_css_class('#my_form input', 'error')
      for error in form.errors:
         dajax.add_css_class('#id_%s' % error, 'error')
			
   return dajax.json()

अब हम dreamreal.html टेम्पलेट बनाते हैं, जिसमें हमारा फॉर्म है -

<html>
   <head></head>
   <body>
   
      <form action = "" method = "post" id = "my_form" accept-charset = "utf-8">
         {{ form.as_p }}
         <p><input type = "button" value = "Send" onclick = "send_form();"></p>
      </form>
      
   </body>
</html>

उस दृश्य को जोड़ें जो टेम्पलेट के साथ myapp / views.py में जाता है -

def dreamreal(request):
   form = DreamrealForm()
   return render(request, 'dreamreal.html', locals())

Myapp / urls.py में संबंधित URL जोड़ें -

url(r'^dreamreal/', 'dreamreal', name = 'dreamreal'),

अब अजाक्स कार्य करने के लिए अपने टेम्पलेट में आवश्यक जोड़ें -

फ़ाइल जोड़ने के शीर्ष पर -

{% load static %}
{% load dajaxice_templatetags %}

और हमारे dreamreal.html टेम्पलेट ऐड के <head> अनुभाग में -

हम इस उदाहरण के लिए JQuery लाइब्रेरी का उपयोग कर रहे हैं, इसलिए जोड़ें -

<script src = "{% static '/static/jquery-1.11.3.min.js' %}" 
   type = "text/javascript" charset = "utf-8"></script>
<script src = "{% static '/static/dajax/jquery.dajax.core.js' %}"></script>

अजाक्स फ़ंक्शन जिसे क्लिक पर बुलाया जाएगा -

<script>

   function send_form(){
      Dajaxice.myapp.send_form(Dajax.process,{'form':$('#my_form').serialize(true)});
   }
</script>

ध्यान दें कि आपको अपनी स्थिर फ़ाइलों निर्देशिका में "jquery-1.11.3.min.js" और jquery.dajax.core.js की भी आवश्यकता है। यह सुनिश्चित करने के लिए कि आपके स्टैटिक डायरेक्टरी के तहत सभी डैजैक्स स्टैटिक फाइल सर्व की जाती हैं, चलाएं -

$python manage.py collectstatic

Note - कभी-कभी jquery.dajax.core.js गायब हो सकते हैं, यदि ऐसा होता है, तो बस स्रोत डाउनलोड करें और उस फ़ाइल को ले जाएं और इसे अपने स्थिर फ़ोल्डर के नीचे रखें।

आपको निम्नलिखित स्क्रीन देखने को मिलेगी, एक्सेस करने पर / myapp / dreamreal / -

सबमिट करने पर, आपको निम्न स्क्रीन मिलेगी -