本篇内容主要讲解“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://lswzjz.com/article/ppdisd.html