django处理select下拉表单实例(从model到前端到post到form)
作者:呆萌的代Ma 发布时间:2023-09-02 13:47:09
标签:django,select,表单
现在假如要写一个按照"标题",'内容','作者'等等进行针对性的选择,这时需要涉及到使用select下拉表单来进行选择.django是可以比较简单的解决这个问题的.
下面是model:
from django.db import models
class TestModel(models.Model):
SELVALUE = (
('标题', 'first'), #前面是展示在前端界面的内容,后面的'first'是真正存在数据库中的
('内容', 'second'),
('作者', 'third'),
)
select_value = models.CharField(max_length=10, choices=SELVALUE)
接下来我们写forms:
from django import forms
class SelectTestForm(forms.Form):
SELVALUE = (
('标题', 'first'),
('内容', 'second'),
('作者', 'third'),
)
sel_value = forms.CharField(max_length=10,widget=forms.widgets.Select(choices=SELVALUE))
然后就可以写view了:
from django.shortcuts import render
from django.views.generic import View
from .forms import SelectTestForm
class TestView(View):
def get(self, request):
select_form = SelectTestForm()
return render(request, 'sel_test.html', { #这里'sel_test.html'使我们的前端页面
'select_form': select_form, # 这里需要把form传到前端,前端就可以借助这个form填充界面
})
def post(self, request):
select_form = SelectTestForm(request.POST)
if select_form.is_valid():
get_value = request.POST.get('sel_value', "") #这里可以取到下拉表单中的值
#接下来就是保存数值与其他逻辑了
else:
#表单验证未通过的逻辑,多半要重新填写或直接给个404
pass
这是前端界面'sel_test.html':
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form method="post" action="">
<select name="sel_value">
{# 这里我们遍历form表单中的SELVALUE这个字典,然后把key,value成对取出 #}
{% for key,value in select_form.SELVALUE %}
<option value="{{ value }}">{{ key }}</option>
{% endfor %}
</select>
<input type="submit" value="测试"/>
{% csrf_token %}
</form>
</body>
</html>
补充知识:Django 表单,模型 结合前端select 显示
ModelChoiceField 使用方法
使用ModelChoiceField方法向前端提供模型
后端 forms.py
default_tester = forms.ModelChoiceField(
label='测试人员', queryset=User.objects.all(), required=True
)
前端代码
{% for user in form.default_tester.field.queryset %}
<option value="{{ user.pk }}">
{{ user }}
</option>
{% endfor %}
来源:https://blog.csdn.net/weixin_35757704/article/details/83351339
0
投稿
猜你喜欢
- function getElementsByClassName(elem_name,elem_tags) { //elem_name:查询的
- 因为工作原因,需要定期清理某个文件夹下面创建时间超过1年的所有文件,所以今天集中学习了一下Python对于本地文件及文件夹的操作。网上 这篇
- 相对于Firefox2来说,Firefox3除了采用全新的Gecko 1.9引擎外,在性能、稳定性和安全性方面进行许多改进,在我们最关心的对
- 引言在 Linux 服务器上,磁盘空间的使用情况是一个非常重要的指标。如果服务器上的磁盘空间不足,可能会导致服务器崩溃,影响网站的正常运行。
- 南京的炎炎夏日也未能挡住书友会朋友们的参与,下午两点半我们正式开始了这个月的话题:“浏览器”。一开始大家大致上说了一些自己认为各浏览器中各自
- 可试试下面这个方法,但要保证在FORM中使用的Input Name都和数据库中使用的是一样的:upfiles.asp<% &
- 用CSS+DIV编写的实现在网页中显示圆角矩形的代码!希望对大家有用!谢谢支持!以下为CSS代码:<style> div.bg{
- 1、什么是AspJpeg?AspJpeg是一款功能强大的基于Microsoft IIS环境的图片处理组件,网络上对其进行详细和深入介绍的中文
- 直接上代码:#!/usr/bin/python# -*- coding: utf-8 -*-import urllibimport os,d
- MySQL支持大量的列类型,它可以被分为3类:数字类型、日期和时间类型以及字符串(字符)类型。本节首先给出可用类型的一个概述,并且总结每个列
- psutil是一个跨平台的Python库,它允许你获取有关系统进程和系统资源使用情况的信息。它支持Windows、Linux、OS X、Fr
- python面向对象编程入门,我们需要不断学习进步"""抽象工厂模式的实现"""
- Oracle的执行计划一句话命令:set autotrace on
- 目录1 简介2 在Dash中实现文件上传与下载2.1 在Dash中配合dash-uploader实现文件上传2.1.1
- 昨天十行代码实现文字识别,感觉怎样,是不是很爽今天咋们继续利用pillow和pytesseract来实现验证码的识别一、环境配置需要 pil
- 本文环境Python 3.6.5Django 2.0.4fix(2018.5.19):最近得知Django 的model基类需要声明为abs
- 制作圆角导航其实跟制作圆角边框是一样的道理,有一种很常见的方法就是使用CSS绝对定位,切四个圆角的小图片,然后分别定位在四个角,这样就可以实
- 前几天,看到有人写了个superLink的东东,主要的做什么用呢?我们有时会给在大块元素加个window.location='htt
- 可以在Mac OS X 10.2.x(“Jaguar”)和以上版本上Mac OS X使用二进制安装软
- 此文主要讲述的是SQL Server连接中经常出现的3个常见错误,以及对这三个错误的详细分析,如果你其心存好奇的话,以下的文章将会揭开它的神