объект не сохраняется в корзину в Django - PullRequest
0 голосов
/ 05 февраля 2019

Я пытаюсь добавить объект в корзину, но ничего не добавлено.Я довольно новичок в Django, любая помощь приветствуется.Также я думаю, что ошибка связана с моей функцией cart_update.В этом уроке я писал так, но когда я искал эту проблему, я обнаружил, что должен использовать get_object_or_404.Когда я попытался таким образом, мне все еще не удалось добавить объекты в корзину.

models.py

from django.db import models
import os
import random
from django.db.models import Q
from django.db.models.signals import pre_save, post_save
from django.urls import reverse 
from django.shortcuts import get_object_or_404

from .utils import unique_slug_generator

def get_filename_ext(filepath):
    base_name = os.path.basename(filepath)
    name, ext = os.path.splitext(base_name)
    return name, ext

def upload_image_path(instance, filename):
    new_filename = random.randint(1,233434234)
    name, ext = get_filename_ext(filename)
    final_filename = '{new_filename}{ext}'.format(new_filename=new_filename, ext=ext)
    return "products/{new_filename}/{final_filename}".format(new_filename=new_filename, final_filename=final_filename)


class ProductQuerySet(models.query.QuerySet):
    def active(self):
        return self.filter(active=True)

    def featured(self):
        return self.filter(featured=True, active=True)

    def search(self,query):
        lookups = (Q(title__icontains=query) | 
                   Q(description__icontains=query) |
                   Q(price__icontains=query) |
                   Q(tag__title__icontains=query)
                    )
        return self.filter(lookups).distinct()

class ProductManager(models.Manager):
    def get_queryset(self):
        return ProductQuerySet(self.model, using=self._db)

    def all(self):
        return self.get_queryset().active()

    def featured(self):
        return self.get_queryset().featured()

    def get_by_id(self,id):
        qs = self.get.queryset().filter(id=id)
        if qs.count() == 1:
            return qs.first()
        return None

    def search(self,query):
        return self.get_queryset().active().search(query)

class Product(models.Model):
    title           = models.CharField(max_length=120)
    slug            = models.SlugField(blank=True,unique=True)
    description     = models.TextField()
    price           = models.DecimalField(decimal_places=2,max_digits=20,default=10.99)
    image           = models.ImageField(upload_to='gallery',null=True,blank=True)
    featured        = models.BooleanField(default=False)
    active          = models.BooleanField(default=True)
    timestamp       = models.DateTimeField(auto_now_add=True)

    objects = ProductManager()

    def get_absolute_url(self):
#        return "/products/{slug}/".format(slug=self.slug)
         return reverse("products:detail", kwargs={"slug": self.slug})

    def __str__(self):
        return self.title

def product_pre_save_receiver(sender, instance, *args, **kwargs):
    if not instance.slug:
        instance.slug = unique_slug_generator(instance)

pre_save.connect(product_pre_save_receiver, sender=Product)

В этом представлении моя функция cart_update, в которой возникает проблема.

Корзина / views.py

    from django.shortcuts import render, redirect, get_object_or_404
from products.models import Product
from .models import Cart


def cart_home(request):
    cart_obj, new_obj = Cart.objects.new_or_get(request)
    products = cart_obj.products.all()

    return render(request, 'carts/home.html', {})

def cart_update(request):
    product_id = 1 #request.POST.get('product_id')
#    print(Product.objects.get(id=1))
    if product_id is not None:
        try:
            product_obj = Product.objects.get(id=product_id)
        except Product.DoesNotExist:
            print("show message to user ,Product is gone")
            return redirect("cart:home")
        cart_obj, new_obj = Cart.objects.new_or_get(request)
        if product_id in cart_obj.products.all():
            cart_obj.products.remove(product_obj)
        else:    
            cart_obj.products.add(product_obj)
    #    return redirect(product_obj.get_absolute_url())
    return redirect("cart:home")

Ответы [ 2 ]

0 голосов
/ 05 февраля 2019

Есть несколько вещей, которые вы могли бы улучшить в своем коде:

1) Если продукт не существует (у вас "аппаратное соединение" product_id, чтобы быть 1, это может быть так) использовать ведение журнала , бывают ситуации. * Заявления 1007 * будет недостаточно.

2) Если товар уже есть в корзине, вы удалите его, оставив корзину пустой.Возможно, вы могли бы увеличить количество?

3) Условие if product_id in cart_obj.products.all() всегда будет False cart_obj.products.all(), которое вернет набор запросов для Product, а не для значений идентификатора, у вас есть две опции:

if product_id in cart_obj.products.values_list("id", flat=True)

или

if product_obj in cart_obj.products.all()

4) Я не видел ваш шаблон 'carts/home.html', но, по вашему мнению, cart_home, вы не добавляете продукты в контекст представления и, поКстати, поскольку вы можете получить доступ к продуктам в корзине через саму корзину (они связаны), вам не нужна строка products = cart_obj.products.all().Просто добавьте cart_obj в контекст просмотра

def cart_home(request):
    cart_obj, new_obj = Cart.objects.new_or_get(request)
    return render(request, 'carts/home.html', {"cart": cart_obj}) 

и напишите в шаблоне код, подобный следующему:

<ul>
{% for product in cart.products.all %}
    <li>{{ product.title }}</li>
{% endfor %}
</ul>

Надеюсь, вы сможете найти ошибку при проверке одного из них,Удачного кодирования!

0 голосов
/ 05 февраля 2019

Вы также можете проверить new_obj на наличие найденного предмета, насколько я понимаю ...

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...