V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
volvo007
V2EX  ›  Django

Django admin 当中动态显示外键的相关属性

  •  
  •   volvo007 · 2022-02-02 12:01:00 +08:00 · 2755 次点击
    这是一个创建于 1055 天前的主题,其中的信息可能已经有所发展或是发生改变。

    想了半天也不知道怎么用简洁的方式描述, 所以搜索引擎里面也没找到特别对应的方法.

    需求上大概是这么描述:

    1. 有一个包括一些静态属性的表, 比如用户表. 里面有两条记录是 id=1, name='Tom', age=28, id=2, name='Tom', age=35. 注意到有两个同名的用户, 是用id 保证唯一性的
    2. 现在还有一个项目表, 要将项目分派给某个人. 出于使用上的考虑, 肯定不会直接提供 id 让用户填写, 一般都是提供 name 比较合理. 这里的问题是, name 字段是有重名情况的

    所以我的需求是, 当用户选择了 Tom 这个人的时候, 会动态显示这个 Tom 的其他属性在页面上, 可以显示在表单里自动补全, 也可以做个模态框都行(但模态框最好是做个问号图标, 鼠标悬停在上面就显示)

    这样一来, 虽然有名字重名的情况, 但我可以通过这个人的其他属性分辨出来某个项目是否分配给了合适的人 (age 当然也会重复, 这里只是举个例子)

    如果是 django 里面自己写的页面, 用 ajax 向数据库查询一下应该就好了, 但是现在暂时要利用一下现成的 django admin 模块的话, 要怎么在 django admin change 页面实现这个功能呢?

    我找过一些方法, 比如扩展 django admin change 这个模版之类的, 但不确定这么做是不是最佳实践

    谢谢大佬们赐教


    明明选了 markdown 格式, 但是不知道为什么没有正确显示代码引用……

    5 条回复    2022-02-02 23:34:18 +08:00
    izoabr
        1
    izoabr  
       2022-02-02 12:46:20 +08:00   ❤️ 1
    如果坚持要用自带的 admin ,就直接定义这个用户模型的__str__()吧
    ```python

    def __str__():
    return f"{self.department.name}_{self.name}"

    ```
    volvo007
        2
    volvo007  
    OP
       2022-02-02 12:54:13 +08:00
    @izoabr 哈哈好的, 这好像是个非常简单的办法. 相关的字段都一股脑合并扔到回显字段里😂
    freakxx
        3
    freakxx  
       2022-02-02 22:57:40 +08:00   ❤️ 1
    https://stackoverflow.com/a/23747842

    一楼的办法太 hardcode 了,
    正确的办法是自定义一个函数,然后在里面返回需要的数据
    volvo007
        4
    volvo007  
    OP
       2022-02-02 23:25:14 +08:00
    @freakxx 好的, 我回头试试. 看起来要点是在函数里拿到外键相关联的 object, 拿到之后调用这个 object 的属性返回就可以了
    izoabr
        5
    izoabr  
       2022-02-02 23:34:18 +08:00
    @freakxx #3 哦,对哦,没想到这个,一直都没怎么用 admin ,感谢!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1319 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 17:30 · PVG 01:30 · LAX 09:30 · JFK 12:30
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.