请求无法到达我的 Django 视图

问题描述 投票:0回答:1

这是一个 Web Django 项目,在我的导航栏中,我有一个下拉菜单,其中包含根据类别探索产品的按钮,以下是主模板中下拉列表片段的代码:

<li class="nav-item dropdown">
          <a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
            Product Categories
          </a>
          <div class="dropdown-menu" aria-labelledby="navbarDropdown">
            <button data-category = "cloths" class="product-category dropdown-item btn btn-light">Cloths</button>
            <button data-category = "sport" class="product-category dropdown-item btn btn-light">Sport</button>
            <button data-category = "household items" class="product-category dropdown-item btn btn-light">Household items</button>
          </div>
        </li>

我使用 csrf 令牌进行发布请求,这是 javascript 片段:

var productCategories = document.getElementsByClassName("product-category")
for ( i = 0 ; i < productCategories.length ; i ++ )
{
    productCategories[i].addEventListener('click', function(){
        var category = this.dataset.category
        console.log(category)
        exploringCategory(category)
    })
}
function exploringCategory(category)
{
    var url = 'category_exploring/'
    fetch(url,{
        method:'POST',
        headers:{
            'Content-Type' : 'application/json',
            'X-CSRFToken': csrftoken,
        },
        body:JSON.stringify({'category' : category})
    })
}

这是视图:

def category_exploring(request):
    data = json.loads(request.body)
    category = data['category']
    print('*')
    print(category)
    user = request.user
    products = Product.objects.filter(category=category)
    order, created = Order.objects.get_or_create(customer = user, complete = False)
    cartItems = order.get_total_order_cnt
    context = {'products' : products, 'cartItems': cartItems}
    return render(request, 'store/store.html', context)

问题是当我点击按钮时没有任何反应,我该怎么办?

javascript python django
1个回答
0
投票

我看到您正在尝试在category_exploring()函数中渲染模板,所以为什么不直接创建一个指向该url的a标签。这样就不需要js和post请求了...

<a href="{% url 'category_exploring' 'cloths' %}" data-category = "cloths" class="product-category dropdown-item btn btn-light">Cloths</a>
<a href="{% url 'category_exploring' 'sport' %}" data-category = "sport" class="product-category dropdown-item btn btn-light">Sport</a>
<a href="{% url 'category_exploring' 'household-items' %}" data-category = "household items" class="product-category dropdown-item btn btn-light">Household items</a>

只需更新category_exploring()函数以接受category_slug并使用此变量进行所有过滤...

def category_exploring(request, category_slug):
    pass

和网址

path("category_exploring/<category_slug>/list", category_exploring, name='category_exploring')
© www.soinside.com 2019 - 2024. All rights reserved.