django_day10_项目相关

  • 展示数据的方法

    • 数据对象obj

      • 普通字段
      1. obj.字段名 ====》 数据库该字段的值
      • 带choices参数的

        1. obj.字段名 ====》 数据库该字段的值
        2. obj.get_字段名_display() ====》 要显示的结果
      • 外键

        1. obj.外键====》 所关联的对象 __str__ 方法
        2. obj.外键.字段
      • 自定义方法

        from django.utils.safestring import mark_safe
        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()))
  • 定义modelform

    class ArticleForm(forms.ModelForm):
    class Meta:
    model = models.Article#只能是model
    fields = "__all__"
    exclude = ['detail']
    # 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 然后拿到对应的属性做修改
  • 使用form

    def article_add(request):
    form_obj = ArticleForm()#什么都不传
    if request.method == 'POST':
    form_obj = ArticleForm(request.POST)#拿到form表单
    #开始校验
    if form_obj.is_valid():
    #获取文章详情字符串
    detail = request.POST.get('detail')
    # 创建文章详情对象
    detail_obj = models.ArticleDetail.objects.create(content=detail)
    form_obj.instance.detail_id = detail_obj.pk
    form_obj.save() # form_obj.instance.save()
    return redirect('article_list')
    return render(request, 'article_add.html', {'form_obj': form_obj}) #关联了俩个表
    def article_edit(request, pk):
    obj = models.Article.objects.filter(pk=pk).first() # 查到一个queryset对象 first拿到第一个 如果没有则返回为null
    form_obj = ArticleForm(instance=obj) #传了个instance对象
    if request.method == 'POST':
    form_obj = ArticleForm(request.POST, instance=obj) # 包含数据库没修改之前的数据 以及表单提交的数据
    if form_obj.is_valid(): # 通过校验
    form_obj.instance.detail.content = request.POST.get('detail')
    form_obj.instance.detail.save()# 修改以后 还要保存 文章详情
    form_obj.save()# 保存文章的信息
    return render(request, 'article_edit.html', {'form_obj': form_obj, 'obj': obj}) #HTML
    <form class="form-horizontal" method="post" action="" novalidate>
    {% csrf_token %}
    {% for field in form_obj %} {{ field.id_for_label }} # 拿到id {{ field.label }} #提示信息 models中的 verbose_name {{ field }} #生成input框 {{ field.errors.0 }} #错误 {% endfor %}
    </form>
  • 让用户上传图像

    #model中添加ImageField
    avatar = models.ImageField(upload_to='img/avatar',default='img/avatar/default.jpg') #ImageField 依赖pillow模块 #settings.py中的配置
    MEDIA_URL = '/media/'
    MEDIA_ROOT = os.path.join(BASE_DIR,'media') #urls.py中的配置
    from django.views.static import serve
    from django.conf import settings
    urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^', include('app01.urls')),
    url(r'^media/(?P<path>.*)',serve,{'document_root':settings.MEDIA_ROOT}),
    ] #模板中使用
    注册时:form中加上 enctype="multipart/form-data"
    显示时:<img width="20px" src="/media/img/avatar/张伟.jpg" alt=""> #views中
    form_ojb = RegForm(request.POST,request.FILES)
  • 使用django-ckeditor

    1. 下载pip install django-ckeditor

    2. 注册app

      INSTALLED_APPS = [
      ........
      'ckeditor',
      'ckeditor_uploader',
      ]
    3. urls.py

      urlpatterns = [
      .........................
      url(r'^ckeditor/', include('ckeditor_uploader.urls')),
      ]
    4. models.py

      class ArticleDetailForm(forms.ModelForm):
      
          class Meta:
      model = models.ArticleDetail # 只能是model
      fields = "__all__"
      form_obj = ArticleDetailForm()#实例化
    5. html

      {{ form_obj.content }}

      引用静态文件

      {% block js %}
      {% load static %}
      <script type="text/javascript" src="{% static "ckeditor/ckeditor-init.js" %}"></script>
      <script type="text/javascript" src="{% static "ckeditor/ckeditor/ckeditor.js" %}"></script>
      {% endblock %}
    6. 上传需要认证,取消认证

      #将staff_member_required这个装饰器取消掉
      urlpatterns = [
      url(r'^upload/', staff_member_required(views.upload), name='ckeditor_upload'),
      url(r'^browse/', never_cache(staff_member_required(views.browse)), name='ckeditor_browse'),
      ] #改为下面这样
      from ckeditor_uploader import views urlpatterns = [
      url(r'^upload/', views.upload, name='ckeditor_upload'),
      url(r'^browse/', never_cache(views.browse), name='ckeditor_browse'),
      ]

django_day10_项目相关的更多相关文章

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

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

  2. django_day11_项目相关

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

  3. django_day09_项目相关

    django_day09_项目相关 展示数据: 给模板一个querySet对象列表,循环出对象列表obj 普通字段 obj.字段名 ----> 数据库中的数据 外键 obj.外键 ------- ...

  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. 【Redis】quicklist

    Redis List 在Redis3.2版之前,Redis使用压缩列表和双向链表作为List的底层实现.当元素个数比较少并且元素长度比较小时,Redis使用压缩列表实现,否则Redis使用双向链表实现 ...

  2. 倾斜摄影3D模型|手工建模|BIM模型 轻量化处理

    一.什么是大场景? 顾名思义,大场景就是能够从一个鸟瞰的角度看到一个大型场景的全貌,比如一个园区.一座城市.一个国家甚至是整个地球.但过去都以图片记录下大场景,如今我们可以通过建造3D模型来还原大场景 ...

  3. React基础中的单一标签包裹的问题

    先上一段代码: <div id="example"> </div function HelloMessage(props1) { return (<h1&g ...

  4. (数据科学学习手札139)geopandas 0.11版本重要新特性一览

    本文示例代码已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 大家好我是费老师,就在几天前,geopandas ...

  5. skywalking链路监控

    1. 下载安装包官网地址:http://skywalking.apache.org/downloads/ 2. tar xzf apache-skywalking-apm-6.5.0.tar.gz - ...

  6. EasyExcel导出创建Excel下拉框

    话不多说,上才艺. 下面代码粘贴即用 /** * * 导出表格带下拉框 */ @GetMapping("exportBox") public void export(HttpSer ...

  7. C++ 模板和泛型编程(掌握Vector等容器的使用)

    1. 泛型 泛型在我的理解里,就是可以泛化到多种基本的数据类型,例如整数.浮点数.字符和布尔类型以及自己定义的结构体.而容器就是提供能够填充任意类型的数据的数据结构.例如vector就很类似于pyth ...

  8. Tapdata x 轻流,为用户打造实时接入轻流的数据高速通道

      在全行业加速布局数字化的当口,如何善用工具,也是为转型升级添薪助力的关键一步.   那么当轻量的异构数据实时同步工具,遇上轻量的数字化管理工具,将会收获什么样的新体验?此番 Tapdata 与轻流 ...

  9. 实战模拟│单点登录 SSO 的实现

    目录 什么是单点登录 单点登录的凭证 父域 Cookie 方式 用户认证中心方式 localstorage方式 什么是单点登录 单点登录: SSO(Single Sign On) 用户只需登录一次,就 ...

  10. VS无线振弦采集仪的常见问题

    1 无法开机( 1)检查电源连接是否正确,电压范围应为 DC10~24V,输出能力不低于 2A, 正负极连接正确.若电池极性接反,即便未进行过开机操作也会导致设备永久性损坏.( 2)若使用电池供电,则 ...