婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Django利用AJAX技術實現博文實時搜索

Django利用AJAX技術實現博文實時搜索

熱門標簽:外呼不封號系統 荊州云電銷機器人供應商 幫人做地圖標注收費算詐騙嗎 悟空智電銷機器人6 溫州旅游地圖標注 電信營業廳400電話申請 蘇州電銷機器人十大排行榜 遼寧400電話辦理多少錢 江蘇房產電銷機器人廠家

學習Python Web和Django開發不能只學習Python。我們有時必需借助其它技術比如AJAX實現我們想要的功能。今天我們就要利用Django 2.0 + AJAX開發一個功能性頁面: 我們一邊輸入關鍵詞,網頁一邊會給你提示所找到的博文數量。

什么是AJAX技術?它的應用場景有哪些?

Ajax 即“Asynchronous Javascript And XML”(異步 JavaScript 和 XML),是指一種創建交互式網頁應用的網頁開發技術。通過在后臺與服務器進行少量數據交換,Ajax 可以使網頁實現異步更新。這意味著可以在不重新加載整個網頁的情況下,對網頁的某部分進行更新。

Ajax常見應用場景包括:

  • 搜索提示: 在你輸入關鍵詞還未提交前,搜索框給你提示。
  • 用戶名驗證: 當你輸入用戶名時,頁面提示你是否已注冊。
  • 顯示投票結果:用戶投票后,不用加載頁面即可顯示投票結果。
  • 評論加載: 在你提交新的評論后,不用重新加載整個網頁就會顯示新提交的評論。

以上場景都是Django單靠自己無法實現的。注意Ajax應只用于與服務器少量數據交換,且存安全隱患,不宜廣泛使用。

總體開發思路

我們創建一個叫blog的APP,并把它加入到INSTALLED_APP里去,然后在后臺添加一些文章, 用于搜索(如下所示)。我們需要設計2個功能性頁面: 一個展示博客文章清單,一個搜索頁面。

下面我們來看下具體代碼。

models.py

本案例中所用到的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', '發表'),
    )

    title = models.CharField('標題', max_length=200, unique=True)
    slug = models.SlugField('slug', max_length=60)
    body = models.TextField('正文')
    pub_date = models.DateTimeField('發布時間', default=now, null=True)
    create_date = models.DateTimeField('創建時間', auto_now_add=True)
    mod_date = models.DateTimeField('修改時間', auto_now=True)
    status = models.CharField('文章狀態', 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 = "文章"

urls.py

前文提到過我們需要設計2個功能性頁面: 一個展示博客文章清單,一個搜索。然而在urls.py里我們卻設計了3個URL。這是因為我們還要設計一個URL與AJAX進行后臺數據交換。這是用戶看不見的,后面我們會用到這個URL。當ajax發送請求到/blog/ajax/search/時,Django就會調用ajax_search方法來處理。

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'),

]

views.py

對應3個URL,我們需要在視圖里編寫3個處理方法,其中ajax_search用來給搜索頁面返回Json數據(查詢到的文章數量)。article_search方法用來返回搜索結果。我們為什么不用ajax_search返回搜索結果呢?因為查詢到的數據集可能非常大,而ajax方法一般僅應用于與服務器的少量數據交換。

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是如何工作的。

  • 當搜索頁面上ajax的通過GET發送請求時,服務器獲取ajax發送過來的keyword。
  • 如果keyword不為空,服務器查詢文章標題包含有keyword的文章數量。
  • 服務器將字典{‘count': count }轉化為Json數據格式并返回給ajax所在頁面。

模板blog/search.html

我們的模板blog/search.html代碼如下:

{% block content %}
h3>Django Ajax實時搜索文章/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>正在實時查詢...共" + 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如何工作的。

  • 當搜索框#id_keyword有屬性變化時,Ajax實時獲取#id_keyword的值,并將其通過GET方法發送至url('/blog/ajax/search')。
  • Django視圖里ajax_search方法處理ajax發來的請求,并返回json數據。
  • 如果服務器響應成功并成功發來json數據,將其顯示在id=result的DIV里。

查看效果

下圖是實時顯示搜索結果數量的效果。隨著關鍵詞的增長,查詢到的結果數量越來越少。

以上就是Django利用AJAX技術實現博文實時搜索的詳細內容,更多關于Django用AJAX實時搜索的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • Django如何與Ajax交互
  • Django與AJAX實現網頁動態數據顯示的示例代碼
  • 使用AJAX和Django獲取數據的方法實例
  • Django查詢優化及ajax編碼格式原理解析
  • 淺析Django 接收所有文件,前端展示文件(包括視頻,文件,圖片)ajax請求
  • django ajax發送post請求的兩種方法
  • django框架中ajax的使用及避開CSRF 驗證的方式詳解
  • Django中ajax發送post請求 報403錯誤CSRF驗證失敗解決方案
  • Django結合ajax進行頁面實時更新的例子
  • Django 通過JS實現ajax過程詳解

標簽:臺灣 景德鎮 欽州 喀什 黃山 濟南 宿遷 三沙

巨人網絡通訊聲明:本文標題《Django利用AJAX技術實現博文實時搜索》,本文關鍵詞  Django,利用,AJAX,技術,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Django利用AJAX技術實現博文實時搜索》相關的同類信息!
  • 本頁收集關于Django利用AJAX技術實現博文實時搜索的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日高清视频| 欧美一级在线免费| 色一情一乱一乱一91av| 久久精品人人爽人人爽| 麻豆精品一区二区三区| 99热99精品| 欧美精品一区二区三区四区| 亚洲第一会所有码转帖| 奇米色一区二区| 国产一区二区在线看| 一区二区三区精品在线观看| 91美女视频网站| 精品一区二区三区视频 | 精久久久久久久久久久| 国产成人精品免费网站| 国产精品网站导航| 亚洲视频一区二区在线观看| voyeur盗摄精品| 亚洲高清视频中文字幕| 欧美成人女星排行榜| 玖玖九九国产精品| 韩国一区二区三区| 亚洲午夜电影网| 午夜精品一区二区三区电影天堂 | 91精品国产91热久久久做人人| 久久国产欧美日韩精品| 91精品国产aⅴ一区二区| 成人一道本在线| 裸体一区二区三区| 亚洲成av人片在线观看无码| 中文字幕中文字幕一区| 日韩一区二区三区在线| 91久久久免费一区二区| 久久精品国产一区二区三| 国产精品久久久久久久久免费相片 | 国产99久久久国产精品潘金| 国产欧美一区二区三区鸳鸯浴| 美腿丝袜亚洲一区| 亚洲午夜一区二区| 精品国产免费久久| 亚洲精品国产成人久久av盗摄| 久久久亚洲精品一区二区三区| 亚洲午夜久久久久久久久电影网| 日韩三级视频在线看| 国产专区综合网| 国产精品久久久久影院老司| 欧美日韩一区三区| 97aⅴ精品视频一二三区| 亚洲综合区在线| 午夜精品久久久久久久99水蜜桃 | 欧美日韩高清一区二区| 色嗨嗨av一区二区三区| 国产精品免费观看视频| 一区二区三区成人在线视频| 在线观看中文字幕不卡| 亚洲精品在线三区| 成人永久免费视频| 久久影院午夜片一区| 美女视频一区在线观看| 91精品91久久久中77777| 欧美极品美女视频| 久久国产三级精品| 欧美成人高清电影在线| 久久99热99| 九一久久久久久| 秋霞影院一区二区| 国产精品嫩草99a| 精品日韩成人av| 国产99久久久精品| www成人在线观看| 日韩色在线观看| 欧美一卡二卡三卡| 精品国产伦一区二区三区观看方式| 色婷婷av一区二区三区大白胸| 91在线视频播放| 免费在线观看一区| 亚洲成在线观看| 久久久av毛片精品| 99久久精品一区二区| 久久精品国产色蜜蜜麻豆| 日本三级亚洲精品| 国产精品女主播av| 亚洲综合网站在线观看| 制服视频三区第一页精品| 国产精品99久| 国产成人8x视频一区二区| 99久久er热在这里只有精品66| 欧美精品123区| 精品久久久久久久人人人人传媒| 欧美日韩久久久久久| 99精品欧美一区二区三区小说 | 国产中文字幕精品| 欧美剧情片在线观看| 国产精品一区二区久久精品爱涩| 一本一道波多野结衣一区二区| 婷婷丁香久久五月婷婷| 中文字幕+乱码+中文字幕一区| 91久久一区二区| 91麻豆精品国产综合久久久久久| 色香色香欲天天天影视综合网| 亚洲国产成人va在线观看天堂 | 亚洲人成网站精品片在线观看| 亚洲一区在线看| 粉嫩aⅴ一区二区三区四区五区| 蜜桃精品视频在线| 欧美色图免费看| 亚洲国产欧美在线人成| 国产九色sp调教91| 国产精品理论在线观看| 偷窥国产亚洲免费视频| 国产精品一区二区久久精品爱涩| 欧美电影精品一区二区| 日本vs亚洲vs韩国一区三区二区| 成人午夜激情在线| **性色生活片久久毛片| 欧美视频在线不卡| 午夜不卡av免费| 欧美伊人久久久久久午夜久久久久| 亚洲欧美在线高清| 亚洲一区二区三区视频在线播放| 欧美三级电影网| 色综合久久久久网| 粉嫩欧美一区二区三区高清影视| 国产精品乱码一区二区三区软件| 色婷婷综合久色| 久久夜色精品国产欧美乱极品| 91久久线看在观草草青青| 六月婷婷色综合| 亚洲日本在线观看| 国产欧美1区2区3区| 欧美亚洲禁片免费| 秋霞成人午夜伦在线观看| 欧美精品在线视频| 亚洲精品你懂的| 国产一区二区在线观看视频| 在线观看91精品国产麻豆| 国产精品国产馆在线真实露脸| 欧美极品aⅴ影院| 欧美在线观看一二区| 成a人片国产精品| 成人综合婷婷国产精品久久蜜臀 | 成人免费视频caoporn| 亚洲妇女屁股眼交7| 亚洲三级免费电影| 精品一区精品二区高清| av中文字幕不卡| 国内精品久久久久影院薰衣草| 亚洲一二三专区| 一本色道久久综合狠狠躁的推荐| 国产精品一区二区在线观看不卡| 4hu四虎永久在线影院成人| 欧美大片在线观看一区二区| 久久免费偷拍视频| 777午夜精品免费视频| 欧美高清视频www夜色资源网| 成人午夜视频免费看| 亚洲午夜精品久久久久久久久| 日韩高清一区在线| 另类小说色综合网站| 99国产精品久久| 欧美一区二区三区思思人| 国产成人精品亚洲日本在线桃色| 99久久精品免费| 久久国产三级精品| 亚洲色图在线看| 麻豆久久一区二区| 午夜伊人狠狠久久| 精品一区二区三区av| 91在线免费播放| 韩国三级电影一区二区| 国产99久久久国产精品| 69堂亚洲精品首页| 亚洲成人三级小说| 在线成人高清不卡| 天天爽夜夜爽夜夜爽精品视频| 久久黄色级2电影| 亚洲人成精品久久久久| 久久久久国产精品人| 亚洲一区二区三区视频在线| 91在线高清观看| 色屁屁一区二区| 欧美大片免费久久精品三p| 一区二区三区在线播放| 国产网红主播福利一区二区| 国产成人小视频| 欧美成人精品1314www| 乱中年女人伦av一区二区| 99视频有精品| 天天影视色香欲综合网老头| 欧美午夜片在线观看| 国产精品久99| 国产精品一区二区三区乱码| 极品尤物av久久免费看| 亚洲高清在线视频| 欧美一区二区久久久| 成人av电影在线网| 国产福利一区在线观看| 精品一区二区三区免费毛片爱| 欧美一二三区精品| 精品一区二区三区日韩|