django如何通过get_FOO_display查找模型中的choice值

本篇内容主要讲解“django如何通过get_FOO_display 查找模型中的choice值”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“django如何通过get_FOO_display 查找模型中的choice值”吧!

创新互联云计算的互联网服务提供商,拥有超过13年的服务器租用、四川绵阳服务器托管、云服务器、网页空间、网站系统开发经验,已先后获得国家工业和信息化部颁发的互联网数据中心业务许可证。专业提供云主机、网页空间、域名注册、VPS主机、云服务器、香港云服务器、免备案服务器等。

在 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值”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


本文标题:django如何通过get_FOO_display查找模型中的choice值
文章出自:http://pwwzsj.com/article/ppdisd.html