最近在拿天天生鲜练手,看到 购物单表 CartInfo:[ pk, user, goods, count]
直接把购物单返回给templates,
@user_decorator.login
def orderForm(request):
uid = request.session['user_id']
carts = CartInfo.objects.filter(user_id=uid)
# 通过debug,发现carts[1]里面是有goods这个属性类的,里面是相关外键的信息
context = {
'title': '天天生鲜——购物车',
'loginName': '购物车',
'iscart': 1,
'carts': carts,
}
return render(request, 'Cart/cart.html', context)
看到大概是这样的
{% for cart in carts %}
<ul class="cart_list_td clearfix">
<li class="col01"><input type="checkbox" name="" checked></li>
<li class="col02"><img src="/static/{{ cart.goods.goodsPicture }}"></li>
<li class="col03">{{ cart.goods.goodsTitle }}<br><em>{{ cart.goods.gprice }}元/{{ cart.goods.goodsUnit }}</em></li>
<li class="col04">{{ cart.goods.goodsUnit }}</li>
<li class="col05">{{ cart.goods.gprice }}</li>
<li class="col06">
<div class="num_add">
<a href="javascript:;" class="add fl">+</a>
<input type="text" class="num_show fl" value="{{ cart.count }}">
<a href="javascript:;" class="minus fl">-</a>
</div>
</li>
<li class="col07">25.80元</li>
<li class="col08"><a href="javascript:;">删除</a></li>
</ul>
{% endfor %}
我定义的商品表
# 商品表 (没通过__str__起别名)
class GoodsInfo(models.Model):
# 标题
goodsTitle = models.CharField(max_length=20)
# 商品类型
goodsType = models.ForeignKey(TypeInfo, on_delete="CASCADE")
# 照片(上传)
goodsPicture = models.ImageField(upload_to='images/goods/')
# 价格
gprice = models.DecimalField(max_digits=6, decimal_places=2)
...
按照一贯作风,在templates中对通过cart外键查询商品表应该是{{ cart.GoodsInfo_set.all()[0].goodsTitle }} 之类的。
什么 时候冒出来个goods属性来的呢?通过debug 查了一下。cart对象还真的有goods对象,里面是我需要的商品信息
不明白什么机制使得命名改变了,不过Django能通过外键直接在templates这个思路是没问题的。就是实现的时候,需要自己好好查查。特此记录一下。如有大神知道的,还请赐教。