前端知识笔记(三十七)———Django与Ajax

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 前端知识笔记(三十七)———Django与Ajax

特点:

       异步提交

       局部刷新

例子:github注册

动态获取用户名实时的跟后端确认并实时的展示到前端(局部刷新)

朝后端发送请求的方式

       1.浏览器地址栏直接输入url回车 -----》get请求

       2.a标签的href属性  -----》get请求

       3.form表单 -----》get请求、post请求

       4.ajax -----》 get请求、post请求

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

(其他框架也可以,原理是一样的)

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

       jq操作dom

       jq发ajax请求

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

 

写一个例子:

页面上有三个input框,前两个框输入数字,点击提交,朝后端发送ajax请求,后端计算出结果再返回给前端,动态展示到第三个input框中,整个页面不能刷新,也不能在前端计算

html代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<input type="text" id="d1">+<input type="text" id="d2">=<input type="text" id="d3">
<button id="btn">提交</button>
<script>
    // 先给按钮一个点击事件
    $('#btn').click(function (){
        // 朝后端发送ajax请求
        $.ajax({
            // 1.指定朝哪个后端发送ajax请求
            url:'', // 不写就是朝当前地址提交
            // 2.请求方式
            type:'post', // 不指定就是get,都是小写
            // 3.数据
            data:{'l1':$('#d1').val(),'l2':$('#d2').val()},
            // 4.回调函数:当后端给你返回结果的时候会自动触发 args接收后端返回的结果
            success:function (args) {
                $('#d3').val(args)
            }
        })
    })
</script>
</body>
</html>

views代码

from django.shortcuts import render,HttpResponse
def ab_ajax(request):
    if request.method=='POST':
        l1 = request.POST.get('l1')
        l2 = request.POST.get('l2')
        #先转成整型再加
        l3=int(l1)+int(l2)
        return HttpResponse(l3)
    return render(request,'ajax.html')

前后端传输数据的编码格式(contentType)

因为get请求数据就是直接放在url后面的(url?user=kk$pwd=123),所以主要看下post请求的编码格式


向后端发送post请求的方式

       1.form表单


       2.ajax请求


前后端传输数据的编码格式

      urlencoded


       formdata


       json


       form表单


默认的编码格式是urlencoded


数据格式:user=kk&pwd=123        


Django后端针对符合urlencoded编码格式的数据会自动帮你解析封装到request.POST中


user=kk&pwd=123     --------》   request.POST


如果把编码格式改成formdata,那么针对普通的键值对还是解析到request.POST中, 而将文件解析到request.FILES中


form表单是没办法发送json格式数据的


ajax默认的编码格式是urlencoded


ajax发送json格式数据

html代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<button id="d1">点我</button>
<script>
    $('#d1').click(function () {
        $.ajax({
            url:'',
            type:'post',
            data:JSON.stringify({'username':'kk','age':12}),
            contentType:'application/json',  //指定编码格式
            success:function () {
            }
        })
    })
</script>
</body>
</html>

views代码

import json
from django.shortcuts import render
def login(request):
    return render(request,'login.html')
def ab_json(request):
    #针对json格式的数据需要自己手动处理
    if request.is_ajax(): #判断是不是ajax的请求
        json_bytes=request.body #拿到一个字符串类型
        json_dict=json.loads(json_bytes)  #传入的二进制的数据会内部自动解码再反序列化
        print(json_dict)
    return render(request,'ab_json.html')

ajax发送json格式数据需要注意点


       1.contentType参数指定成:applicaton/json


       2.数据是真正的json格式数据


       3.Django后端不会帮你处理json格式数据,需要你自己去request.body获取并处理

ajax发送文件

1.  ajax发送文件需要借助于js内置对象FormData

html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<p>username<input type="text" id="d1"></p>
<p>password<input type="text" id="d2"></p>
<p><input type="file" id="d3"></p>
<button id="d4">点我</button>
<script>
    //点击按钮朝后端发送普通键值对和文件数据
    $('#d4').on('click',function () {
        //需要先利用FormData内置对象
        let formDataObj=new FormData();
        //2 添加普通的键值对
        formDataObj.append('username',$('#d1').val());
        formDataObj.append('password',$('#d2').val());
        //3添加文件对象
        formDataObj.append('myfile',$('#d3')[0].file[0]);
        //4将对象基于发送给后端
        $.ajax({
            url:'',
            type:'post',
            data:formDataObj, //直接将对象放在data后面即可
            //ajax发送文件必须指定两个参数
            contentType:false, //不需使用任何编码,Django后端都能自动识别formdata对象
            processData: false, //告诉你的浏览器不要对你的数据进行任何处理
            success:function () {
            }
        })
    })
</script>
</body>
</html>

2.  ajax发送文件必须指定两个参数:

           contentType:false,  //不需使用任何编码,Django后端都能自动识别formdata对象

           processData: false,  //告诉你的浏览器不要对你的数据进行任何处理

3.  Django后端能够直接识别formdata对象并且能够将内部的普通键值自动解析并封装到request.POST中,文件数据自动解析并封装到request.FILES中

相关文章
|
30天前
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
127 2
|
30天前
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
37 0
|
2月前
|
前端开发 API UED
Python后端与前端交互新纪元:AJAX、Fetch API联手,打造极致用户体验!
Python后端与前端交互新纪元:AJAX、Fetch API联手,打造极致用户体验!
86 2
|
29天前
|
前端开发 JavaScript
回顾前端页面发送ajax请求方式
回顾前端页面发送ajax请求方式
36 18
|
30天前
|
人工智能 自然语言处理 运维
前端大模型应用笔记(一):两个指令反过来说大模型就理解不了啦?或许该让第三者插足啦 -通过引入中间LLM预处理用户输入以提高多任务处理能力
本文探讨了在多任务处理场景下,自然语言指令解析的困境及解决方案。通过增加一个LLM解析层,将复杂的指令拆解为多个明确的步骤,明确操作类型与对象识别,处理任务依赖关系,并将自然语言转化为具体的工具命令,从而提高指令解析的准确性和执行效率。
|
30天前
|
存储 弹性计算 算法
前端大模型应用笔记(四):如何在资源受限例如1核和1G内存的端侧或ECS上运行一个合适的向量存储库及如何优化
本文探讨了在资源受限的嵌入式设备(如1核处理器和1GB内存)上实现高效向量存储和检索的方法,旨在支持端侧大模型应用。文章分析了Annoy、HNSWLib、NMSLib、FLANN、VP-Trees和Lshbox等向量存储库的特点与适用场景,推荐Annoy作为多数情况下的首选方案,并提出了数据预处理、索引优化、查询优化等策略以提升性能。通过这些方法,即使在资源受限的环境中也能实现高效的向量检索。
|
30天前
|
机器学习/深度学习 弹性计算 自然语言处理
前端大模型应用笔记(二):最新llama3.2小参数版本1B的古董机测试 - 支持128K上下文,表现优异,和移动端更配
llama3.1支持128K上下文,6万字+输入,适用于多种场景。模型能力超出预期,但处理中文时需加中英翻译。测试显示,其英文支持较好,中文则需改进。llama3.2 1B参数量小,适合移动端和资源受限环境,可在阿里云2vCPU和4G ECS上运行。
|
30天前
|
前端开发 算法 测试技术
前端大模型应用笔记(五):大模型基础能力大比拼-计数篇-通义千文 vs 文心一言 vs 智谱 vs 讯飞vsGPT
本文对比测试了通义千文、文心一言、智谱和讯飞等多个国产大模型在处理基础计数问题上的表现,特别是通过链式推理(COT)提示的效果。结果显示,GPTo1-mini、文心一言3.5和讯飞4.0Ultra在首轮测试中表现优秀,而其他模型在COT提示后也能显著提升正确率,唯有讯飞4.0-Lite表现不佳。测试强调了COT在提升模型逻辑推理能力中的重要性,并指出免费版本中智谱GLM较为可靠。
前端大模型应用笔记(五):大模型基础能力大比拼-计数篇-通义千文 vs 文心一言 vs 智谱 vs 讯飞vsGPT
|
2月前
|
SpringCloudAlibaba JavaScript 前端开发
谷粒商城笔记+踩坑(2)——分布式组件、前端基础,nacos+feign+gateway+ES6+vue脚手架
分布式组件、nacos注册配置中心、openfegin远程调用、网关gateway、ES6脚本语言规范、vue、elementUI
谷粒商城笔记+踩坑(2)——分布式组件、前端基础,nacos+feign+gateway+ES6+vue脚手架
|
2月前
|
前端开发 数据库 数据安全/隐私保护