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_项目相关的更多相关文章

  1. 根据funID,personID获取最新规划包项目相关信息

    1.定义:根据funID,personID获取最新规划包项目相关信息(code projecttype(阶段) Pname(code+name) projectID) 项目表tbl_cfg_Proje ...

  2. django_day10_项目相关

    django_day10_项目相关 展示数据的方法 数据对象obj 普通字段 obj.字段名 ====> 数据库该字段的值 带choices参数的 obj.字段名 ====> 数据库该字段 ...

  3. django_day11_项目相关

    django_day11_项目相关 新增和编辑 路由 url(r'^category_add/$', views.category_change, name='category_add'), url( ...

  4. django_day08_项目相关

    django_day08_项目相关 定义数据库表 from django.db import models # Create your models here. class User(models.M ...

  5. IDEA 从SVN检出项目相关配置

    1.新建好一个工程,然后通过SVN检出项目 2.检出后一般tomcat的环境是配置好的,点击上方Project Structure按钮,弹出窗体,查看Project项,一般没问题,如果要配置就配置Pr ...

  6. IntelliJ IDEA 项目相关的几个重要概念介绍

    必备材料介绍 IntelliJ IDEA 对其他 IDE 转过来的用户有特别优待,对其专门整理了非常棒的资料,还请其他 IDE 过来的用户抽时间查看,会有很大帮助:Eclipse 用户可以看:http ...

  7. Java面试06|项目相关介绍

    1.明确你的项目到底是做什么的,有哪些功能 广告投放机:项目主要是为移动端有针对性的进行广告展示. 媒体管理平台SSP:为媒体端实现多种变现途径 (1)广告投放机中关于广告检索与排序的功能 1.广告检 ...

  8. 预置第三方apk到MTK项目相关问题总结

    目前5.0之后项目预置方式通用步骤为: 建立apk文件夹;  置目标apk到该文件夹下;   解压缩apk查看是否包含lib/文件夹(apk项目是否包含lib库文件);  在该文件夹下编写Androi ...

  9. Linux 首先基本包安装(vim啊什么的),源,源优化,项目架构介绍, (LNMuWsgi)Django项目相关软件mysql,redies,python(相关模块)安装配置测试

    内容 补充: 查看已启动服务的端口 netstat -tulnp |grep (方式1) ss -tulnp|grep (方式2) 前期铺垫: . Linux要能上网 . 掌握Linux软件包安装方法 ...

随机推荐

  1. 2.1 动为进程,静为程序 -进程概论 -《zobolの操作系统学习札记》

    2.1 动为进程,静为程序 -进程概论 目录 2.1 动为进程,静为程序 -进程概论 问1:发明进程的原因? 问2:现在计算机中的进程的定义是什么? 问3:为什么进程跟处理器的联系更密切? 问4:进程 ...

  2. [pwn基础]Pwntools学习

    目录 [pwn基础]Pwntools学习 Pwntools介绍 Pwntools安装 Pwntools常用模块和函数 pwnlib.tubes模块学习 tubes.process pwnlib.con ...

  3. 面试突击60:什么情况会导致 MySQL 索引失效?

    为了验证 MySQL 中哪些情况下会导致索引失效,我们可以借助 explain 执行计划来分析索引失效的具体场景. explain 使用如下,只需要在查询的 SQL 前面添加上 explain 关键字 ...

  4. 从Mpx资源构建优化看splitChunks代码分割

    背景 MPX是滴滴出品的一款增强型小程序跨端框架,其核心是对原生小程序功能的增强.具体的使用不是本文讨论的范畴,想了解更多可以去官网了解更多. 回到正题,使用MPX开发小程序有一段时间了,该框架对不同 ...

  5. docker安装Sentinel

    1.拉取镜像 docker pull bladex/sentinel-dashboard:latest 2.运行 docker run --name sentinel --restart=always ...

  6. npm uninstall和rm直接删除的区别

    结论: 1. npm uninstall会备份包本身依赖的node_modules,rm -f会删除整个目录 2. npm uninstall不会删除被依赖的包.即使显式要删除这个包,但它被依赖不会删 ...

  7. 安装rlwrap

    一. 安装readlineyum install readline* -y 二. 安装rlwrap[root@dbserver ~]# tar -zxvf rlwrap-0.43.tar.gz[roo ...

  8. Tapdata 实时数据融合平台解决方案(五):落地

    作者介绍:TJ,唐建法,Tapdata 钛铂数据 CTO,MongoDB中文社区主席,原MongoDB大中华区首席架构师,极客时间MongoDB视频课程讲师. 通过前面几篇文章,我们从企业数据整合与分 ...

  9. LMC7660即-5V产生电路

    LMC7660为小功率极性反转电源转换器,通过LMC7660电路产生-5V电压,其芯片管脚定义如下表所示. LMC7660负电压产生电路如下图所示. 其中6脚当供电电压大于等于5V时该脚必须悬空,当供 ...

  10. PoweJob高级特性-MapReduce完整示例

    由于网上搜索 PowerJob MapReduce 都是设计原理,demo也展示个空壳子,没有演示Map到Reduce结果怎么传递,对于没有MR开发经验的人来说并没有什么帮助,所以这里写了一个有完整计 ...