您好,登录后才能下订单哦!
本篇内容主要讲解“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 = 7
order_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值”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。