Models.py中
class article(models.Model): id = models.AutoField(primary_key=True,verbose_name ='编号') title = models.CharField(max_length=100,verbose_name ='标题') content = models.CharField(max_length=20000,verbose_name ='正文') create_time = models.DateTimeField(verbose_name ='创建时间') change_time = models.DateTimeField(verbose_name ='修改时间') excerpt = models.CharField(max_length=200,blank=True,verbose_name ='摘要') type = models.ForeignKey(category,verbose_name ='类别') tags = models.ManyToManyField(tags,blank=True,verbose_name ='标签') class Meta: verbose_name = '文章列表' verbose_name_plural = '文章列表' def __str__(self): return self.title
我们可以在这基础上改进,添加其它字段,从而改变django后台admin 数据库列表字段的显示。 这个页面应该提供便利,比如说:在这个列表中可以看到编号,标题,发布时间。如果能按照编号,发布时间来排序,那就更好了。
为了达到这个目的,我们将为articel模块定义一个ModelAdmin类。 这个类是自定义管理工具的关键,其中最基本的一件事情是允许你指定列表中的字段。 打开admin.py并修改:
from django.contrib import admin from .models import category,tags,article # Register your models here. class articleAdmin(admin.ModelAdmin): list_display = ('id','title','create_time','change_time','type') #添加字段显示 search_fields = ('title','create_time') #添加快速查询栏 admin.site.register(category) admin.site.register(tags) admin.site.register(article,articleAdmin)
补充知识:Django----将列表按照一定的顺序展示
1、要求:按照文章的时间降序排列,并且只展示前5篇文章
2、需要用到:list的切片知识
###改造view.py中的视图方法 #列表页 def get_article(request): article_list = Article.objects.all(); #按照文章时间排序(并且是降序排列) order_3_list=Article.objects.order_by('-articel_date')[:3]------------->使用order_by('字段名称'),order_by('-字段名称')【前面加一个减号,表示降序】 page=request.GET.get('page'); if page: page=int(page); else: page=1; print('PAGE 参数为:',page); #实例化一个分页组件,第一个参数是需要被分页的列表,第二个参数是每一个的item个数 paginator=Paginator(article_list,2); #page方法,传入一个参数,表示第几页的列表,这边传入的page,是你在地址中写的参数 page_article_list=paginator.page(page); page_num=paginator.num_pages print('page_num:',page_num); #判断是否存在下一页 if page_article_list.has_next(): next_page=page+1; else: next_page=page; if page_article_list.has_previous(): previous_page=page-1; else: previous_page=page; return render(request,'index.html',{ 'article_list':page_article_list, "order_3_list":order_3_list,--------------->把这个东西传回前端 'page_num':range(1,page_num+1), 'curr_page':page, 'next_page':next_page, 'previous_page':previous_page }) #前端改造 <div class="col-md-3" role="complementary"> <div><h2>持续更新中......</h2> {% for article in order_3_list %} <h4><a href="get_detail/{{ article.article_id }}" rel="external nofollow" >{{article.article_title}}</a></h4> {% endfor %} </div>
查看结果,调试正常,加油↖(^ω^)↗
以上这篇Django自定义列表 models字段显示方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“Django自定义列表 models字段显示方式”评论...
更新动态
2024年11月25日
2024年11月25日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]