我觉得在有些应用场景下,这个操作是有用的,因为可以减少一个AJAX的请求,以增加性能。

当然,是二次请求,还是一次传输。这即要考虑用户体验,还要兼顾服务器性能。

一切是有条件的平衡吧。就算是一次传输,字段少的可以全部传,而字段多的就要自定义啦。

在以下样例里,发布单是主表,但相关的项目,组件,用户,如果默认情况下,只显示ID,很不友好。

我们可以将相关的外键名称也一并序列化啦。

重点的DRF:

class UserSerializer(serializers.ModelSerializer):

    class Meta:
        model = User
        fields = ('id', 'username', 'email', 'first_name', 'last_name', 'is_superuser')

class SiteSerializer(serializers.ModelSerializer):

    class Meta:
        model = Site
        fields = ('id',  'name')

class AppSerializer(serializers.ModelSerializer):

    class Meta:
        model = App
        fields = ('id', 'name')

class DeployPoolSerializer(serializers.ModelSerializer):
    site = SiteSerializer(source='site_name') #如有问题,记得那个read_only,many之类的参数,然后看官方文档
    app = SiteSerializer(source='app_name')
    create_user = UserSerializer()

    class Meta:
        model = DeployPool
        fields = ('id',  'name', 'description', 'site', 'app', 'branch_build',
                  'jira_issue_no', 'create_user', 'change_date')
        read_only_fields = ('name',)

  

angular服务和控制器:

prismVersion.factory("versionSrv", ['$resource', function ($resource) {
    return $resource(
        "http://127.0.0.1:8000/server_api/version_api/:Id",
        {Id: "@Id" },
        {'query': {method: 'GET' }},
        {update: {method: "PUT"}}
    );
}]);

prismVersion.factory("siteSrv", ['$resource', function ($resource) {
    return $resource(
        "http://127.0.0.1:8000/server_api/site_api/:Id",
        {Id: "@Id" },
        {'query': {method: 'GET' }},
        {update: {method: "PUT"}}
    );
}]);

prismVersion.controller('versionCtrl',
    ['$scope','versionSrv','siteSrv',
        function($scope,
            versionSrv, siteSrv){
                $scope.versions = versionSrv.query();
}]);

angular显示:

<tr ng-repeat="item in versions.results">
                                <td>
                                    <a href="#" target="_blank">{{item.id}}-{{item.name}}</a>

                                </td>

                                <td>
                                    <a href="#">
                                        {{item.app.id}}-
                                        {{item.app.name}}
                                    </a>

                                </td>
                                <td>
                                    <a href="#">
                                        {{item.site.id}}-
                                        {{item.site.name}}
                                    </a>
                                </td>
                                <td>
                                    {{item.branch_build}}
                                </td>

                                 <td>
                                        <a href="#">
                                         {{item.jira_issue_version}}
                                     </a>
                                </td>
                                <td>
                                    {{item.create_user.id}}-
                                    {{item.create_user.username}}
                                </td>

                                <td>
                                    {{item.change_date}}
                                </td>
                            </tr>

  LOOK:

DRF如何序列化外键的字段的更多相关文章

  1. MySql数据库在表中添加新字段,设置主键,设置外键,字段移动位置,以及修改数据库后如何进行部署和维护的总结

    1,为当前已有的表添加新的字段 alter table student add studentName varchar(20) not null; 2,为当前已有的表中的字段设置为主键自增 alter ...

  2. django rest framework如何实现nest field显示,如何保存有外键的字段更新

    一步一步深入了. 相关设置技巧如下: 直接nest field显示: class VersionPoolSerializer(serializers.ModelSerializer): site_na ...

  3. DRF 有无外键操作实例

    models.py from django.db import models # Create your models here. class Category(models.Model): &quo ...

  4. MS SQL巡检系列&mdash;&mdash;检查外键字段是否缺少索引

    前言感想:一时兴起,突然想写一个关于MS SQL的巡检系列方面的文章,因为我觉得这方面的知识分享是有价值,也是非常有意义的.一方面,很多经验不足的人,对于巡检有点茫然,不知道要从哪些方面巡检,另外一方 ...

  5. 总结: MySQL(基础,字段约束,索引,外键,存储过程,事务)操作语法

    1. 显示数据库列表 show databases; # 查看当前所有数据库 show databases \G   #以行的方式显示 2. 在命令行中,执行sql语句 mysql -e 'show ...

  6. 2-16 MySQL字段约束-索引-外键

    一:字段修饰符 1:null和not null修饰符 我们通过这个例子来看看 mysql> create table worker(id int not null,name varchar(8) ...

  7. mysql字段约束-索引-外键---3

    本节所讲内容: 字段修饰符 清空表记录 索引 外键 视图 一:字段修饰符 (约束) 1:null和not null修饰符   我们通过这个例子来看看 mysql> create table wo ...

  8. mysql之字段的修改,添加、删除,多表关系(外键),单表详细操作(增删改)

    字段的修改.添加和删除 create table tf1( id int primary key auto_increment, x int, y int ); #修改 alter table tf1 ...

  9. drf框架 - 序列化组件 | ModelSerializer (查,增,删,改)

    ModelSerializer 序列化准备: 配置 settings.py # 注册rest_framework框架 INSTALLED_APPS = [ ... 'rest_framework' ] ...

随机推荐

  1. Yii2 发送邮件

    http://www.cnblogs.com/wwolf/p/5438691.html?utm_source=tuicool&utm_medium=referral

  2. xshell5.0实现中键复制

    1. 右建点击黑色屏幕 2. 在打开选项 3. 勾选 ""

  3. SQL Server数据库还原:&quot;因为数据库正在使用,所以无法获得对数据库的独占访问权&quot;

    如题,网上找了一些客套的方法,如果不想去折腾,请看我的方法: 1.先脱机数据库,这个目的就是为了停掉所有链接 2.选择还原数据库,如果提示日志尾部不完整,请选择数据库属性的选项,覆盖现有数据. 还可以 ...

  4. PHP开发经验总结

    1.使用内嵌的HTML代码,而不是PHP的echo语句. 因为PHP是一门嵌入式Web编程语言,可以将HTML代码和PHP代码相互嵌入.但是很多程序员担心在HTML代码中过多的使用”"嵌入P ...

  5. Install_ruby

    Install rvm 1 2 3 $ curl -L get.rvm.io | bash -s stable $ source ~/.bashrc $ source ~/.bash_profile ...

  6. ASP.NET 全局变量和页面间传值方法

    http://www.cnblogs.com/dgjack/archive/2011/05/28/2060913.html 1. 使用QueryString变量 QueryString是一种非常简单的 ...

  7. Linux 系统管理06--磁盘管理

    Linux系统管理06——磁盘管理 一.磁盘结构 1.硬盘的物理结构 盘片:硬盘有多个盘片,每个盘片2面 磁头:每面一个磁头 2.硬盘的数据结构 扇区:盘片被分为多个扇形区域,每个扇形区存放512字节 ...

  8. snort安装使用教程(CentOS6.5)

    官网:https://www.snort.org/ 官方文档:https://www.snort.org/documents 2.安装 2.1安装依赖 yum install flex bison - ...

  9. uva-321-暴力枚举-隐式图搜索

    题意:给你n个房间,有许多灯的控制开关,i房间灯的开关在j房间,未开灯的房间不能进,i房间和j房间之间如果没有门,也不能从i进入到j,开始房间是1,并且灯是开着的,问你是否能够走到最后一个房间n,并且 ...

  10. POJ 2575

    #include<iostream> #include<set> #include<stdio.h> using namespace std; int my_abs ...