19、Django实战第19天:课程列表页
从今天开始,我们将完成"公开课"课程的相关功能.....
1、把course-list.html复制到templates目录下
2、这个页面的头部、底部与之前定义的base.html模板是一样的,所以我们可以继承它,编辑course-list.html

3、在app.courses下新建urls.py文件,以后我们把课程相关的url都放在这个文件下
4、编辑项目根下的urls.py,把courses下面的urls.py包含进去
urlpatterns = [
...
#课程相关url配置
url(r'course/', include('courses.urls', namespace='course')), ]
5、我先把页面展示出来,编写个view,编辑courses.views.py
from django.shortcuts import render
from django.views.generic import View class CourseListView(View):
def get(self, request):
return render(request, 'course-list.html', {})
6、添加一条url,编辑courses.urls.py
from django.conf.urls import url
from .views import CourseListView urlpatterns = [
url(r'^list/$', CourseListView.as_view(), name='course_list'), ]
7、我修改下首页的导航

8、现在可以访问到课程列表页了,点击首页中的公开课或者http://127.0.0.1:8000/course/list/

默认是"最新",先来完成这部分,编辑views
...
from .models import Course class CourseListView(View):
def get(self, request):
all_courses = Course.objects.all().order_by('-add_time') #根据时间排序 return render(request, 'course-list.html', {
'all_courses': all_courses,
})
编辑course-list.html

分页功能
编辑views

加了分页以后,页面的for循环那里要改下

页码部分

"最热门"和"参与人数"排序
编辑vires
from django.shortcuts import render
from django.views.generic import View
from .models import Course
from pure_pagination import Paginator, PageNotAnInteger class CourseListView(View):
def get(self, request):
all_courses = Course.objects.all().order_by('-add_time') #根据时间排序 #课程排序
sort = request.GET.get('sort', '')
if sort:
if sort == 'host':
all_course = all_courses.order_by('-click_nums')
elif sort == 'students':
all_courses = all_courses.order_by('-students') # 对课程进行分页
try:
page = request.GET.get('page', 1)
except PageNotAnInteger:
page = 1 p = Paginator(all_courses, 3, request=request)
courses = p.page(page) return render(request, 'course-list.html', {
'all_courses': courses,
'sort': sort,
})
编辑前端course-list.html

热门课程推荐
编辑views

前端页面

访问页面后,发现存在一个问题,就是课程难度那里显示的是我们数据库中的字母

那么该如何显示我们在model中设置的中文部分呢???

Django专门为choice设置了一种用法,编辑course-list.html

19、Django实战第19天:课程列表页的更多相关文章
- [py][mx]django模板继承-课程列表页
		
课程列表页分析 1,机构类型 2,所在地区 3.排序 学习人数 先分析下 纵观页面,页头页脚都一样. django提供了模板继承. 至少 不同页面的title 面包屑路径 content内容不一致,以 ...
 - mxonline实战10,课程列表页,课程详情页1
		
对应github地址:第10天 一. 课程列表页 1. 拷贝course-list.html到templates目录中 2. 编写url和view 在courses/views.py中新加
 - mxonline实战13,授课讲师列表页,详情页,index页面全局导航
		
对应github地址:第13天 把teacher-list.html和teacher-detail.html拷贝过来 一. 授课讲师列表页 1. 修改html文件 把org-list.ht ...
 - 微信小程序 项目实战(三)list 列表页 及 item 详情页
		
1.项目结构 2.list 列表页 (1)数据(逻辑) list.js // pages/list/list.js Page({ /** * 页面的初始数据 */ data: { title: '加载 ...
 - Django实战(19):自定义many-to-many关系,实现Atom订阅
		
记得有人跟我说过,rails的has_many :through是一个”亮点“,在Django看来,该功能简直不值一提.rails中的many-to-many关联中,还需要你手工创建关联表(写 mig ...
 - [Django实战] 第8篇 - 分页列表
		
当用户登录成功后,首先看到的是他自己之前提交的任务列表,本篇将实现该页面. 视图(views.py)里定义如下: from django.core.paginator import Paginator ...
 - 14、Django实战第14天:列表筛选功能
		
今天完成的是点击这些条件进行机构的筛选 首先来完成城市:当用户点击城市的时候,我们自动给它加一个参数(city.id) 编辑organization.views.py 刷新页面,发现筛选功能已经OK了 ...
 - 20、Django实战第20天:课程详情页
		
1.把course-detail.html复制到templates目录下 2.编辑course-detail.html,分析页面,继承base.html 3.编辑courses.views .... ...
 - 16、Django实战第16天:优化url
		
今天完成的是一个优化url.... 前面我们所有的url都是配置在一个mxonline.urls.py中.因为我们根据项目实际情况配置了多个app,那么我们相应的url是可以配置在自己的app中的,这 ...
 
随机推荐
- [ZJOI2006]物流运输 DP 最短路
			
---题面--- 题解: 设f[i]表示到第i天的代价,cost[i][j]表示第i天到第j天采取同一种方案的最小代价.那么转移就很明显了,直接$n^2$枚举即可. 所以问题就变成了怎么获取cost数 ...
 - [Leetcode] Symmetric tree 对称二叉树
			
Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center). For e ...
 - jquery从零起步学
			
html: <HTML> <head> <meta http-equiv="content-type" content="text/html ...
 - eclipse调试java技巧
			
详细内容请看: http://www.oschina.net/question/82993_69439
 - struts2和jstl有关循环的写法
			
一:前言 其实觉得自己现在就是个码农啊,对于struts2的标签和jstl的标签我一直都是只会用,但是觉得自己老是会混淆这种概念性的问题.所以我自己在代码里面就试着用了几种方式,实现同一种效果,下面就 ...
 - 【Atcoder】ARC 080 F - Prime Flip
			
[算法]数论,二分图最大匹配 [题意]有无限张牌,给定n张面朝上的牌的坐标(N<=100),其它牌面朝下,每次操作可以选定一个>=3的素数p,并翻转连续p张牌,求最少操作次数使所有牌向下. ...
 - [bzoj2002][Hnoi2010]Bounce弹飞绵羊——分块
			
Brief description 某天,Lostmonkey发明了一种超级弹力装置,为了在他的绵羊朋友面前显摆,他邀请小绵羊一起玩个游戏.游戏一开始,Lostmonkey在地上沿着一条直线摆上n个装 ...
 - 在生成的Debug中test.exe的同级目录下创建一个文件,如TestLog.log
			
在上次编写一个日志类库时,想在.exe的同级目录下创建.log文件,对于这个路径的获得很简单,调用GetModuleFileName()函数即可.但是要去掉.exe而换成.log时,由于对字符串处理不 ...
 - win端git连接私服仓库+上传本地项目+从服务器下载文件到win
			
win端git连接私服仓库: 1.win端 检查c:/Users/用户/.ssh/目录下是否有config文件(!!!没有任何后缀名).如果没有则新建config文件,然后修改添加如下内容: Host ...
 - 慎用Java递归调用
			
总结:慎用Java递归调用,测试时可以尝试该方法,否则尽量不要使用递归!递归过多调用时,最好改为for或者whlie来代替. 在java语言中,使用递归调用时,如果过多的调用容易造成java.lang ...