计算总成本并向购物车添加销售税

时间:2012-04-25 03:24:32

标签: django calculator cart

我正在创建一个基本的购物车应用程序,我可以在购物车中获取所有项目以填充数量和成本,但我试图找到一种方法,我可以创建总成本,并添加销售税最重要的是。显然总线是问题,但我不知道如何填充所有产品的价格和数量并将它们相乘。

{% for addtocart in userCart %}
  <li>Quantity:{{addtocart.quantity}} <a href="/products/{{addtocart.product.id}}">{{addtocart.product.prodName}}</a> ${{addtocart.product.prodPrice}}(<a
href=/delItem/{{addtocart.id}}>Remove</a>)<br>
{% endfor %}
</ul>
{% else %}
<p> No products available </p>
{% endif %}
***<p>Total: {{addtocart.quantity}}"x"{{addtocart.product.prodPrice}}***

views.py

def addtocart(request, prod_id):
        if (request.method == 'POST'):
                form = CartForm(request.POST)
                if form.is_valid():
                        newComment = form.save()
                        newComment.session = request.session.session_key[:20]
                        newComment.save()
                        return HttpResponseRedirect('/products/' + str(newComment.product.id))
        else:
                form = CartForm( {'name':'Your Name', 'session':'message', 'product':prod_id} )

        return render_to_response('Products/comment.html', {'form': form, 'prod_id': prod_id})

def userHistory(request):
        userCart = Cart.objects.filter(session = request.session.session_key[:20])
        return render_to_response('Products/history.html', {'userCart':userCart})

models.py

from django.db import models
from django.forms import ModelForm

# Create your models here.
class prod(models.Model):
        prodName = models.CharField(max_length=100)
        prodDesc = models.TextField()
        prodPrice = models.FloatField()
        prodImage = models.ImageField(upload_to="userimages/")
        def __unicode__(self):
                return self.prodName

class Cart(models.Model):
        session = models.CharField(max_length=100)
        product = models.ForeignKey('prod')
        quantity = models.IntegerField()

        def __unicode__(self):
                return self.name

class CartForm(ModelForm):
        class Meta:
                model = Cart
                exclude = ('session')

3 个答案:

答案 0 :(得分:2)

有两种方法可以做到这一点:

  1. 计算视图中的总计,并将其作为单独的变量传递
  2. 定义一个执行乘法的自定义模板标记(Django默认没有)
  3. (1)更详细:

    在您看来:

    def userHistory(request):
        userCart = Cart.objects.filter(session = request.session.session_key[:20])
        totalCost = 0
        for item in userCart:
            totalCost += item.quantity * item.product.prodPrice
        return render_to_response('Products/history.html', {'userCart':userCart,
            'totalCost': totalCost})
    

    然后在你的模板中: <p>{{totalCost}}</p>

    (2)更详细:

    首先创建一个新文件my_app / templatetags / my_tags.py(同样将__init__.py文件放在此目录中,以便Python知道它是一个包)

    from django import template
    register = template.Library()
    
    @register.filter 
    def multiply(arg1, arg2): 
        return float(arg1) * float(arg2)
    

    然后在您的模板中,在顶部添加{% load my_tags %},您就可以使用{{addtocart.quantity|multiply:addtocart.product.prodPrice}}

答案 1 :(得分:0)

快速说明:您在添加到购物车时没有记录价格。这可能是某些推车上的问题。取决于商店。

答案 2 :(得分:0)

不是将它放在你的视图中,而是将它作为你模型下的一个函数。这样,如果您必须计算应用中其他位置的总数,则无需重复使用相同的代码。

真正的问题是您使用的是不正确的模型。用户只有一个购物车,而不是很多。所以你应该使用以下模型:

class Cart(models.Model):
    session = models.CharField(max_length=100)

class CartItem(models.Model):
    cart = models.ForeignKey('Cart', related_name='items')
    product = models.ForeignKey('prod') 
    quantity = models.IntegerField()

然后,将总函数添加到购物车模型:

class Cart(models.Model):
    session = models.CharField(max_length=100)
    items = models.ManyToManyField(prod, through="CartProduct")

    def total(self):
        total = 0.0
        for item in self.items.all():
            total += (item.product.prodPrice * item.quantity)
        return total

我还要认真地建议将prod模型重命名为Product并重命名字段以匹配Django命名约定。