您好,登錄后才能下訂單哦!
本篇內容介紹了“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字段顯示方式”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。