zoukankan      html  css  js  c++  java
  • restframwork组件的使用

    要使用rest_framework组件首先得在settings里面配置中把它添加入app里 这样才可以通过浏览器去访问

    替换掉之前使用url链接直接对应视图函数的方式,取代之前render 或者redirect渲染页面返回数据的方式,直接返回json字符数据,通过get,post,put,delete 等请求协议来实现数据传递,要查看传递的数据可以通过postman插件来浏览。

    url代码块:

    1 url(r'^publish/$',views.PublishDeteal.as_view({"get":"list","post":"create"}),name="pub"),
    2 url(r'^publish/(?P<pk>d+)/$',views.PublishDeteal.as_view({"get":"retrieve","put":"update","delete":"destroy"}),name="public"),

    链接通过传入指定的协议参数,让其找对应方法去执行相应视图,若是带参数的url则必须指定其pk值

    views视图代码块:

    1 from rest_framework import viewsets
    2 
    3 class PublishDeteal(viewsets.ModelViewSet):
    4     queryset = Publish.objects.all()
    5     serializer_class = PublishShowSerializers

    此时的视图类继承的父类改为 viewset.ModelViewSet,

    它必须为父类提供的配置属性是queryset:从model数据库里查询出来的queryset对象

    和serializer_class:序列化类 按照序列化类下的配置对queryset里面的数据进行序列化配置

    自定义的序列化类代码块:

    1 class PublishShowSerializers(serializers.ModelSerializer):
    2     class Meta:
    3         model=Publish
    4         fields="__all__"

    如果它默认的显示方法得不到期望值,可以重写父类下的方法 如:list create retrieve update  delete

    不带参数:

      get: list 查询所有对象

      post:create 添加数据记录

    带参数:

      get:retrieve 查询指定对象数据

      put:update 更新指定对象数据

      delete:destroy删除指定对象数据

  • 相关阅读:
    Vue源码探究-数据绑定的实现
    vue 数组遍历方法forEach和map的原理解析和实际应用
    vue 微信内H5调起支付
    uni-app官方教程学习手记
    vue-cli3 搭建的前端项目基础模板
    vue.js响应式原理解析与实现
    vue-waterfall2 基于Vue.js 瀑布流组件
    解决lucene更新删除无效的问题
    spring项目启动报错
    js监听页面copy事件添加版权信息
  • 原文地址:https://www.cnblogs.com/wen-kang/p/9928361.html
Copyright © 2011-2022 走看看