大家看到这个标题是不是有点懵逼,其实我就是想要一个这样的效果

比如我get一条书籍的数据,在一对多的字段中我们显示一个url,看起来是不是很绚!

下面我们就来实现这么一个东西

首先我们一对多字段中的一表是 出版社表,因为我们这里要显示某个出版社的url,所以我们首先必须要为出版社的设计一个url

"""
from django.conf.urls import url
from django.contrib import admin
from django.conf.urls import include
from app1 import views
urlpatterns = [
url(r'^test/', views.test),
url(r'^test_cbv/', views.test_cbv.as_view(),name="test1"),
url(r'^test_rest/', views.Rest_view.as_view(),name="test2"),
url(r'^book_cbv/', views.Book_cbv.as_view(),name="test3"),
url(r'^publish_detail_cbv/(?P<id>\d+)', views.Pub_detail_cbv.as_view(),name="publish_url_name"),
url(r'^book_detail_cbv/(?P<id>\d+)', views.Book_detail_cbv.as_view(),name="test4"),
]

  

就是这样的一条

然后我们为出版社设计modelserializer类,所有的字段都使用默认的形式

class pubmodelserializer(serializers.ModelSerializer):
class Meta:
model = models.Publish
fields = "__all__"

  

然后我们写cbv中的c,也就是视图类

class Pub_detail_cbv(APIView):
def get(self,request,id):
obj = models.Publish.objects.filter(id=id).first() # bs = pubmodelserializer(obj,many=False,context={'request': request})
bs = pubmodelserializer(obj, many=False)
return Response(bs.data) def put(self,request,id):
obj = models.Publish.objects.filter(id=id)
bs = pubmodelserializer(obj,data=request.data)
if bs.is_valid():
bs.save() return Response(bs.data)
else:
return Response(bs.errors)

这样,基本框架就完成了,我们开始来实现超链接

首先要为每条url设计别名

因为我们要对书籍表中的某个字段做超链接处理,所以需要到书籍表的modelserializer类中为超链接字段做特殊的处理

超链接字段使用使用HyperLinkedIdentityField这个类

这个必须要有3个参数,后面会具体的分析

class bookmodelserializer(serializers.ModelSerializer):
class Meta:
model = models.Book
fields = "__all__" book_publish = serializers.HyperlinkedIdentityField(
view_name="publish_url_name",
lookup_field="book_publish_id",
lookup_url_kwarg="id" )

  

就是我截图框红的这里,下面我们来具体解释下

view_name就是这个字段我们想显示的url的别名

lookup_field字段是一个我们自定义的值,因为我们这里的类是对model对象做序列化处理,所以每个model对象都一个序列化的实例,而这个字段就是这个实例的出版社的id

lookup_url_kwarg字段就是我们的url参数,比如我们这里写的是id,那么lookup_filed这个参数对应的值就会赋值给url中命名变量为id这个变量

这里我们在看下url,因为我们的url中这里要显示的id,所以我们在lookup_fileld就要获取对应的出版社的id,所以这里大家是否清楚了,lookup_fileld要获取什么值,完全取决于我们在url中变量想要什么值;这里为什么还要指定url中的变量的名称呢?因为url中的变量可不止一个,所以必须要指定变量的名称;这里不能使用位置参数,必须使用命名参数

下面我们通过postman发送一个get请求测试一下

发现会报错

这个报错要这样解决

在视图类中序列化一个modelserializer对象的时候要这么写,其实这也是一个固定的写法,在所以实例化model对象或者queryset中均这样写就好了

class Book_detail_cbv(APIView):
def get(self,request,id):
obj = models.Book.objects.filter(id=id).first() bs = bookmodelserializer(obj,many=False,context={'request': request})
# bs = bookmodelserializer(obj, many=False,)
return Response(bs.data)

  

然后我们在测试一下

上面是django1.0版本的处理

  

===============================================================================================================

在djaong2.0中,稍微有一点不同,就是django2.0中对于二级路由的命令别名和django1.0有些改动,这里稍微做一下回忆

首先在工程的url文件中需要按照下面的格式来写

然后在对应app的url中要这么写

最后在超链接类中view_name要这样指定url的别名

其他均和在django1.0中保持一致

附上在django2.0中的所有的代码

序列化处理的代码

from rest_framework import serializers
from app1 import models
from rest_framework.views import APIView
from rest_framework.response import Response
from django.urls import reverse
class bookmodelserializers(serializers.ModelSerializer):
class Meta:
model = models.Book
fields = "__all__"
#
# book_publish = serializers.CharField(source="book_publish.publish_name")
book_publish = serializers.HyperlinkedIdentityField(
view_name= "app1:pub_detail",
lookup_field="book_publish_id",
lookup_url_kwarg="pid"
) def create(self, validated_data):
print("validated_data",validated_data,"==============================") class pubmodelserializers(serializers.ModelSerializer):
class Meta:
model = models.Publish
fields = "__all__"

  

视图类的代码

from django.shortcuts import render
from django.shortcuts import HttpResponse
from django.shortcuts import redirect
from django import views # Create your views here. class Test(views.View):
def get(self,request):
print(request,type(request))
return HttpResponse("ok") def post(self):
pass from rest_framework import serializers
from app1 import models
from rest_framework.views import APIView
from rest_framework.response import Response from app1.serializer import * class Book_modelserializer_cbv(APIView):
def get(self,request): queryset_list = models.Book.objects.all()
ret = bookmodelserializers(queryset_list,many=True)
print(dir(ret),type(ret))
return Response(ret.data) def post(self,request): ret = bookmodelserializers(data=request.data)
print("request.data",request.data,"==============================")
if ret.is_valid():
ret.save()
return Response(ret.data)
else:
return Response(ret.errors) class Book_Detail_modelserializer_cbv(APIView):
def get(self,request,bid):
obj = models.Book.objects.filter(id=bid).first() ret = bookmodelserializers(obj,many=False,context={'request': request})
return Response(ret.data) def put(self,request,bid):
obj = models.Book.objects.get(id=bid)
bs = bookmodelserializers(obj,data=request.data)
if bs.is_valid():
bs.save()
return Response(bs.data)
else:
return Response(bs.errors) def delete(self,request,bid):
models.Book.objects.get(id=bid).delete()
return HttpResponse("删除成功") from django.urls import reverse class Pub_Detail_modelserializer_cbv(APIView):
def get(self,request,pid):
obj = models.Publish.objects.filter(id=pid).first() ret = pubmodelserializers(obj,many=False,context={'request': request})
s = reverse("app1:pub_detail",kwargs={"pid":int(pid)}) return Response(ret.data) def put(self,request,pid):
obj = models.Publish.objects.get(id=pid)
bs = pubmodelserializers(obj,data=request.data,)
if bs.is_valid():
bs.save()
return Response(bs.data)
else:
return Response(bs.errors) def delete(self,request,pid):
models.Publish.objects.get(id=pid).delete()
return HttpResponse("删除成功")

  

Django1.0和2.0中的rest_framework的序列化组件之超链接字段的处理的更多相关文章

  1. rest_framework之序列化组件

    什么是rest_framework序列化? 在写前后端不分离的项目时: 我们有form组件帮我们去做数据校验 我们有模板语法,从数据库取出的queryset对象不需要人为去转格式 当我们写前后端分离项 ...

  2. Django的rest_framework的序列化组件之序列化多表字段的方法

    首先,因为我们安装了restframework,所以我们需要在django的settings中引入restframework INSTALLED_APPS = [ 'django.contrib.ad ...

  3. django rest_framework Serializers 序列化组件

    为什么要用序列化组件 当我们做前后端分离的项目~~我们前后端交互一般都选择JSON数据格式,JSON是一个轻量级的数据交互格式. 那么我们给前端数据的时候都要转成json格式,那就需要对我们从数据库拿 ...

  4. Django的rest_framework的序列化组件之serializers.ModelSerializer介绍

    这里的介绍的serializers.ModelSerializer就和我们之前学习的modelform一样 serializers.ModelSerializer如下几个功能 1.序列化queryse ...

  5. DRF 序列化组件 模型层中参数补充

    一. DRF序列化 django自带有序列化组件,但是相比rest_framework的序列化较差,所以这就不提django自带的序列化组件了. 首先rest_framework的序列化组件使用同fr ...

  6. vc6.0运用mysql数据库中的编码所导致的乱码问题(接收和输出的编码必须要一致)

    [编译中遇见的问题]       ①在用vc 6.0去调用MySQL中的数据时,出现中文乱码       ②不明白mysql中的码制 [开始解决问题]      ①打开mysql控制台         ...

  7. OpenGL2.0及以上版本中glm,glut,glew,glfw,mesa等部件的关系

    OpenGL2.0及以上版本中gl,glut,glew,glfw,mesa等部件的关系 一.OpenGL OpenGL函数库相关的API有核心库(gl),实用库(glu),辅助库(aux).实用工具库 ...

  8. android4.0浏览器在eclipse中编译的步骤

    工程源码: 注意: 如果下载已经修过的源码,只要进行3.4.8步骤就应该可以了. eclipse版本:adt-bundle-windows (Android Developer Tools Build ...

  9. 从0,1,2...n中统计0,1,2...9各出现了多少次【SWUN1597】

    题目就是说给你一个N.计算一下从0,1,2,3,4,5,,,,,,n-1,n中计算出0,1,2,3,,,,7,8,9分别出现了多少次... #include<cstdio> #includ ...

随机推荐

  1. 一次linux启动故障记录

    故障背景: 在2.6.32升级内核之后,出现多台设备启动失败,失败的全部都是ssd作为系统盘的机器,bios引导之后,屏幕就黑了,没有打印. 一开是以为是mbr损坏了,所以将启动盘挂载到其他服务器上, ...

  2. Oracle分区表常见操作

    Oracle分区表常用于业务中大表使用,如历史交易记录表等,提高表记录查询效率.本文主要描述范围分区表的创建.新增以及索引创建. Oracle操作分区表相关信息 显示数据库所有分区表的信息:DBA_P ...

  3. vue启动时报错,node-modules下xxx缺失

    从qq上拷贝了一个项目,解压后打开进vscode,安装依赖与scss后启动,显示node-modules下xxx指向缺失(想不起来是哪个缺失了),在网上找了很多解决办法,包括重新安装node 与 np ...

  4. MySQL字符集介绍及配置

    目录 1.MySQL编码集 2.修改字符集 3.MySQL数据库中字符集转换流程 4.修改现有字符集 1.MySQL编码集 查看MySQL支持的字符集 mysql> show character ...

  5. Hibernnate 一对多多对一双向关联

    Group.java package com.bjsxt.hibernate; import java.util.HashSet; import java.util.Set; import javax ...

  6. Win8系统本地连接显示为网络2

    Win8系统中,当改变了网络环境,本地连接就会被识别为网络2,网络3等: 如果在一个固定的网络环境中,需要修改此名称,可以打开注册表: [HKEY_LOCAL_MACHINE\SOFTWARE\Mic ...

  7. quartz 实例

    第一步:添加jar包 第二步:在spring配置文件中添加 <context:annotation-config/> 第三步:编写定时代码 我们通常做Java后台接口,是让前端访问的,让前 ...

  8. js 表单序列化为json对象

    $.fn.serializeJson = function () { var o = {}; var a = this.serializeArray(); $.each(a, function () ...

  9. tensorflow serving 中 No module named tensorflow_serving.apis,找不到predict_pb2问题

    最近在学习tensorflow serving,但是运行官网例子,不使用bazel时,发现运行mnist_client.py的时候出错, 在api文件中也没找到predict_pb2,因此,后面在网上 ...

  10. linux下arm汇编的常用指令解析

    1. ldr 和 str : (1) ldr 作为指令,叫做寄存器加载指令.将内存中的值加载到寄存器中. (2) ldr 作为伪指令,实现一个32位常数或地址值加载到寄存器中.后面加载的常量或地址值标 ...