Django回顾 - 6 Ajax

【1】Ajax

定义:

异步Javscript和XML

作用:

Javascript语言与服务器(django)进行异步交互,传输的数据为XML(当然,传输的数据不只是XML,现在更多使用json数据)

同步交互和异步交互:

1、同步交互:js发送出请求---》直到请求回来---》页面不能操作,不能点击

2、异步交互:js发出请求---》等待请求回来的过程中--->页面可以随意继续操作

【1.1】Ajax使用

4 、使用:使用了jquery帮咱们封装的方法 ajax ,名字跟ajax相同 -------- $.ajax

5、真正的ajax原生,需要使用js操作,jq的ajax方法是对原生js的封装,方便咱们使用

-前后端混合项目中,我们通常使用jquery的ajax实现 js和后端异步交互

-jquery操作DOM

-jquery发ajax请求

-前后端分离项目中,我们会使用另一个第三方库(axios),实现 js和后端异步交互

-只想发送ajax请求---》只用来发ajax请求的库

【1.2】编码格式

  • 默认编码格式
    • urlencode
  • 文件上传编码格式
    • form-data
  • json编码格式
    • application/json

【1.3】Ajax上传文件

html 复制代码
<input type='file' name='my_file' id="files"> 

<button id="id_btn">提交</button>

$('#id_btn').click(function(){
    var formdata = new FormData()
    formdata.append('files',$('#files')[0].files[0])
    $.ajax({
        url:'',
        type:'post',
        data:formdata,
        contentType:false, //告诉jQuery不要去处理发送的数据
        processData:false, // 告诉jQuery不要去设置Content-Type请求头
        success:function(){
            
        }
    })
})

'''
Ajax上传文件格式的数据必须使用FormData函数,因为文件上传的编码格式为form-data

contentType设置为false
processData设置为false

'''

【1.4】Ajax上传json格式的数据

python 复制代码
	      $.ajax({
            url: '/demo01/',
            method: 'post',
            contentType: 'application/json',
            data: JSON.stringify({name: 'lqz', age: 19}), // 把对象转成字符串形式,json格式字符串
            success: function (data) {
                console.log(data)
            }
        })

【1.5】Ajax执行流程图

相关推荐
海市公约14 分钟前
FastAPI中间件与依赖系统实战指南
中间件·fastapi·依赖注入·异步编程·web架构·代码复用·拦截器模式
万粉变现经纪人23 分钟前
如何解决 pip install flash-attention 报错 需要 SM_80+(Ampere)架构 问题
python·架构·django·bug·virtualenv·pip·pygame
云和数据.ChenGuang1 小时前
机器学习之方差和标准差计算
人工智能·python·机器学习·django·pygame·deepseek
开开心心就好1 小时前
经典塔防游戏移植移动端随时畅玩
java·前端·科技·游戏·edge·django·pdf
8Qi81 天前
RabbitMQ高级篇:消息可靠性、幂等性与延迟消息
java·分布式·微服务·中间件·rabbitmq·springcloud
fuquxiaoguang1 天前
中间件行业产品市场洞察报告 – 2026年第一季度
中间件·市场洞察
小熊Coding1 天前
Windows 上安装 mysqlclient 时遇到了编译错误,核心原因是缺少 Microsoft Visual C++ 14.0 或更高版本 的编译环境。
c++·windows·python·microsoft·django·mysqlclient·bug记录
深兰科技1 天前
深兰科技与宝武集团旗下钢友汇达成国际市场合作,俄罗斯、巴西、阿根廷市场同步推进
人工智能·django·fastapi·pygame·httpx·视觉大模型·深兰科技
fuquxiaoguang1 天前
灰度·熵减·长期主义:任正非心智模型下的中国中间件技术突围与未来
中间件·任正非
betazhou1 天前
django+postgresql创建第一个网站
python·postgresql·django