温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Django怎么自定义 models字段显示方式

发布时间:2021-03-11 16:55:41 来源:亿速云 阅读:128 作者:TREX 栏目:开发技术

本篇内容介绍了“Django怎么自定义 models字段显示方式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

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><h3>持续更新中......</h3>    {% for article in order_3_list %}    <h5><a href="get_detail/{{ article.article_id }}" rel="external nofollow" >{{article.article_title}}</a></h5>    {% endfor %}   </div>

查看结果,调试正常,加油↖(^ω^)↗

“Django怎么自定义 models字段显示方式”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI