呼啦圈

1.1 表结构设计

  • 不会经常变化的值放在内存:choices形式,避免跨表性能低。

  • 分表:如果表中列太多/大量内容可以选择水平分表

  • 表自关联

from django.db import models

class UserInfo(models.Model):
  """ 用户表 """
  username = models.CharField(verbose_name='用户名',max_length=32)
  password = models.CharField(verbose_name='密码',max_length=64)


class Article(models.Model):
  """ 文章表 """
  category_choices = (
      (1,'咨询'),
      (2,'公司动态'),
      (3,'分享'),
      (4,'答疑'),
      (5,'其他'),
  )
  category = models.IntegerField(verbose_name='分类',choices=category_choices)
  title = models.CharField(verbose_name='标题',max_length=32)
  image = models.CharField(verbose_name='图片路径',max_length=128) # /media/upload/....
  summary = models.CharField(verbose_name='简介',max_length=255)

  comment_count = models.IntegerField(verbose_name='评论数',default=0)
  read_count = models.IntegerField(verbose_name='浏览数',default=0)

  author = models.ForeignKey(verbose_name='作者',to='UserInfo')
  date = models.DateTimeField(verbose_name='创建时间',auto_now_add=True)

class ArticleDetail(models.Model):
  article = models.OneToOneField(verbose_name='文章表',to='Article')
  content = models.TextField(verbose_name='内容')


class Comment(models.Model):
  """ 评论表 """
  article = models.ForeignKey(verbose_name='文章',to='Article')
  content = models.TextField(verbose_name='评论')
  user = models.ForeignKey(verbose_name='评论者',to='UserInfo')
  # parent = models.ForeignKey(verbose_name='回复',to='self', null=True,blank=True)

1.2 系统结构(CMS)

1.3 功能实现

1.3.1 增加文章(可以不写)

一次增加两个表中的数据:

  def post(self,request,*args,**kwargs):
      """ 新增文章(应该在后台管理开发)"""
      ser = ArticleSerializer(data=request.data)
      ser_detail = ArticleDetailSerializer(data=request.data)
      if ser.is_valid() and ser_detail.is_valid():
          # 增加文章
          article_object = ser.save(author_id=1)
          ser_detail.save(article=article_object)
          return Response('添加成功')
      return Response('错误')

1.3.2 文章列表

1.3.3 文章详细

1.3.4 评论列表

  • 查看评论列表 访问时:http://127.0.0.1:8000/hg/comment/?article=2

  • 添加评论

    http://127.0.0.1:8000/hg/comment/

    {
    article:1,
    content:'xxx'
    }
    http://127.0.0.1:8000/hg/comment/?article=1

    {
    content:'xxx'
    }

2. 筛选

案例:在文章列表时候,添加筛选功能。

全部:http://127.0.0.1:8000/hg/article/
筛选:http://127.0.0.1:8000/hg/article/?category=2
class ArticleView(APIView):
  """ 文章视图类 """

  def get(self,request,*args,**kwargs):
      """ 获取文章列表 """
      pk = kwargs.get('pk')
      if not pk:
          condition = {}
          category = request.query_params.get('category')
          if category:
              condition['category'] = category
          queryset = models.Article.objects.filter(**condition).order_by('-date')
           
          pager = PageNumberPagination()
          result = pager.paginate_queryset(queryset,request,self)
          ser = ArticleListSerializer(instance=result,many=True)
          return Response(ser.data)
      article_object = models.Article.objects.filter(id=pk).first()
      ser = PageArticleSerializer(instance=article_object,many=False)
      return Response(ser.data)
drf的组件:内置了筛选的功能
from django.shortcuts import render
from rest_framework.views import APIView
from rest_framework.response import Response
from . import models

from rest_framework.filters import BaseFilterBackend

class MyFilterBackend(BaseFilterBackend):

  def filter_queryset(self, request, queryset, view):
      val = request.query_params.get('cagetory')
      return queryset.filter(category_id=val)
   

class IndexView(APIView):

  def get(self,request,*args,**kwargs):
      # http://www.xx.com/cx/index/
      # models.News.objects.all()

      # http://www.xx.com/cx/index/?category=1
      # models.News.objects.filter(category=1)

      # http://www.xx.com/cx/index/?category=1
      # queryset = models.News.objects.all()
      # obj = MyFilterBackend()
      # result = obj.filter_queryset(request,queryset,self)
      # print(result)
       
      return Response('...')

3.视图

  • APIView,感觉没提供功能。

  • GenericAPIView,桥梁,内部定义:get_queryset/get_serilizer/get_page...

  • ListAPIView,CreateAPIView,RetrieveAPIView,UpdateAPIView,DestroyAPIView
class TagSer(serializers.ModelSerializer):
  class Meta:
      model = models.Tag
      fields = "__all__"

class TagView(ListAPIView,CreateAPIView):
  queryset = models.Tag.objects.all()
  serializer_class = TagSer

  def get_serializer_class(self):
      # self.request
      # self.args
      # self.kwargs
      if self.request.method == 'GET':
          return TagSer
      elif self.request.method == 'POST':
          return OtherTagSer
  def perform_create(self,serializer):
      serializer.save(author=1)

class TagDetailView(RetrieveAPIView,UpdateAPIView,DestroyAPIView):
  queryset = models.Tag.objects.all()
  serializer_class = TagSer

实现呼啦圈

ListAPIView,CreateAPIView,RetrieveAPIView,UpdateAPIView,DestroyAPIView
+
定义钩子方法

drf呼啦圈的更多相关文章

  1. 呼啦圈(keyframes和transform结合)

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  2. drf

    跨域同源 django做跨域同源 需要把csrf去掉 跨站请求伪造 同源 同源机制:域名.协议.端口号相同的同源 简单请求 不写头部请求 跨域会拦截报错缺少请求信息 (1) 请求方法是以下三种方法之一 ...

  3. drf源码系列

    过滤器 对查询出来的数据进行筛选可写可不写 from rest_framework.filters import BaseFilterBackend 源码 ''' def filter_queryse ...

  4. drf(请求封装/认证/权限/节流)

    1.请求的封装 class HttpRequest(object): def __init__(self): pass @propery def GET(self): pass @propery de ...

  5. Drf06 /drf总结

    Drf06 /drf总结 目录 Drf06 /drf总结 1. restful规范 2. drf组件认证的实现过程? 3. drf组件中权限的实现过程? 4. drf组件中节流的实现方式? 5. 什么 ...

  6. restframework详细

    1.写视图的方法 1.1第一种:原始APIView url(r'^login/$',account.LoginView.as_view()), from rest_framework.views im ...

  7. webpack入门必知必会

    关于 微信公众号:前端呼啦圈(Love-FED) 我的博客:劳卜的博客 知乎专栏:前端呼啦圈 前言 这是我第一篇介绍webpack的文章,先从一个入门教程开始吧,后续会有更多相关webpack的文章推 ...

  8. JavaScript易错点转载

    前言 本文是我学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由浅入深的介绍和讲解,其中也涉及了一 ...

  9. 写好你的JavaScript

    关于 微信公众号:前端呼啦圈(Love-FED) 我的博客:劳卜的博客 知乎专栏:前端呼啦圈 前言 在实际工作中,我们应该经常会看到一些功能上没有问题,但编码风格和规范却十分糟糕的代码,这往往会让人不 ...

随机推荐

  1. youths |government|some

    N-COUNT (新闻用语,尤指惹麻烦的)青年,小伙子Journalists often refer to young men as youths, especially when they are ...

  2. Jsp入门EL表达式_学习笔记

    1.EL表达式 [1] 简介 > JSP表达式 <%= %> 用于向页面中输出一个对象. > 到JSP2.0时,在我们的页面中不允许出现 JSP表达式和 脚本片段. > ...

  3. 浏览器证书问题,chorm,ie,edge,safari都会去读系统证书,firefox例外

    坑爹 没想过浏览器兼容的问题. 为系统安装用户证书后, firefox一直无法连接 提示 连接 www.httpsserver.com:8985 时发生错误. SSL 对等端无法协商出一个可接受的安全 ...

  4. DIP|PCN|CoevDB|PID|Y2H|RosettaDock Serve|元基因组学|微生物多样性

    生命组学: 比较真核生物有关呼吸链的gene是比较核外编码基因,因为与呼吸有关的功能在线粒体上,线粒体位于核外.想要查看两种基因是否具有相互作用,可以对不同物种的编码ATP6 和ATP8的直系同源基因 ...

  5. 3DSMAX 卸载工具,完美彻底卸载清除干净3dsmax各种残留注册表和文件

    一些同学安装3dsmax出错了,也有时候想重新安装3dsmax的时候会出现这种本电脑已安装3dsmax,你要是不留意直接安装,只会安装3dsmax的附件,3dsmax是不会安装上的.这种原因呢就是大家 ...

  6. mysql中事务的并发问题与隔离级别

    回归一下事务的四大特性ACID 1.原子性(Atomicity) 事务开始后所有操作,要么全部做完,要么全部不做.事务是一个不可分割的整体.事务在执行过程中出错,会回滚到事务开始之前的状态,以此来保证 ...

  7. 某某项目SDV软件测试报告范例

    说明:本范例为符合CMMI 5级要求的范例 Prepared by 拟制 小张 Date 日期 2008-04-09 Reviewed by 评审人 小丽.小王.小李.小莉.小三.小四.小猪.小猫.小 ...

  8. History of AI

    人工智能的历史源远流长.在古代的神话传说中,技艺高超的工匠可以制作人造人,并为其赋予智能或意识.[1]现代意义上的AI始于古典哲学家用机械符号处理的观点解释人类思考过程的尝试.20世纪40年代基于抽象 ...

  9. 微软亚洲研究院的“哈利·波特”:Thomas Moscibroda

    在微软亚洲研究院,有一位名为Thomas Moscibroda的研究员几乎是无人不知.无人不晓,江湖人送外号"哈利·波特".Thomas认为他这么"红"是因为他 ...

  10. Ubuntu 14.04 下NFS安装配置

    1.执行命令:sudo apt-get install nfs-kernel-server; 2.执行命令:mkdir /home/jack/nfs-share 建立一个nfs服务的专有的文件夹; 3 ...