• Ajax基础(应用场景|jquery实现Ajax|注意事项|Ajax发送json数据|Ajax携带文件数据)


    一、Ajax简介

    AJAX(Asynchronous Javascript And XML)翻译成中文就是“异步Javascript和XML”。即使用Javascript语言与服务器进行异步交互也是用XML进行数据传输(当然,传输的数据不只是XML,目前更多的使用Json数据)。
    (XML应用于Web开发的许多方面,常用于简化数据的存储和共享)

    	AJAX不是什么新的编程语言,而是一种使用现有标准的新方法
    	AJAX最大的优点就是不需要重新加载整个页面的情况下,可以与服务器交换数据并更新网页内容
    	(简单来说就是,在网页前端刚输入完数据,后端其实已经验证完数据了,不需要等点击提交了)
    	AJAX不需要任何浏览器插件,但需要用户运行Javascript在浏览器上执行
    
    	1.AJAX使用Javascript技术向服务器发公司异步请求
    	2.AJAX请求无需刷新整个页面
    	3.因为服务器响应内容不再是整个页面,而是页面中的部分内容,所以AjAX性能高。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

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

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


    常见的使用场景
    在这里插入图片描述

    注册用户时,会根据用户输入的命令关键字,自动提示改关键字是否通过检验

    很多网站注册的时候都会使用到AJAX技术,当文本框发生了输入变化时,使用AJAX技术向服务器发送一个请求,然后服务器会把查询到的结果响应到的结果响应给浏览器,期间浏览器是不用刷新的,最后把后端返回的结果展示出来。

    • 整个过程中页面没有刷新,只是刷新了页面中的局部位置
    • 当请求发出后,浏览器还可以进行其他操作,无需等待服务器的响应

    二、基于jquery实现Ajax

    目前Ajax一般不会使用原生Javascript来编写,因为需要考虑不同浏览器的兼容性。我们这里通过jquery来实现,更简单、不需要考虑不同浏览器引发的兼容问题。

    过程:我们通过在前端向一个URL发送Ajax请求,来让后端处理这个请求后返回数据给Ajax接收。

    这里用一个案例来代入:
    通过Ajax,实现前端输入两个数字,服务器做加法,返回到前端页面

    先在Django配置路由

    	from django.conf.urls import url
    	from django.contrib import admin
    	from app import views
    	
    	urlpatterns = [
    	    url(r'^admin/', admin.site.urls),
    	    url(r'^index/', views.index),
    	    url(r'^sum/', views.sums),  # ajax会向这个路由提交请求,执行sums视图函数
    	]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    注意:一定要在settings.py配置文件里面注释中间件的一行内容
    在这里插入图片描述
    这行代码的作用后续在讲解,目前先注释掉,不然请求会提交不成功!


    views.py处理请求

    	from django.shortcuts import render,HttpResponse
    	
    	def index(request):  # 返回一个index页面
        	return render(request,'index.html')
    
    	def sums(request):  # 处理ajax请求
    	    num1 = int(request.POST.get('num1'))
    	    num2 = int(request.POST.get('num2'))
    	    return HttpResponse(num1+num2)  # 返回计算后的值
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    index.html文件,定义Ajax与后端进行交互

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script>
        <link href="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css" rel="stylesheet">
        <script src="https://cdn.bootcdn.net/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script>
        <style>
            *{
                margin-top:20px;
                margin-left:20px;
            }
        </style>
    </head>
    <body>
    <input type="text" id="num1" placeholder="数字1">+
    <input type="text" id="num2" placeholder="数字2">=
    <input type="text" id="num3" placeholder="总和">
    
    <button id="btn">计算</button>
    
    
    <script>
        $('#btn').click(function (){  // 当按钮被点击时触发一个匿名函数
            var num1 = $('#num1').val()  // 点击按钮后获取id属性值为num1的值
            var num2 = $('#num2').val()  // 点击按钮后获取id属性值为num2的值
            $.ajax({  // 定义ajax发送请求
                url:'/sum/',  // 请求发送的地址  有三种填写方式,与form标签的action一致
                method:'post',  // 请求发送的方式
                data: {'num1':num1,'num2':num2},  // 请求携带的数据
                success:function(data){  // 异步等待,当后端响应成功会回调执行匿名函数,并将数据传递给data参数
                    $('#num3').val(data)  // 将数据设置给id属性值为num3的文本框
                }// 使用ajax交互,那么后端返回的数据会被data接收,不在直接影响整个浏览器页面
    
            })
        })
    </script>
    </body>
    </html>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40

    我们已经编写好了一个简单的小案例,通过Ajax向后端发送请求,后端处理完数据响应给Ajax,再将得到的数据在页面使用以此来达到局部更新页面效果。而form表单要达到这一效果需要全局更新数据,使用重定向来实现。

    得到的结果:
    在这里插入图片描述


    三、使用Ajax注意的问题

    1.Ajax不要与form表单同时提交

    • 如果在form表单中,写了button按钮或者input是submit类型的话,点击会触发form表单的提交。
    • 如果点击按钮既触发Ajax又触发了form表单的提交,那么就会发送两个请求,导致页面数据可能错乱或者不显示问题。
    • 要是无可避免同时使用Ajax提交form表单下的表单控件时,form表单内的input按钮请使用button类型,这样该按钮绑定了Ajax请求的话,就只会提交Ajax请求,而不是form
    	<!--这种类型的按钮,无法触发form表单的提交-->
    	<input type="button" value="提交">
    	
    	<!--如果该button在form内,则会触发form表单的提交-->
    	<button>提交</button>
    
    • 1
    • 2
    • 3
    • 4
    • 5

    2.后端响应格式问题

    • 后端如果是通过非JsonResponse返回值的话,响应格式为text/html,前端得到数据后需要手动转换成对象的形式。
        if request.is_ajax():
            import json
            d = {'name':'jack','age':18}
            d_json = json.dumps(d,ensure_ascii=False)
            return HttpResponse(d_json)
    
    • 1
    • 2
    • 3
    • 4
    • 5

    就算我们在后端已经将字典转换成了Json格式,但是通过HttpResponse返回以后,还是变成了一堆字符串到前端,并且响应格式为:text/html

    <button id="btn">点击发送Ajax请求</button>
    <script>
       $('#btn').click(function(){
           $.ajax({
               url:'/home/',
               method:'post',
               data:{'name':'tom'},
               success:function (data){
                   console.log(data)
                   console.log(data.name)  // 如果返回的是Json的话这样是可以打印出来的
               }
           })
       })
    </script>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    查看后端响应的数据格式:

    在这里插入图片描述
    控制台结果:
    在这里插入图片描述
    需要在前端手动将数据转换成JSON格式,那么下次就会先将数据转换成JSON,然后再打印了

    	success:function (data){
    		data = JSON.parse(data)
    		console.log(data)
    		console.log(data.name)
    	}
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 如果我们是通过JsonResponse返回的话,那么响应状态码就会是application/json,并且在Ajax内接收到的也会是一个JSON格式的数据
    	from django.http import JsonResponse
    	def home(request):
    	    if request.is_ajax():
    	        import json
    	        d = {'name':'jack','age':18}
    	        return JsonResponse(d)
    	    return render(request,'home.html')
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    Ajax内接收到以后不需要手动转换成JSON格式

    	success:function (data){
    	    console.log(data)
    	    console.log(data.name)
       }
    
    • 1
    • 2
    • 3
    • 4

    查看响应头编码格式
    在这里插入图片描述
    控制台打印效果:
    在这里插入图片描述

    总结:

    1. 后端如果使用retrun JsonResponse(d),前端不能反序列化,直接当成对象使用
    2. 后端使用return HttpResponse(d),前端需要自己反序列化:data=JSON.parse(data)
    3. 后端使用return HttpResponse(d),前端不反序列化,需要指定参数:datatype:‘json’

    3、使用了Ajax作为请求后的注意事项

    • 后端不要返回render、redirect、HttpResponse。因为这些内容会被统一当做字符串返回给Ajax
    	def test(request):
        if request.is_ajax():
            return render(request,'login.html')
    
        return render(request,'test.html')
    
    • 1
    • 2
    • 3
    • 4
    • 5

    控制台打印效果:
    在这里插入图片描述

    总结:使用了AJax作为请求以后,建议使用JsonResponse返回数据,虽说最终还是通过HttpResponse返回到web的,但是JsonResponse内部就做了响应格式的转换

    在这里插入图片描述

    这种和我们直接通过HttpResponse返回一个JSON格式数据是不一样的。AJax只会根据响应码来做处理


  • 相关阅读:
    STM32 堆栈空间分布
    docker-compose搭建
    虚谷数据库-定时作业
    生产环境数据库表迁移实践集锦
    常见国密算法简介
    oracle数据库老是死 怎么处理?
    优思学院|看板方式与传统生产方式的对比
    SpringBoot+Vue“咱村那些事”乡村基层信息采集系统
    Vue | Vue 核心 +
    Redis笔记
  • 原文地址:https://blog.csdn.net/achen_m/article/details/134513175