这是一个 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)
问题是当我点击按钮时没有任何反应,我该怎么办?
我看到您正在尝试在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')