广告位 |
django无限分类
2021年9月25日 11:28编程 > 1132人已围观
简介 很多网站的首页上都会展示很多的分类,诸如:京东,淘宝,C站等等,都是利用Django模型中的自关联做的,今天做一期无限级分类的Blog! 定义了一个基本的模型用于继承(创建时间和更新时间)...
很多网站的首页上都会展示很多的分类,诸如:京东,淘宝,C站等等,都是利用Django模型中的自关联做的,今天做一期无限级分类的Blog!
?模型创建
定义了一个基本的模型用于继承(创建时间和更新时间)
from django.db import models
# Create your models here.
class BaseModel(models.Model):
create_time = models.DateTimeField(auto_now_add=True)
update_time = models.DateTimeField(auto_now=True)
class Meta:
abstract = True
class Cart(BaseModel):
name = models.CharField(max_length=50)
parent = models.ForeignKey('self', on_delete=models.CASCADE, null=True, blank=True, related_name='son')
level = models.IntegerField(null=True, blank=True)
top_parent = models.IntegerField(null=True, blank=True)
class Meta:
db_table = 'cart'
?功能实现
根据前端所需要的数据来构造数据
from rest_framework.response import Response
from rest_framework.views import APIView
from .models import Cart
from .serializer import CartSerializer
def getCart(carts):
"""
解析分类
"""
dict = {}
list = []
for i in carts:
dict[i['id']] = i
for j in carts:
parent_id = j['parent']
if parent_id:
if 'son' not in dict[parent_id]:
dict[parent_id]['son'] = []
dict[parent_id]['son'].append(j)
else:
list.append(j)
return list
class CartView(APIView):
"""
获取分类
"""
def get(self, request):
# 查询分类
cart_obj = Cart.objects.all()
cart_ser = CartSerializer(cart_obj, many=True)
cart_list = getCart(cart_ser.data)
return Response({'code': 200, 'cartList': cart_list})
?路由配置
"""
Including another URLconf
1. Import the include() function: from django.urls import include, path
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
from django.urls import path
from . import views
urlpatterns = [
path('home/', views.CartView.as_view()) # 首页分类接口
]
?前端功能
用vue-cli脚手架
<template>
<div>
<h3>无限级分类展示</h3>
<div v-for="i in cart_list">
<p v-for="j in i.son">
<span>{{ i.name }}</span>  
<span>{{ j.name }}</span> 
<span v-for="k in j.son">{{ k.name }}</span> 
</p>
</div>
</div>
</template>
<script>
export default {
data() {
return {
cart_list: []
}
},
methods: {
getCart() {
this.axios.get('cart/home/',).then(res => {
this.cart_list = res.data.cartList
})
}
},
mounted() {
this.getCart()
}
}
</script>
?效果展示
主要是实现后端功能,页面效果可忽略!
?总结
利用django模型提供的自关联构造首页数据,一级分类下面嵌套二级分类,二级分类下面嵌套三级等等,利用**related_name**实现向下查找即可!!!
下一篇: django部署静态文件访问
广告位 |
相关文章
随机图文
-
当微信的大门已打开,抖音的电商外链何时开?
近日,各大互联网平台纷纷上演一场“拆墙”行动,其中微信已经对淘宝和抖音敞开了大门。 腾讯在9月17日公布《微信外部链接内容管理规范》调整的声明,称将分阶段分步骤实施外链管理措施,第一阶段从9月17日起开始执行。具体做法包含用户可在一对一聊天场景中访问外部链接;提供自主个性化选择;设立外链投诉入口等。... -
django部署静态文件访问
技术环境: python3.8 + centos7 +Django3 + gunicorn + nginx 1、settings.py配置:静态文件访问和存放目录... -
江南布衣不江南
这家品牌,从骨子里,一贯所默认的就是西方元素能够抓住市场的眼球。但事实上,现在的中国市场,早已过了“外国的月亮比较圆”的阶段了。而江南布衣有这样的品牌文化,也与之成长路径有着密不可分的关系。... -
血管里的斑块能溶解吗
最近,李大爷经常觉得胸闷、气短、乏力。超声检查显示,他的颈动脉处有两个比较明显的斑块,多处血管腔不同程度出现狭窄和硬化。李大爷问医生:“既然血管堵了,能不能往里打点药溶解掉?现在医疗技术这么先进,斑块不能直接吸出来吗?”...