本篇内容主要讲解“django如何通过get_FOO_display 查找模型中的choice值”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“django如何通过get_FOO_display 查找模型中的choice值”吧!
在 django 的 models.py 中,我们定义了一些 choices 的元组,类似一些字典值,比如一个订单状可能有多种状态,这时订单状态这个字段就可以用 choice ,在数据库中 status 保存的是数字整型。
status = models.IntegerField(verbose_name="订单状态", choices=order_status_choice,)
订单状态数字对应的状态含义可以用元组绑定,这样写比较灵活,数字可以随便改。
class MainOrderStatus(object): wait_order_check = 1 wait_finance_check = 2 wait_out_stock_confirm = 3 wait_delivery_confirm = 4 success = 5 invalid = 6 cancel = 7order_status_choice = ( (MainOrderStatus.wait_order_check, "待订单审核"), (MainOrderStatus.wait_finance_check, "待财务审核"), (MainOrderStatus.wait_out_stock_confirm, "待出库确认"), (MainOrderStatus.wait_delivery_confirm, "代发货确认"), (MainOrderStatus.success, "已完成"), (MainOrderStatus.invalid, "已作废"), (MainOrderStatus.cancel, "已取消"),
但是在前端页面展示订单状态的时候,在 django 框架中可以用 get_FOO_display() 获取数字对应的订单状态。本例可以用 order_status = main_order.get_status_display() 获取该订单的状态。FOO 是对应模型中的字段。
在代码中尽量不要出现固定的硬编码,比如某个判断条件,判断订单的状态为待订单审核,你可能会这么写:
if status == 1: pass
比较灵活的写法应该是这样的:
if status == MainOrderStatus.wait_order_check: pass
到此,相信大家对“django如何通过get_FOO_display 查找模型中的choice值”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/u/4579283/blog/4351096