解决django中form表单设置action后无法回到原页面的问题
作者:攻城狮的策划 发布时间:2023-06-27 00:27:54
django中form表单设置action后,点提交按钮是跳转到action页面的,比如设置action为login,网址为192.168.1.128,跳转后便会来到192.168.1.128/login,F5刷新也会是重新提交表单对话框,无法回到原页面。
因此就要在django服务器进行重定向,具体就是
from django.shortcuts import redirect
#最后返回原页面
return redirect(url)
补充知识:Django + Ajax发送POST表单,并将返回信息回显到页面中
将表单数据发送回后端,然后处理后端返回的信息并显示在当前页面中,这里使用Ajax进行处理;
那么先看js代码:
<!--以下为 Ajax脚本 -->
<script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$("#save").click(function(){
$.ajax({
url:"/api/add_event/", #url
type: "POST", #提交表单的类型,相当于method="post"
dataType: "json", #dataType, 这个是请求后,返回的数据将以json格式显示
data:{"name": $("#id_name").val(), #在"#"号后面是控件id, 所以千万不要搞错了,要不然会出大事的
"limit":$("#id_limit").val(),
"address": $("#id_address").val(),
"start_time": $("#id_start_time").val(),
"status": $("#id_status").val(),
}, #Data这个地方,必须要获取数据,代表将获取到的数据发送到后端,后端再进行处理
success:function(data){
console.log(data); #调试使用
console.log(data.status); #调试使用
console.log(data.message); #调试使用
$(".text").text(data.message); #将后端返回到结果通过前端页面进行展示
}, #注意标点
}); #需要注意标点符号,如果标点符合错误了,那ajax基本上都不会执行(否则,后果很严重哦)
}); #注意标点
}); #注意标点
</script>
注意(踩过的坑):
1.contentType: "application/json" ——>加入该语句时,在后端print(request.POST)时无法获取内容,相当于后端根本拿不到数据。因此在网上搜索了解到,使用contentType: “application/json”则data只能是json字符串;不使用时contentType一般为默认的application/x-www-form-urlencoded格式, 因此如果不限制 POST格式,干脆就不写。
2. 说说“data”这里面需要注意:data:{"name", $("#id_name").val(), } 这其中id_name必须为控件的id 名称,使用其它的则不能获取的数据,这个还是得注意。
3. 标注符号,标点符号,标点符号,重要的事情说三遍,当然可以借助专门的编辑器(我主要是懒哦,哈哈)
4. $(".text").text(data.message); 回显在html中,是对后端返回的数据进行处理
那行回显在网页面上面
<font color="red">
<span class="text"></span>
</font>
以下为html代码
<div class="container">
<div class="col-md-4 col-md-offset-4">
<form id="form1" onsubmit="return false" action="##" method="POST" class="form-horizontal">
<!--此处就是通过后端返回到前端,前端进行展示-->
<font color="red">
<span class="text"></span>
</font>
<div class="form-group">
<label for="id_name">发布会名称:</label>
<input type="text" name="name" class="form-control" placeholder="发布会名称" maxlength="128" required id="id_name" />
</div>
<div class="form-group">
<label for="id_limit">Limit:</label>
<input type="number" name="limit" class="form-control" required id="id_limit" />
</div>
<div class="form-group">
<label for="id_address">发布会地址:</label>
<input type="text" name="address" class="form-control" placeholder="地址" maxlength="128" required id="id_address" />
</div>
<div class="form-group">
<label for="id_start_time">开始日期:</label>
<input type="text" name="start_time" required id="id_start_time" />
</div>
<div class="form-group">
<label for="id_status">发布状态:</label>
<select name="status" id="id_status">
<option value="blank">-----</option>
<option value="1">True</option>
<option value="0">False</option>
</select>
</div>
<div align="center">
<input class="btn btn-lg btn-primary" id="save" type="submit" value="保存发布会" ></input >
</div>
</form>
</div>
</div>
现在来看一下后端的代码:
from django.views.decorators.csrf import csrf_exempt
@csrf_exempt
def add_event(request):
if request.is_ajax():
print(request.body)
print(request.POST)
name = request.POST.get('name', '') # 发布会名称
limit = request.POST.get('limit', '') # 限制人员
status = request.POST.get('status', '') # 发布会状态
address = request.POST.get('address', '') # 发布会地址
start_time = request.POST.get('start_time', '') # 发布会时间
if name == '' or limit == '' or status == '' or start_time == '':
return JsonResponse({'status': 10021, 'message': 'parameter error'})
# 判断发布会名称重复
result = Event.objects.filter(name=name)
if result:
return JsonResponse({'status': 10023, 'message': 'event name already exists'})
if status == '':
status = 1
try:
# Event.objects.create(id = eid, name = name, limit = limit, address = address, status = int(status), start_time=start_time)
Event.objects.create(name=name, limit=limit, address=address, status=int(status), start_time=start_time)
except ValidationError as e:
error = 'start_time format error. It must be in YYYY-MM-DD HH:MM:SS'
return JsonResponse({'status': 10024, 'message': error})
return JsonResponse({'status': 200, 'message': 'add event success'})
1、在后端处理时,我们需要加入:@csrf_exempt 标记,所以导包from django.views.decorators.csrf import csrf_exempt,否则会出现错误csrf_token错误 (403)
2、request.is_ajax()判断当前是否是使用ajax 进行表单提交
3、django request.POST / request.body
当request.POST没有值 需要考虑:
1.请求头中的: Content-Type: application/x-www-form-urlencoded request.POST中才会有值(才会去request.body中解析数据),关于Content-Type前面也提到,不写的错误,它就是默认。
request.body的请求数据
b'name=%E5%A4%BA%E5%A4%BA&limit=123‘
request.POST的数据,django已进行自动处理
QueryDict: {‘name': [‘夺夺'], ‘limit': [‘123']
来源:https://blog.csdn.net/m0_37566460/article/details/62047803
猜你喜欢
- 先来看一段创建文件并写入文本的代码,然后作介绍。 #!/usr/bin/env python 'makeFile.py
- 我们经常见到很多网站留言系统的显示访客的IP地址都是隐藏了一部分,以达到隐蔽访客真实地理位置的功能。如:111.222.333.*,当然在系
- 启动服务发生1067错误:1.删除datadir 下的用户数据库文件 和 日志文件 (ib_logfile0,ib_logfile1)。2.
- 实例如下所示:>>>from compiler.ast import flatten>>>Xmatrix
- Python是一种计算机程序设计语言,一种面向对象的动态类型语言,一种脚本语言。最初被设计用于编写自动化脚本(shell)的,常用于各种服务
- 本文实例讲述了Python学习笔记之列表推导式。分享给大家供大家参考,具体如下:列表推导式列表推导式可以快速简练地创建列表之前的复杂写法:c
- 前言现在我能一整天都严肃地盯着屏幕,看起来就像在很认真地工作,利用摸鱼,打开小说,可实行完美摸鱼,实时保存进度用PYQT5 Mock一个摸鱼
- find()方法判断字符串str,如果起始索引beg和结束end索引能找到在字符串或字符串的一个子串中。语法以下是find()方
- 写在前面最近在使用Mockjs作为项目里面mock数据的工具,发现mockjs做的拦截部分是自己实现摸拟了一个XMLHttpRequest的
- 这篇文章主要介绍了python3 pathlib库Path类方法总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习
- 目录前言环境依赖代码前言本文主要分享一个可以将图片或者视频模糊化的工具代码。技术路线主要是使用ffmpeg滤镜。环境依赖ffmpeg环境部署
- Python 条件语句Python条件语句是通过一条或多条语句的执行结果(True或者False)来决定执行的代码块。可以通过下图来简单了解
- Bottle是一个快速、简洁、轻量级的基于WSIG的微型Web框架,此框架只由一个 .py 文件,除了Python的标准库外,其不依赖任何其
- 在连接数据库的url地址有点不一样jdbc:oracle:thin:@(DESCRIPTION=(LOAD_BALANCE=on)(ADDR
- 昨天我只是将数据库附加到SQL2012,然后各个数据库都做了收缩事务日志的操作兼容级别这些都没有改再附加回SQL2005的时候就报错在SQL
- 1、查看数据库的字符集数据库的字符集必须和Linux下设置的环境变量一致,不然会有乱码。以下两个sql语句都可以查到:select * fr
- 随着手机用户的不断增加,WAP站点如雨后春笋迅速的滋长开来,手机邮箱也不断的出现在人的眼前,笔者也曾经开发了一套手机邮箱的系统,但由于时间仓
- 基本概念数字图像定义对于一幅图像,我们可以将其放入坐标系中,这里取图像左上定点为坐标原点,x 轴向右,和笛卡尔坐标系x轴相同;y 轴向下,和
- 错误信息:ERROR 2002 (HY000): Can't connect to local MySQL server throu
- 一、概述在一般的sql操作中,sql语句基本上都是固定的,如: SELECT t.empno,t.ename FROM scott