1.简介

    AJAX(Asynchronous Javascript And XML)翻译成中文就是“异步的Javascript和XML”。即使用Javascript语言与服务器进行异步交互,传输的数据为XML(当然,传输的数据不只是XML,现在更多使用json数据)。

    AJAX 不是新的编程语言,而是一种使用现有标准的新方法。

    AJAX 最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容。(这一特点给用户的感受是在不知不觉中完成请求和响应过程)

    AJAX 不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。

      a.同步交互:客户端发出一个请求后,需要等待服务器响应结束后,才能发出第二个请求;

      b.异步交互:客户端发出一个请求后,无需等待服务器响应结束,就可以发出第二个请求。

  AJAX除了异步的特点外,还有一个就是:浏览器页面局部刷新;(这一特点给用户的感受是在不知不觉中完成请求和响应过程

 2.示例

    页面输入两个整数,通过AJAX传输到后端计算出结果并返回。

    html文件名称为ajax_demo1.html,内容如下

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="x-ua-compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1">
  7. <title>AJAX局部刷新实例</title>
  8. </head>
  9. <body>
  10.  
  11. <input type="text" id="i1">+
  12. <input type="text" id="i2">=
  13. <input type="text" id="i3">
  14. <input type="button" value="AJAX提交" id="b1">
  15.  
  16. <script src="/static/jquery-3.2.1.min.js"></script>
  17. <script>
  18. $("#b1").on("click", function () {
  19. $.ajax({
  20. url:"/ajax_add/", //别忘了加双引号
  21. type:"GET",
  22. data:{"i1":$("#i1").val(),"i2":$("#i2").val()}, //object类型,键值形式的,可以不给键加引号
  23. success:function (data) {
  24. $("#i3").val(data);
  25. }
  26. })
  27. })
  28. </script>
  29. </body>
  30. </html>

    views.py里面的内容:

  1. def ajax_demo1(request):
  2. return render(request, "ajax_demo1.html")
  3.  
  4. def ajax_add(request):
    #time.sleep(10) #不影响页面发送其他的请求
  5. i1 = int(request.GET.get("i1"))
  6. i2 = int(request.GET.get("i2"))
  7. ret = i1 + i2
  8. return JsonResponse(ret, safe=False)
    #return render(request,'index.html') #返回一个页面没有意义,就是一堆的字符串,拿到了这个页面,你怎么处理,你要做什么事情,根本就没有意义

    urls.py里面的内容

  1. urlpatterns = [
  2. ...
  3. url(r'^ajax_add/', views.ajax_add),
  4. url(r'^ajax_demo1/', views.ajax_demo1),
  5. ...
  6. ]

   启动django项目,然后运行看看效果,页面不刷新

  3.AJAX常见应用情景

    搜索引擎根据用户输入的关键字,自动提示检索关键字。

    还有一个很重要的应用场景就是注册时候的用户名的查重。

    其实这里就使用了AJAX技术!当文件框发生了输入变化时,使用AJAX技术向服务器发送一个请求,然后服务器会把查询到的结果响应给浏览器,最后再把后端返回的结果展示出来。

      a.整个过程中页面没有刷新,只是刷新页面中的局部位置而已!

      b.当请求发出后,浏览器还可以进行其他操作,无需等待服务器的响应!

    

    当输入用户名后,把光标移动到其他表单项上时,浏览器会使用AJAX技术向服务器发出请求,服务器会查询名为lemontree7777777的用户是否存在,最终服务器返回true表示名为lemontree7777777的用户已经存在了,浏览器在得到结果后显示“用户名已被注册!”。

    a.整个过程中页面没有刷新,只是局部刷新了;

    b.在请求发出后,浏览器不用等待服务器响应结果就可以进行其他操作;

  4.AJAX的优缺点

    优点:

      1.AJAX使用JavaScript技术向服务器发送异步请求;

      2.AJAX请求无须刷新整个页面;

      3.因为服务器响应内容不再是整个页面,而是页面中的部分内容,所以AJAX性能高;

例子:一个登陆认证页面,登陆失败不刷新页面,提示用户登陆失败,登陆成功自动跳转到网站首页。

  1. # html页面:
  2. {% load static %}
  3. <!DOCTYPE html>
  4. <html lang="en">
  5. <head>
  6. <meta charset="UTF-8">
  7. <title>Title</title>
  8. <link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}">
  9. </head>
  10. {#<form action="{% url 'login' %}" method="post" >#}
  11. {# {% csrf_token %}#}
  12. {# 用户名: <input type="text" name="username">#}
  13. {# 密码: <input type="password" name="password">#}
  14. {# <input type="submit">#}
  15. {##}
  16. {#</form>#}
  17. {% csrf_token %}
  18. 用户名: <input type="text" id="username">
  19. 密码: <input type="password" id="password">
  20. <button id="sub" >提交</button>
  21. <span id="error" style="color: red;, font-size: 12;"></span>
  22. </body>
  23. <script src="{% static 'js/jquery.js' %}"></script>
  24. <script>
  25. $('#sub').click(function () {
  26. var name = $('#username').val();
  27. var pw = $('#password').val();
  28. var csrf_token = $('input[name=csrfmiddlewaretoken]').val();
  29.  
  30. $.ajax({
  31. url: {% url 'login' %}, # 向哪里提交数据
  32. type: 'post', # 提交数据的方式
  33. data:{'uname':name, 'pwd':pw, 'csrfmiddlewaretoken':csrf_token}, # 提交的数据 /object类型, 键值形式,键可以不加引号
  34. success: function (response) { # response: 形参,
  35. if(response.status){
  36. $('#error').text('成功了');
  37. location.href = response.home_url;
  38. }else{
  39. $('#error').text('失败了');
  40. }
  41. }
  42.  
  43. })
  44. })
  45.  
  46. </script>
  47.  
  48. </html>
  1. # views.py
  2. from django.shortcuts import render, HttpResponse, redirect
  3. from app01 import models
  4. from django.http import JsonResponse
  5. from django.urls import reverse
  6. import json
  7.  
  8. # Create your views here.
  9.  
  10. def login(request):
  11. if request.method == "GET":
  12. return render(request, 'login.html')
  13. else:
  14. # form 表单提交数据
  15. # uname = request.POST.get('username')
  16. # pwd = request.POST.get('password')
  17. # print(uname, pwd)
  18. # return HttpResponse('ok')
  19.  
  20. a = {'status': None, 'home_url': None}
  21. uname = request.POST.get('uname')
  22. pwd = request.POST.get('pwd')
  23. print(uname, pwd)
  24.  
  25. ret = models.UserInfo.objects.filter(name=uname, pwd=pwd)
  26. if ret.exists():
  27. a['status'] = True
  28. a['home_url'] = reverse('home')
  29. a_json = json.dumps(a)
  30. # return HttpResponse(a_json, content_type='application/json')
  31. return JsonResponse(a )
  32. else:
  33. return HttpResponse('file')
  34.  
  35. def home(request):
  36.  
  37. return render(request, 'home.html')
  1. # urls.py
  2.  
  3. from django.conf.urls import url
  4. # from django.contrib import admin
  5. from app01 import views
  6. urlpatterns = [
  7. # url(r'^admin/', admin.site.urls),
  8. url(r'^login/', views.login, name='login'),
  9. url(r'^home/', views.home, name='home'),
  10.  
  11. ]

登陆失败:

登陆成功:(会跳转到home页面)

Django之初识Ajax的更多相关文章

  1. Django补充及初识Ajax

    Django创建一对多表结构 首先现在models.py中写如下代码: from django.db import models # Create your models here. class Bu ...

  2. Django(四) ORM 外键操作及初识Ajax

    一.内容回顾 1.Django请求的生命周期: ​ 路由系统 -> 视图函数(获取模板+数据 -> 渲染) -> 字符串返回给用户 2.路由系统: /index/ #-> 函数 ...

  3. Django中的Ajax

    Ajax 很多时候,我们在网页上请求操作时,不需要刷新页面.实现这种功能的技术就要Ajax!(本人定义,不可迷信) jQuery中的ajax就可以实现不刷新页面就能向后台请求或提交数据的功能,我们仍然 ...

  4. django中的ajax组件

    目录 django中的ajax 向服务器发送请求的途径 Ajax的特点 基于jquery实现的ajax请求 利用ajax实现计算器 利用ajax实现登陆认证 利用form表单进行文件上传 利用ajax ...

  5. Django框架 之 Ajax

    Django框架 之 Ajax 浏览目录 AJAX准备知识 AJAX与XML的比较 AJAX简介 jQuery实现的ajax AJAX参数 AJAX请求如何设置csrf_token 序列化 一.AJA ...

  6. Django中的Ajax详解

    AJAX(Asynchronous Javascript And XML)翻译成中文就是“异步Javascript和XML”.即使用Javascript语言与服务器进行异步交互,传输的数据为XML(当 ...

  7. Django如何与ajax通信

    示例一 文件结构 假设你已经创建好了一个Django项目和一个App,部分结构如下: mysite myapp |___views.py |___models.py |___forms.py |___ ...

  8. Django的日常-AJAX

    目录 Django的日常-AJAX AJAX简介 AJAX与JQ的一个实例 AJAX与contentType AJAX传json格式 AJAX传文件 Django的日常-AJAX AJAX简介 首先A ...

  9. Django框架09 /ajax、crsf、settings导入

    Django框架09 /ajax.crsf.settings导入 目录 Django框架09 /ajax.crsf.settings导入 1. ajax概述 2. ajax应用 3. ajax上传文件 ...

随机推荐

  1. H5中用js让页面全屏

    概述 意外的发现一个网页有一个按钮能使网页全屏,查了下代码发现是H5的全屏api,于是就查了下资料,记录下来供以后开发时参考,相信对其他人也有用. 参考资料: 利用js如何做到让页面全屏和不全屏功能 ...

  2. Node.js(day2)

    一.使用Node实现基本Apache的功能 在上一篇笔记中,我们提到如果打开一个文件需要进行一次url判断是繁琐的,我们希望我们的Node具有类似Apache这种web服务器的一个功能:将文件放到ww ...

  3. SVM算法简单应用

    第一部分:线性可分 通俗解释:可以用一条直线将两类分隔开来 一个简单的例子,直角坐标系中有三个点,A,B点为0类,C点为1类: from sklearn import svm # 三个点 x = [[ ...

  4. C语言数组一种巧妙的使用方式

    作为计算机一种比较古老的语言,它并没有随着岁月老去,而是仍旧在整个领域发挥出耀眼的光芒,就像写作,有很多光芒万丈的句子值得我们去珍藏,今天就遇到了个比较巧妙的数组使用方法,做个记录,以供后续使用. # ...

  5. python2程序移植python3的一些注意事项

    1 queue: python2: import Queue python3: import queue 2 queue size: python2: cache = Queue.Queue(maxs ...

  6. Scala - 快速学习03 - 基础语法

    1- 变量 变量 mutable variable 在程序运行过程中其值可能发生改变的量 关键词var定义变量,定义时直接进行求值 常量 immutable variable 在程序运行过程中其值不会 ...

  7. [MongoDB]Mongo基本使用

    [MongoDB]Mongo基本使用:   汇总: 1. [MongoDB]安装MongoDB2. [MongoDB]Mongo基本使用:3. [MongoDB]MongoDB的优缺点及与关系型数据库 ...

  8. sql server 备份与恢复系列三 简单恢复模式下的备份与还原

    一.概述 前面讲了备份的一些理论知识,这篇开始讲在简单恢复模式下的备份与还原.在简单模式下是不能做日志备份的,发生灾难后,数据库最后一次备份之后做的数据修改将是全部丢失的,所以在生产环境下,数据又很重 ...

  9. 【EF6学习笔记】(十二)EF高级应用场景

    本篇原文链接:Advanced Entity Framework Scenarios 本篇主要讲一些使用Code First建立ASP.NET WEB应用的时候除了基础的方式以外的一些扩展方式方法: ...

  10. Spring mybatis源码篇章-MapperScannerConfigurer关联dao接口

    前言:Spring针对Mybatis的XML方式的加载MappedStatement,通过引入MapperScannerConfigurer扫描类来关联相应的dao接口以供Service层调用.承接前 ...