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


猜你喜欢
- 前言这期文章我就为大家介绍关于python的艺术美——画图神器在数学中有一种美,叫几何美,我们又称为
- 说明:vm.$refs 一个对象,持有已注册过 ref 的所有子组件(或HTML元素)使用:在 HTML元素 中,添加ref属性,然后在JS
- 首先说一个小技巧,True可看作1,False可看作0 ,并且可以参与运算!正文开始!!! 一、map()map(func,ite
- 简介这是一个操作数据库(sqlite3)的项目,用PyQt5进行界面封装。此次项目最主要的是,主界面与子界面的交互,一个主界面与三个子界面交
- 本文总结了两种方法来导入opencv与numpy包,第一种是直接在Pycharm中导入两个包,第二种是在官网下载相关文件进行配置。本人比较推
- pop()函数1、描述pop() 函数用于移除列表中的一个元素(默认最后一个元素),并且返回该元素的值。语法pop()方法语法:list.p
- 作为python和机器学习的初学者,目睹了AI玩游戏的各种风骚操作,心里也是跃跃欲试。然后发现微信跳一跳很符合需求,因为它不需要处理连续画面
- 本文实例讲述了JS表单验证插件之数据与逻辑分离操作。分享给大家供大家参考,具体如下:之前已经写过一个表单验证插件了,为什么还会重复造轮子呢?
- 如下所示:>> type(np.newaxis)NoneType>> np.newaxis == NoneTruen
- 在这里给出是的WindowsXP操作系统下的安装过程一、下载安装文件到MySQL官方网站找到ZIP文件提示:有些是安装文件,安装时会有提示,
- 本文实例讲述了thinkphp3.x连接mysql数据库的方法。分享给大家供大家参考,具体如下:惯例配置文件:ThinkPHP/conf/c
- 基础环境# +++++ 阿里云OSS开发指南里都有详细的步骤,在这里整理了一下自己需要的东西# 确定开发环境,centOS默认安装了pyth
- 我们有时候希望回车键敲在文本框(input element)里来提交表单(form),但有时候又不希望如此。比如搜索行为,希望输入完关键词之
- 一,概要需求: 实现一个GUI界面下的 6+1体育彩票选号器.(1) 要求界面可以加载系统时间及开奖时间(2)功能区完成人选及机选的功能 人
- 实现功能QuestType 1->查询语句, 2->更新语句, 3->删除语句, 4->插入语句<
- 一、实验目的实现学生选课系统二、实验环境Python3.6pymysql(Python连接MySQL)xlrd(操作Excel)三、程序结构
- PHP chunk_split() 函数实例在每个字符后分割一次字符串,并在每个分割后添加 ".":<?php $
- 效果图如下所示:实现代码如下:<!DOCTYPE html><html lang="zh-cn">
- 往期学习:python数据类型: python数据结构:数据类型.python的输入输出: python数据结构之输入输出及控制和异常.py
- 背景:用python画AR模型的时序图。结果:代码:import numpy as npimport matplotlib.pyplot a