当前位置: 首页 > news >正文

django Ajax--前后端数据交互

一.Django的Ajax和JavaScript的Ajax

Django的Ajax和JavaScript的Ajax实质上是指同一种技术,即异步JavaScript和XML(Asynchronous JavaScript and XML)。它允许在不刷新整个页面的情况下,通过前后端之间的异步交互来获取或发送数据。

区别在于角色和层次:

Django的Ajax:
Django的Ajax通常是指在Django框架中使用Ajax技术的方式。在Django中,使用Ajax时,您需要创建处理Ajax请求的视图函数,并在其中返回JSON数据或HTML片段。通常,Ajax请求将通过Django的URL映射和视图函数进行处理,视图函数处理完数据后,返回JsonResponse或HTML片段,然后前端通过JavaScript来接收和处理这些数据。Django的Ajax技术是Django框架与JavaScript之间的交互方式。

JavaScript的Ajax:
JavaScript的Ajax是指在纯JavaScript代码中使用Ajax技术的方式。使用JavaScript的Ajax时,您直接在前端的JavaScript代码中使用XMLHttpRequest对象(或者更常见的现代浏览器中的fetch API)来发送HTTP请求到后端,并处理返回的数据。这种方式不依赖于任何特定的后端框架,可以与任何服务器进行交互,而不仅仅是Django。

总的来说,Django的Ajax和JavaScript的Ajax都是指实现异步交互的方式,但前者是在Django框架中使用Ajax技术,后者是在纯JavaScript代码中使用Ajax技术。无论哪种方式,都可以实现前后端之间的异步数据交互,让页面实时地获取或发送数据,而无需刷新整个页面。

二.django ajax方法

在Django ajax中,GET方法和POST方法是HTTP请求的两种常用方式。
GET方法:

GET方法用于从服务器获取数据。当使用GET请求时,请求的数据会附加在URL的查询参数中,以键值对的形式传递给服务器。例如:/search/?q=keyword。
使用GET方法时,数据会暴露在URL中,因此不适合传递敏感数据。GET请求也有长度限制,不适合传递较大量的数据。
在Django中,通过request.GET对象可以获取GET请求中的参数。

POST方法:

POST方法用于向服务器提交数据,这些数据不会暴露在URL中,而是通过请求的消息体传递给服务器。因此,POST方法适合传递较大量或敏感的数据。
使用POST方法时,数据不受URL长度限制,可以传递更多数据。
在Django中,通过request.POST对象可以获取POST请求中的参数。

from django.shortcuts import render
from django.http import JsonResponsedef my_view(request):# 处理GET请求if request.method == 'GET':search_query = request.GET.get('q', '')  # 获取名为'q'的查询参数return render(request, 'search_results.html', {'query': search_query})# 处理POST请求if request.method == 'POST':data = request.POST.get('data', '')  # 获取名为'data'的POST参数return JsonResponse({'message': 'Data received successfully', 'data': data})

my_view视图函数处理了GET和POST请求。对于GET请求,它从查询参数中获取搜索关键字,并将其传递给模板进行渲染。对于POST请求,它从POST参数中获取名为’data’的数据,并返回一个JSON响应表示数据接收成功。

需要注意的是,在处理POST请求时,如果需要获取表单数据或JSON数据等,需要确保前端请求中的Content-Type头正确设置为application/x-www-form-urlencoded(常用表单数据)或application/json(JSON数据),以便Django正确解析POST参数。如果是使用Ajax发送POST请求,通常会自动设置正确的Content-Type头。另外,在表单中使用Django的{% csrf_token %}标签来处理POST请求时,也需要确保表单中包含csrfmiddlewaretoken字段,以通过CSRF保护。

三.Ajax的POST

使用Ajax的POST方法向后端发送数据,可以使用ajax方法或者现代浏览器中的fetch API。

使用jQuery的ajax方法:
假设我们有一个后端视图函数save_data,用于接收并处理前端发送的数据。

views.py:

from django.http import JsonResponsedef save_data(request):if request.method == 'POST':data = request.POST.get('data', None)if data is not None:# 在这里处理接收到的数据,例如保存到数据库等# 这里假设我们将数据原样返回给前端return JsonResponse({'message': 'Data received successfully'})return JsonResponse({'message': 'Invalid request'})

urls.py:

from django.urls import path
from . import viewsurlpatterns = [path('save_data/', views.save_data, name='save_data'),
]

在前端,我们通过$.ajax方法将数据发送到/save_data/URL:

index.html:

<!DOCTYPE html>
<html>
<head><title>Django Ajax POST Example</title><script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
</head>
<body><div><input type="text" id="dataInput"><button id="saveButton">Save Data</button></div><div id="resultContainer"></div><script>$(document).ready(function() {$('#saveButton').click(function() {// 获取用户输入的数据const inputData = $('#dataInput').val();// 使用Ajax发送POST请求$.ajax({url: '/save_data/',type: 'POST',data: {'data': inputData},success: function(data) {// 当成功保存数据后,将后端返回的消息显示在页面上$('#resultContainer').html('<p>' + data.message + '</p>');},error: function(error) {console.log('Error:', error);}});});});</script>
</body>
</html>

使用现代浏览器的fetch API:
与$.ajax方法类似,使用fetch API也可以向后端发送POST请求。

index.html:

<!DOCTYPE html>
<html>
<head><title>Django Ajax POST Example</title>
</head>
<body><div><input type="text" id="dataInput"><button id="saveButton">Save Data</button></div><div id="resultContainer"></div><script>document.addEventListener('DOMContentLoaded', function() {document.getElementById('saveButton').addEventListener('click', function() {// 获取用户输入的数据const inputData = document.getElementById('dataInput').value;// 使用fetch API发送POST请求fetch('/save_data/', {method: 'POST',headers: {'Content-Type': 'application/json','X-CSRFToken': getCookie('csrftoken') // 在Django中,需要在POST请求头中添加CSRF token},body: JSON.stringify({'data': inputData})}).then(response => response.json()).then(data => {// 当成功保存数据后,将后端返回的消息显示在页面上document.getElementById('resultContainer').innerHTML = '<p>' + data.message + '</p>';}).catch(error => {console.error('Error:', error);});});});// 获取CSRF token的函数function getCookie(name) {let cookieValue = null;if (document.cookie && document.cookie !== '') {const cookies = document.cookie.split(';');for (let i = 0; i < cookies.length; i++) {const cookie = cookies[i].trim();if (cookie.substring(0, name.length + 1) === (name + '=')) {cookieValue = decodeURIComponent(cookie.substring(name.length + 1));break;}}}return cookieValue;}</script>
</body>
</html>

无论是使用ajax方法还是fetch API,都可以通过POST请求将数据发送到后端,然后在视图函数中进行处理。请确保在前端的HTML文件中引入了jQuery库(如果使用$.ajax方法)或者使用了现代浏览器中的fetch API。同时,如果使用Django的CSRF保护,请在POST请求头中添加CSRF token。

四.Ajax的GET方法

使用Ajax的GET方法向后端发送数据较为简单,只需要在URL中添加查询参数即可。以下是使用Ajax的GET方法向后端发送数据的示例:

假设我们有一个后端视图函数process_data,用于接收并处理前端发送的数据。

views.py:

from django.http import JsonResponsedef process_data(request):if request.method == 'GET':data = request.GET.get('data', None)if data is not None:# 在这里处理接收到的数据,例如保存到数据库等# 这里假设我们将数据原样返回给前端return JsonResponse({'message': 'Data received successfully', 'data': data})return JsonResponse({'message': 'Invalid request'})

urls.py:

from django.urls import path
from . import viewsurlpatterns = [path('process_data/', views.process_data, name='process_data'),
]

在前端,我们通过$.ajax方法将数据发送到/process_data/URL:

index.html:

<!DOCTYPE html>
<html>
<head><title>Django Ajax GET Example</title><script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
</head>
<body><div><input type="text" id="dataInput"><button id="sendButton">Send Data</button></div><div id="resultContainer"></div><script>$(document).ready(function() {$('#sendButton').click(function() {// 获取用户输入的数据const inputData = $('#dataInput').val();// 使用Ajax发送GET请求$.ajax({url: '/process_data/',type: 'GET',data: {'data': inputData},success: function(data) {// 当成功发送数据后,将后端返回的消息和数据显示在页面上$('#resultContainer').html('<p>' + data.message + '</p><p>Received Data: ' + data.data + '</p>');},error: function(error) {console.log('Error:', error);}});});});</script>
</body>
</html>

在上述示例中,我们使用了ajax方法来发送GET请求到/process_data,通过URL的查询参数传递数据。当成功发送数据后,我们将后端返回的消息和数据显示在页面上。

请注意,使用Ajax的GET方法向后端发送数据时,数据将通过URL中的查询参数传递。如果需要传递更大量的数据或敏感数据,建议使用POST方法,并在POST请求体中传递数据。

五.模板引擎

前端获取后端发送的数据可以通过模板引擎

Django的模板引擎允许将后端传递的数据直接渲染到HTML模板中,然后将整个渲染后的页面发送到前端。在视图函数中,可以将数据作为字典传递给模板,然后在模板中使用模板语法进行数据渲染。例如:
views.py:

from django.shortcuts import renderdef my_view(request):data = {'message': 'Hello from the server!','user_name': 'John Doe','age': 30,}return render(request, 'my_template.html', context=data)

my_template.html:

<!DOCTYPE html>
<html>
<head><title>My Template</title>
</head>
<body><h1>{{ message }}</h1><p>User Name: {{ user_name }}</p><p>Age: {{ age }}</p>
</body>
</html>

有些情况下还需要使用json方式来传递:

views.py

return render(request, 'song_list.html',{ "songs_json": json.dumps(song_list)})

在views.py中,song_list是一个Python列表或字典等数据结构,然后通过json.dumps()函数将其转换为JSON格式的字符串。然后,使用render函数将这个JSON字符串传递给模板 song_list.html
index.html

var songs = JSON.parse('{{ songs_json  | safe }}'); 

在index.html中,使用JSON.parse(‘{{ songs_json | safe }}’)来接收从后端传递的JSON字符串。在这里,{{ songs_json | safe }}是Django模板语法,safe过滤器用于确保JSON字符串中的特殊字符不会被转义。通过这个表达式,后端传递的JSON字符串将被嵌入到JavaScript代码中。

然后,JSON.parse()函数会解析这个JSON字符串,并将其转换为对应的JavaScript对象,存储在变量 songs 中。现在,songs 就成为了一个JavaScript对象,您可以在前端的脚本代码中使用这个对象,访问其中的属性和数据。

相关文章:

django Ajax--前后端数据交互

一.Django的Ajax和JavaScript的Ajax Django的Ajax和JavaScript的Ajax实质上是指同一种技术&#xff0c;即异步JavaScript和XML&#xff08;Asynchronous JavaScript and XML&#xff09;。它允许在不刷新整个页面的情况下&#xff0c;通过前后端之间的异步交互来获取或发送数据…...

【嵌入式学习笔记】嵌入式入门1——GPIO

1.什么是GPIO General Purpose Input Output&#xff0c;即通用输入输出端口&#xff0c;简称GPIO&#xff0c;作用是负责采集外部器件的信息或者控制外部器件工作&#xff0c;即输入输出。 2.STM32 GPIO简介 2.1.GPIO特点 不同型号&#xff0c;IO口数量可能不一样&#x…...

[SQL挖掘机] - 多表连接: union

介绍: sql中的union是用于合并两个或多个select语句的结果集的操作符。它将多个查询的结果合并成一个结果集&#xff0c;并自动去除重复的行。请注意&#xff0c;union操作要求被合并的查询返回相同数量和类型的列。 用法: union的基本语法如下&#xff1a; select_stateme…...

AI面试官:SQL Server数据库(三)

AI面试官:SQL Server数据库(三) 当涉及到.NET工程师中关于SQL Server数据库的面试题时,主要考察候选人的数据库知识、SQL查询能力、数据库设计和优化等方面。 文章目录 AI面试官:SQL Server数据库(三)31. 数据库并发控制是什么?数据库有哪些常见的并发控制机制?32. 什…...

python刑事案卷图片转pdf

分两步&#xff0c;第一步是转图片&#xff0c;第二步是合并。 # -*- coding: utf-8 -*- import glob,os from PIL import Imagedef convert_to_pdf(path):# 打开图片文件img Image.open(path)# 将图片转换为 PDF&#xff0c;并保存到同名文件pdf_path os.path.splitext(path…...

vue使用driver.js完成页面引导的功能

需求&#xff1a;给客户做一个页面引导&#xff0c;教客户怎么做 效果&#xff1a; driverjs官方文档 一.安装driver.js # Using npm npm install driver.js# Using pnpm pnpm install driver.js# Using yarn yarn add driver.js 二.在自己需要引导的页面上引入driver.js i…...

学习中遇到的好博客

c日志工具之——log4cpp ECU唤醒的本质就是给ECU供电。 小文件&#xff1a;零拷贝技术 传输大文件&#xff1a;异步 IO 、直接 IO&#xff1a;如何高效实现文件传输&#xff1a;小文件采用零拷贝、大文件采用异步io直接io (123条消息) Linux网络编程 | 彻底搞懂…...

在CSDN学Golang云原生(Kubernetes集群安全)

一&#xff0c;ABAC授权模式 Kubernetes ABAC&#xff08;Attribute-Based Access Control&#xff09;授权模式是一种基于属性的访问控制模型&#xff0c;它可以根据用户或组的属性决定是否允许他们访问 Kubernetes 集群中的资源。 在使用 ABAC 授权模式时&#xff0c;管理员…...

浅谈深度神经网络

Deep neural networks are completely flexible by design, and there really are no fixed rules when it comes to model architecture. -- David Foster 前言 神经网络 (neural network) 受到人脑的启发&#xff0c;可模仿生物神经元相互传递信号。神经网络就是由神经元组成…...

『C语言初阶』第六章-操作符详解

前言 今天小羊又来为铁汁们更新C语言初阶的操作符详解&#xff0c;我们在平时写代码时总会写到一些算术操作符和赋值操作符&#xff0c;可是当铁汁们遇到其他的操作符时&#xff0c;就会望而却步&#xff0c;甚至写出一些bug&#xff0c;所以这期我给铁汁们带来新鲜出炉的操作…...

企业知识文档管理+群晖nas安全云存储

企业知识管理系统&#xff0c;利用软件系统或其他工具的企业管理方法&#xff0c;利用软件系统或其他工具&#xff0c;对组织中大量的有价值的方案、策划、成果、经验等知识进行分类存储和管理&#xff0c;积累知识资产避免流失&#xff0c;促进知识的学习、共享、培训、再利用…...

​《吐血整理》进阶系列教程-拿捏Fiddler抓包教程(9)-Fiddler如何设置捕获Https会话​

1.简介 由于近几年来各大网站越来越注重安全性都改成了https协议&#xff0c;不像前十几年前直接是http协议直接裸奔在互联网。还有的小伙伴或者童鞋们按照上一篇宏哥的配置都配置好了&#xff0c;想大展身手抓一下百度的包&#xff0c;结果一试傻眼了&#xff0c;竟然毛都没有…...

对比CahtGPT Bard Claude2对中文的理解

对比CahtGPT Bard Claude2对中文的理解 今天简单测试了一下目前这三个很火的模型对中文的理解能力 简单问题 鲁迅和周树人的关系 Bard CahtGPT Claude 介绍一下平凡的世界这本书 Bard CahtGPT...

安全测试国家标准解读——并发程序安全

本系列文章主要围绕《GB/T 38674—2020 信息安全技术 应用软件安全编程指南》进行讲解&#xff0c;该标准是2020年4月28日&#xff0c;由国家市场监督管理总局、国家标准化管理委员会发布&#xff0c;2020年11月01日开始实施。我们对该标准中一些常见的漏洞进行了梳理&#xff…...

《吐血整理》进阶系列教程-拿捏Fiddler抓包教程(12)-Fiddler设置IOS手机抓包,你知多少???

1.简介 Fiddler不但能截获各种浏览器发出的 HTTP 请求&#xff0c;也可以截获各种智能手机发出的HTTP/ HTTPS 请求。 Fiddler 能捕获Android 和 Windows Phone 等设备发出的 HTTP/HTTPS 请求。同理也可以截获iOS设备发出的请求&#xff0c;比如 iPhone、iPad 和 MacBook 等苹…...

MySQL中锁的简介——行级锁

1.行级锁概念及分类 可通过以下语句查看意向锁和行锁的加锁情况&#xff1a; select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from performance_schema.data_locks;InnoDB的行锁是针对于索引加的锁&#xff0c;不通过索引条件检索数据&#xff0…...

4 个最常见的自动化测试挑战及应对措施

有人说&#xff1a;“杂乱无章的自动化只会带来更快的混乱。”不仅更快&#xff0c;而且是更严重、更大的混乱。如果使用得当&#xff0c;自动化可以成为测试团队中令人惊叹的生产力助推器和系统的质量增强器。自动化测试的关键是要正确运用&#xff0c;这是初始最困难的部分。…...

23款奔驰GLE450豪华型升级AMG直瀑式中网,战斗感立马提升了一个档次

奔驰GLE450豪华型升级AMG竖杠中网前进气格栅&#xff0c;AMG中网竖杠格栅&#xff0c;镀铬饰条呈圆弧状&#xff0c;色泽均衡&#xff0c;质感顺滑&#xff0c;极富冲击力。AMG专属字标&#xff0c;与中网卡扣装配紧密&#xff0c;凸显AMG的身份象征&#xff0c;点睛之笔又不显…...

ALLEGRO之Logic

本文主要讲述ALLEGRO的Logic菜单。 &#xff08;1&#xff09;Net Logic&#xff1a;暂不清楚&#xff1b; &#xff08;2&#xff09;Net Schedule&#xff1a;暂不清楚&#xff1b; &#xff08;3&#xff09;AssignDifferential Pair&#xff1a;暂不清楚&#xff1b; &a…...

算法leetcode|64. 最小路径和(rust重拳出击)

文章目录 64. 最小路径和&#xff1a;样例 1&#xff1a;样例 2&#xff1a;提示&#xff1a; 分析&#xff1a;题解&#xff1a;rust&#xff1a;go&#xff1a;c&#xff1a;python&#xff1a;java&#xff1a; 64. 最小路径和&#xff1a; 给定一个包含非负整数的 m x n 网…...

【磁盘】每天掌握一个Linux命令 - iostat

目录 【磁盘】每天掌握一个Linux命令 - iostat工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景 注意事项 【磁盘】每天掌握一个Linux命令 - iostat 工具概述 iostat&#xff08;I/O Statistics&#xff09;是Linux系统下用于监视系统输入输出设备和CPU使…...

2021-03-15 iview一些问题

1.iview 在使用tree组件时&#xff0c;发现没有set类的方法&#xff0c;只有get&#xff0c;那么要改变tree值&#xff0c;只能遍历treeData&#xff0c;递归修改treeData的checked&#xff0c;发现无法更改&#xff0c;原因在于check模式下&#xff0c;子元素的勾选状态跟父节…...

Android15默认授权浮窗权限

我们经常有那种需求&#xff0c;客户需要定制的apk集成在ROM中&#xff0c;并且默认授予其【显示在其他应用的上层】权限&#xff0c;也就是我们常说的浮窗权限&#xff0c;那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...

Spring是如何解决Bean的循环依赖:三级缓存机制

1、什么是 Bean 的循环依赖 在 Spring框架中,Bean 的循环依赖是指多个 Bean 之间‌互相持有对方引用‌,形成闭环依赖关系的现象。 多个 Bean 的依赖关系构成环形链路,例如: 双向依赖:Bean A 依赖 Bean B,同时 Bean B 也依赖 Bean A(A↔B)。链条循环: Bean A → Bean…...

推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材)

推荐 github 项目:GeminiImageApp(图片生成方向&#xff0c;可以做一定的素材) 这个项目能干嘛? 使用 gemini 2.0 的 api 和 google 其他的 api 来做衍生处理 简化和优化了文生图和图生图的行为(我的最主要) 并且有一些目标检测和切割(我用不到) 视频和 imagefx 因为没 a…...

Java求职者面试指南:计算机基础与源码原理深度解析

Java求职者面试指南&#xff1a;计算机基础与源码原理深度解析 第一轮提问&#xff1a;基础概念问题 1. 请解释什么是进程和线程的区别&#xff1f; 面试官&#xff1a;进程是程序的一次执行过程&#xff0c;是系统进行资源分配和调度的基本单位&#xff1b;而线程是进程中的…...

MyBatis中关于缓存的理解

MyBatis缓存 MyBatis系统当中默认定义两级缓存&#xff1a;一级缓存、二级缓存 默认情况下&#xff0c;只有一级缓存开启&#xff08;sqlSession级别的缓存&#xff09;二级缓存需要手动开启配置&#xff0c;需要局域namespace级别的缓存 一级缓存&#xff08;本地缓存&#…...

【Linux手册】探秘系统世界:从用户交互到硬件底层的全链路工作之旅

目录 前言 操作系统与驱动程序 是什么&#xff0c;为什么 怎么做 system call 用户操作接口 总结 前言 日常生活中&#xff0c;我们在使用电子设备时&#xff0c;我们所输入执行的每一条指令最终大多都会作用到硬件上&#xff0c;比如下载一款软件最终会下载到硬盘上&am…...

C++_哈希表

本篇文章是对C学习的哈希表部分的学习分享 相信一定会对你有所帮助~ 那咱们废话不多说&#xff0c;直接开始吧&#xff01; 一、基础概念 1. 哈希核心思想&#xff1a; 哈希函数的作用&#xff1a;通过此函数建立一个Key与存储位置之间的映射关系。理想目标&#xff1a;实现…...

篇章二 论坛系统——系统设计

目录 2.系统设计 2.1 技术选型 2.2 设计数据库结构 2.2.1 数据库实体 1. 数据库设计 1.1 数据库名: forum db 1.2 表的设计 1.3 编写SQL 2.系统设计 2.1 技术选型 2.2 设计数据库结构 2.2.1 数据库实体 通过需求分析获得概念类并结合业务实现过程中的技术需要&#x…...