學(xué)習(xí)Python Web和Django開(kāi)發(fā)不能只學(xué)習(xí)Python。我們有時(shí)必需借助其它技術(shù)比如AJAX實(shí)現(xiàn)我們想要的功能。今天我們就要利用Django 2.0 + AJAX開(kāi)發(fā)一個(gè)功能性頁(yè)面: 我們一邊輸入關(guān)鍵詞,網(wǎng)頁(yè)一邊會(huì)給你提示所找到的博文數(shù)量。
Ajax 即“Asynchronous Javascript And XML”(異步 JavaScript 和 XML),是指一種創(chuàng)建交互式網(wǎng)頁(yè)應(yīng)用的網(wǎng)頁(yè)開(kāi)發(fā)技術(shù)。通過(guò)在后臺(tái)與服務(wù)器進(jìn)行少量數(shù)據(jù)交換,Ajax 可以使網(wǎng)頁(yè)實(shí)現(xiàn)異步更新。這意味著可以在不重新加載整個(gè)網(wǎng)頁(yè)的情況下,對(duì)網(wǎng)頁(yè)的某部分進(jìn)行更新。
Ajax常見(jiàn)應(yīng)用場(chǎng)景包括:
以上場(chǎng)景都是Django單靠自己無(wú)法實(shí)現(xiàn)的。注意Ajax應(yīng)只用于與服務(wù)器少量數(shù)據(jù)交換,且存安全隱患,不宜廣泛使用。
我們創(chuàng)建一個(gè)叫blog的APP,并把它加入到INSTALLED_APP里去,然后在后臺(tái)添加一些文章, 用于搜索(如下所示)。我們需要設(shè)計(jì)2個(gè)功能性頁(yè)面: 一個(gè)展示博客文章清單,一個(gè)搜索頁(yè)面。
本案例中所用到的Article模型代碼如下:
from django.db import models from django.contrib.auth.models import User from django.urls import reverse from django.utils.timezone import now class Article(models.Model): STATUS_CHOICES = ( ('d', '草稿'), ('p', '發(fā)表'), ) title = models.CharField('標(biāo)題', max_length=200, unique=True) slug = models.SlugField('slug', max_length=60) body = models.TextField('正文') pub_date = models.DateTimeField('發(fā)布時(shí)間', default=now, null=True) create_date = models.DateTimeField('創(chuàng)建時(shí)間', auto_now_add=True) mod_date = models.DateTimeField('修改時(shí)間', auto_now=True) status = models.CharField('文章?tīng)顟B(tài)', max_length=1, choices=STATUS_CHOICES, default='p') views = models.PositiveIntegerField('瀏覽量', default=0) author = models.ForeignKey(User, verbose_name='作者', on_delete=models.CASCADE) def __str__(self): return self.title class Meta: ordering = ['-pub_date'] verbose_name = "文章"
前文提到過(guò)我們需要設(shè)計(jì)2個(gè)功能性頁(yè)面: 一個(gè)展示博客文章清單,一個(gè)搜索。然而在urls.py里我們卻設(shè)計(jì)了3個(gè)URL。這是因?yàn)槲覀冞€要設(shè)計(jì)一個(gè)URL與AJAX進(jìn)行后臺(tái)數(shù)據(jù)交換。這是用戶(hù)看不見(jiàn)的,后面我們會(huì)用到這個(gè)URL。當(dāng)ajax發(fā)送請(qǐng)求到/blog/ajax/search/時(shí),Django就會(huì)調(diào)用ajax_search方法來(lái)處理。
from django.urls import path, re_path from . import views # namespace app_name = 'blog' urlpatterns = [ # 搜索文章 re_path(r'^search/$', views.article_search, name='article_search'), # 用于與ajax交互 re_path(r'^ajax/search/$', views.ajax_search, name='ajax_search'), # 展示所有文章 path('', views.ArticleListView.as_view(), name='article_list'), ]
對(duì)應(yīng)3個(gè)URL,我們需要在視圖里編寫(xiě)3個(gè)處理方法,其中ajax_search用來(lái)給搜索頁(yè)面返回Json數(shù)據(jù)(查詢(xún)到的文章數(shù)量)。article_search方法用來(lái)返回搜索結(jié)果。我們?yōu)槭裁床挥胊jax_search返回搜索結(jié)果呢?因?yàn)椴樵?xún)到的數(shù)據(jù)集可能非常大,而ajax方法一般僅應(yīng)用于與服務(wù)器的少量數(shù)據(jù)交換。
from django.views.generic import ListView from .models import Article from django.shortcuts import render from .forms import SearchForm from django.http import JsonResponse # Create your views here. class ArticleListView(ListView): queryset = Article.objects.filter(status='p').order_by('-pub_date') paginate_by = 6 def article_search(request): if request.method == 'GET': form = SearchForm(request.GET) if form.is_valid(): keyword = form.cleaned_data.get("keyword") if keyword: article_list = Article.objects.filter(title__icontains=keyword) return render(request, 'blog/search.html', {'form': form, 'article_list': article_list}) else: form = SearchForm() return render(request, 'blog/search.html', {'form': form, 'article_list': False, }) def ajax_search(request): if request.method == 'GET': keyword = request.GET.get('keyword', None) if keyword: count = Article.objects.filter(title__icontains=keyword).count() data = {'count': count, } return JsonResponse(data)
我們著重看下ajax_search是如何工作的。
我們的模板blog/search.html代碼如下:
{% block content %} h3>Django Ajax實(shí)時(shí)搜索文章/h3> form method="get" action="">{% csrf_token %} {{ form }} input type="submit" value="Search" /> /form> {% endblock %} div id="result">/div> script src="https://code.jquery.com/jquery-3.1.0.min.js">/script> script> $("#id_keyword").bind('input propertychange', function() { var keyword = $(this).val(); $.ajax({ url: '/blog/ajax/search/', data: { 'keyword': keyword }, type: 'GET', dataType: 'json', success: function (data) { $("#result").html("p>正在實(shí)時(shí)查詢(xún)...共" + data.count + "條記錄/p>") }, }); }); /script> {% if article_list %} p>共找到 {{ article_list | length }} 條記錄。/p> ul> {% for article in article_list %} li>a href="{% url 'blog:article_detail' article.id %}" rel="external nofollow" > {{ article.title }}/a> {{ article.pub_date | date:"Y-m-j" }}/li> {% endfor %} /ul> {% endif %}
我們著重看下Ajax如何工作的。
下圖是實(shí)時(shí)顯示搜索結(jié)果數(shù)量的效果。隨著關(guān)鍵詞的增長(zhǎng),查詢(xún)到的結(jié)果數(shù)量越來(lái)越少。
以上就是Django利用AJAX技術(shù)實(shí)現(xiàn)博文實(shí)時(shí)搜索的詳細(xì)內(nèi)容,更多關(guān)于Django用AJAX實(shí)時(shí)搜索的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
標(biāo)簽:臺(tái)灣 景德鎮(zhèn) 欽州 喀什 黃山 濟(jì)南 宿遷 三沙
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Django利用AJAX技術(shù)實(shí)現(xiàn)博文實(shí)時(shí)搜索》,本文關(guān)鍵詞 Django,利用,AJAX,技術(shù),實(shí)現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。