django_day09_项目相关
django_day09_项目相关
展示数据:
给模板一个querySet对象列表,循环出对象列表obj
普通字段
- obj.字段名 ----》 数据库中的数据
外键
- obj.外键 -------》外键的对象 给类定义__ str__的方法
带choices参数的
- obj.字段名 ------》 数据库中的数据这个显示不是很好i
- obj.get_ 字段名 _display() 显示定义好的结果 在模板中使用不加()
自定义方法
def show_publish_status(self):
color_dict = {True:'green',False:'#772a4d'}
return mark_safe('<span style="background: {};color: white;padding: 3px">{}</span>'.format(color_dict[self.publish_status],self.get_publish_status_display())){{form_obj.title.label}} #指定的是models.py 里面的字段中的:verbose_name='文章标题'
循环生成form表单
#models中(数据库中)
class Article(models.Model):
"""
标题,文章内容 作者 板块 创建时间 更新时间 删除状态 """
title = models.CharField(max_length=64,verbose_name='文章标题')
abstract = models.CharField(max_length=256,verbose_name='文章摘要')
content = models.TextField(verbose_name='文章内容')
author = models.ForeignKey(User,on_delete=models.DO_NOTHING,blank=True,verbose_name='作者')
category = models.ForeignKey(Category,on_delete=models.DO_NOTHING,blank=True,null=True,verbose_name='分类')
creat_time = models.DateTimeField(auto_now_add=True,verbose_name='创建时间')
update_time = models.DateTimeField(auto_now=True,verbose_name='更新时间')
publish_status = models.BooleanField(choices=((False,'未发布'),(True,'发布')),default=False,verbose_name='发布状态')
detail = models.OneToOneField('ArticleDetail',on_delete=models.DO_NOTHING)
def show_publish_status(self):
color_dict = {True:'green',False:'#772a4d'}
return mark_safe('<span style="background: {};color: white;padding: 3px">{}</span>'.format(color_dict[self.publish_status],self.get_publish_status_display())) #forms.py
class ArticleForm(forms.ModelForm):
class Meta:
model = models.Article#只能是model
fields = "__all__"
exclude = ['detail','content']
#views.py中
def article_add(request): form_obj = ArticleForm() return render(request,'article_add.html',{'form_obj':form_obj})
#模板中
<form class="form-horizontal">
{% for field in form_obj %}
<div class="form-group">
<label for="{{field.id_for_label}}" class="col-sm-2 control-label">{{field.label}}</label>
<div class="col-sm-10">
{{field }}
</div>
</div>
效果:
在字段中加入class属性
第一种方法
widgets = {
'title':forms.TextInput(attrs={'class':'form-control'})
}
#这样的话每个都加很麻烦
第二中方法
def __init__(self,*args,**kwargs):
super().__init__(*args,**kwargs)#执行父类方法 #自定义的操作
# self.fields 是个有序字典 字典中的值就是字段的对象
for field in self.fields.values():#field 就是models中定义的字段
field.widget.attrs['class'] = 'form-control'#field.widgrt
# 是拿到对应的插件的对象field.widget.attrs 然后拿到对应的属性做修改
<div class="col-sm-8"> 修改长度!
发送POST请求
if request.method == 'POST':
form_obj = ArticleForm(request.POST)#拿到form表单
#开始校验
if form_obj.is_valid():
form_obj.save()#保存
return redirect('article_list')
<form class="form-horizontal" method="post" novalidate>
{% csrf_token %}插入数据—有两张表需要同时存储 额外加一个input输入框
<div class="form-group">
<label for="detail" class="col-sm-2 control-label">文章详情</label>
<div class="col-sm-8">
<textarea class="form-control" rows="3" id="detail"></textarea>
</div>
</div>
def article_add(request):
form_obj = ArticleForm()
if request.method == 'POST':
form_obj = ArticleForm(request.POST)#拿到form表单 #开始校验
if form_obj.is_valid():
# form_obj.save()#保存 要插入两张表的内容不用这个
#插入文章详情
detail = request.POST.get('detail')
detail_obj = models.ArticleDetail.objects.create(content=detail) #拿到文章详情对象
#往文章里插入内容
#form_obj.cleaned_data 星星打散就可以拿到生成的表单中数据 但是还有自己创建的没加上
#额外加一个
#插入文章
form_obj.cleaned_data['detail_id'] = detail_obj.pk
models.Article.objects.create(**form_obj.cleaned_data)
return redirect('article_list')
return render(request,'article_add.html',{'form_obj':form_obj})
- 手动cleaned_data 添加之后用save就不中用了 要是想用 写个全局钩子
django_day09_项目相关的更多相关文章
- 根据funID,personID获取最新规划包项目相关信息
1.定义:根据funID,personID获取最新规划包项目相关信息(code projecttype(阶段) Pname(code+name) projectID) 项目表tbl_cfg_Proje ...
- django_day10_项目相关
django_day10_项目相关 展示数据的方法 数据对象obj 普通字段 obj.字段名 ====> 数据库该字段的值 带choices参数的 obj.字段名 ====> 数据库该字段 ...
- django_day11_项目相关
django_day11_项目相关 新增和编辑 路由 url(r'^category_add/$', views.category_change, name='category_add'), url( ...
- django_day08_项目相关
django_day08_项目相关 定义数据库表 from django.db import models # Create your models here. class User(models.M ...
- IDEA 从SVN检出项目相关配置
1.新建好一个工程,然后通过SVN检出项目 2.检出后一般tomcat的环境是配置好的,点击上方Project Structure按钮,弹出窗体,查看Project项,一般没问题,如果要配置就配置Pr ...
- IntelliJ IDEA 项目相关的几个重要概念介绍
必备材料介绍 IntelliJ IDEA 对其他 IDE 转过来的用户有特别优待,对其专门整理了非常棒的资料,还请其他 IDE 过来的用户抽时间查看,会有很大帮助:Eclipse 用户可以看:http ...
- Java面试06|项目相关介绍
1.明确你的项目到底是做什么的,有哪些功能 广告投放机:项目主要是为移动端有针对性的进行广告展示. 媒体管理平台SSP:为媒体端实现多种变现途径 (1)广告投放机中关于广告检索与排序的功能 1.广告检 ...
- 预置第三方apk到MTK项目相关问题总结
目前5.0之后项目预置方式通用步骤为: 建立apk文件夹; 置目标apk到该文件夹下; 解压缩apk查看是否包含lib/文件夹(apk项目是否包含lib库文件); 在该文件夹下编写Androi ...
- Linux 首先基本包安装(vim啊什么的),源,源优化,项目架构介绍, (LNMuWsgi)Django项目相关软件mysql,redies,python(相关模块)安装配置测试
内容 补充: 查看已启动服务的端口 netstat -tulnp |grep (方式1) ss -tulnp|grep (方式2) 前期铺垫: . Linux要能上网 . 掌握Linux软件包安装方法 ...
随机推荐
- 用Typescript 的方式封装Vue3的表单绑定,支持防抖等功能。
Vue3 的父子组件传值.绑定表单数据.UI库的二次封装.防抖等,想来大家都很熟悉了,本篇介绍一种使用 Typescript 的方式进行统一的封装的方法. 基础使用方法 Vue3对于表单的绑定提供了一 ...
- Gitlab + Gitlab runner + Window powershell
需求说明 根据领导要求,要把python 项目移到Gitlab 进行管理,并利用Gitlab CI/CD 进行自动化测试,打包,部署.(听起来很简单吧) 比较头大,完全没有经验,python 也是刚上 ...
- Linux字符集和编码
计算机内部,所有信息最终都是一个二进制值形式存放 字符集 字符集:charset是character set的简写,即二进制和字符的对应关系,不关注最终的存储形式 编码 字符集编码:encoding是 ...
- SpringCloudAlibaba分布式流量控制组件Sentinel实战与源码分析-中
实战示例 控制台初体验 Sentinel的控制台启动后,控制台页面的内容数据都是空的,接下来我们来逐步操作演示结合控制台的使用,在上一节也已说明整合SpringCloud Alibaba第一步先加入s ...
- 内存分析器 (MAT)
内存分析器 (MAT) 1. 内存分析器 (MAT) 1.1 MAT介绍 MAT是Memory Analyzer tool的缩写.指分析工具. 1.2 MAT作用 Eclipse Memory ...
- 使用Tapdata一步搞定关系型数据库到MongoDB的战略迁移
摘要:数据库作为最关键的基础设施,随着互联网时代的信息高速增长,关系型数据库因其高门槛.高成本以及扩展性差等原因导致的局限性逐渐浮出水面,如今更是面临诸多问题和挑战,Tapdata 专注新一代实时 ...
- 基于YCbCr色彩模型的简易肤色识别器
一.实验方法 实验共选取了12张图像,利用画笔工具在每幅图像上选取5个点,并分别记录RGB值.取点方式如下图所示: 总共70个点,R,G,B的值分别如下表所示: RGB色彩模型和YCbC ...
- 螣龙安科反入侵:EDR的缺点
EDR解决方案提供了比传统终结点安全解决方案更高的功能,并且可以增加人员数量,但是这些功能都有不少的缺点. EDR功能付出巨大代价 在过去四年中,虽然产品成本平均每年下降约35%,但即使到今天,产品的 ...
- Git Rebase操作
概括 rebase翻译过来为"变基",可以理解为改变基础,它可以用于分支合并和修改提交记录. 合并分支的区别 我们知道merge操作也可以用于分支合并,但是其和rebase操作有着 ...
- 如何用车辆违章查询API接口进行快速开发
最近公司项目有一个车辆违章查询显示的小功能,想着如果用现成的API就可以大大提高开发效率,所以在网上的API商店搜索了一番,发现了 APISpace,它里面的车辆违章查询API非常符合我的开发需求. ...