19、Django实战第19天:课程列表页
2024-10-21 06:45:14
从今天开始,我们将完成"公开课"课程的相关功能.....
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
最新文章
- 本博客现已迁移到chuxiuhong.com
- 浅谈Android样式开发之布局优化
- 20160816_Redis一些资料
- 解决Genymotion下载设备失败的方法(Connection Timeout)
- BZOJ 1688: [Usaco2005 Open]Disease Manangement 疾病管理
- 【转】VSync Count 垂直同步
- Android XListView实现原理讲解及分析
- Machine Learning|Andrew Ng|Coursera 吴恩达机器学习笔记
- MySql准备工作
- JQ初级
- opencart3属性attribute实现换行等简单html代码
- Jquery ajax传递xml方式在ie8下兼容问题
- Shell-16--函数
- springmvc 中@Controller和@RestController的区别
- こだわり者いろはちゃん / Iroha's Obsession (暴力枚举)
- ubuntu计划任务的编写
- 765. Couples Holding Hands
- Django全面讲解(2/2)
- appium===使用weditor代替ui automator viewer
- SpringBoot05 数据操作01 ->; JPA的基本使用、基本使用02