1、编辑users.views.py

...
class IndexView(View):
"""
首页
"""
def get(self, request):
return render(request, 'index.html', {})  

2、修改首页的url配置,编辑mxonline.urls.py

...
from users.views import IndexView urlpatterns = [
...
url(r'^$', IndexView.as_view(), name='index' ),
...
]

3、修改完成后,访问首页能够正常显示 

4、完成轮播图,编辑users.views.py

from .models import Banner
... class IndexView(View):
"""
首页
"""
def get(self, request):
# 按"index"降序取出前5个
banners = Banner.objects.all().order_by('-index')[:5]
return render(request, 'index.html', {
'banners': banners,
})

5、编辑index.html

6、现在我们可以进xadmin后台添加5张轮播图,然后在前端首页就可以看到效果了

完成公开课

公开课里面有一部分是轮播的,因此,我们要在课程表里面加字段,是否轮播

编辑courses.models.py

class Course(models.Model):
...
is_banner = models.BooleanField(default=False, verbose_name='是否轮播')
... //同步到数据库
manage.py@mxonline > makemigrations courses
manage.py@mxonline > migrate courses  

编辑users.views.py

class IndexView(View):
"""
首页
"""
def get(self, request):
# 按"index"降序取出前5个
banners = Banner.objects.all().order_by('-index')[:5] #取出6个不轮播的课程
courses = Course.objects.filter(is_banner=False)[:6]
#取出3个轮播课程
banner_courses = Course.objects.filter(is_banner=True)[:3]
return render(request, 'index.html', {
'banners': banners,
'courses': courses,
'banner_courses': banner_courses,
})

编辑index.html(轮播部分)

现在在后台设置几个课程允许轮播,就可以看到公开课里面轮播的效果了

还有6个不轮播的课程,我们发现这些class都不一样,从3开始的

我们可以这样来实现

完成课程机构

首先在课程机构表里添加一个"标签"字段

class CourseOrg(models.Model):
...
tag = models.CharField(max_length=10, default='全国知名', verbose_name='机构标签')
... //同步到数据库
manage.py@mxonline > makemigrations organization
manage.py@mxonline > migrate organization

编辑users.views.py

class IndexView(View):
"""
首页
"""
def get(self, request):
# 按"index"降序取出前5个
banners = Banner.objects.all().order_by('-index')[:5] #取出6个不轮播的课程
courses = Course.objects.filter(is_banner=False)[:6]
#取出3个轮播课程
banner_courses = Course.objects.filter(is_banner=True)[:3] # 课程机构
course_orgs = CourseOrg.objects.all()[:15]
return render(request, 'index.html', {
'banners': banners,
'courses': courses,
'banner_courses': banner_courses,
'course_orgs': course_orgs,
})

编辑index.html

我们发现5, 10, 15class和其他的不一样

可以这样解决,计数整除5

还剩下最后一个问题,当我们登录后,首页又不能正常显示数据了!!!这是为什么呢??

我们来看看LoginView, 直接返回的index, 而不是Index的view

我们之前做退出登录的时候有一个跳转,也里同样也要用到,所以

修改LoignVew

36、Django实战第36天:首页功能开发的更多相关文章

  1. Python django实现简单的邮件系统发送邮件功能

    Python django实现简单的邮件系统发送邮件功能 本文实例讲述了Python django实现简单的邮件系统发送邮件功能. django邮件系统 Django发送邮件官方中文文档 总结如下: ...

  2. APP UI结构-首页功能点大集锦,很干很详细

    APP UI结构的系列的文章有一段时间没有更新了,因为最近在学一些新东西和看一些新书籍,适当的给自己充电也是为了更好的输出,言归正传,今天想跟大家聊的是和首页相关的一些内容,可能有些内容最近有的小伙伴 ...

  3. 用java实现“钉钉微应用,免登进入某H5系统首页“功能”

    一.前言 哈哈,这是我的第一篇博客. 先说一下这个小功能的具体场景: 用户登录钉钉app,点击微应用,获取当前用户的信息,与H5系统的数据库的用户信息对比,如果存在该用户,则点击后直接进入H5系统的首 ...

  4. 从零开始部署Django生产环境(适用:《跟老齐学Python Django实战》)

    <跟老齐学Python Django实战>作为市面上少有的Django通俗实战书籍,给了我学习Django很大的帮助.作为一名新入门的菜鸟,全书我重复练习了至少三遍,每次都有新的收获. 前 ...

  5. FastAPI(七十)实战开发《在线课程学习系统》接口开发--留言功能开发

    在之前的文章:FastAPI(六十九)实战开发<在线课程学习系统>接口开发--修改密码,这次分享留言功能开发 我们能梳理下对应的逻辑 1.校验用户是否登录 2.校验留言的用户是否存在 3. ...

  6. 「小程序JAVA实战」小程序搜索功能(55)

    转自:https://idig8.com/2018/09/23/xiaochengxujavashizhanxiaochengxusousuogongneng54/ 通过用户搜索热销词,将热销词添加到 ...

  7. go语言实战教程之 后台管理页面统计功能开发(2)

    上节内容介绍了后台管理页面统计功能开发(1),从功能介绍,到接口请求分析和归类,最后是代码设计.经过上节内容的介绍,已经将业务逻辑和开发逻辑解释清楚,本节内容侧重于编程代码实现具体的功能. 当日增长数 ...

  8. go语言实战教程之 后台管理页面统计功能开发(1)

    本节内容我们将学习开发实现后台管理平台页面统计功能开发的功能接口,本章节内容将涉及到多种请求路由的方式. 功能介绍 后台管理平台不仅是功能管理平台,同时还是数据管理平台.从数据管理平台角度来说,在管理 ...

  9. 小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_5-2.微信扫一扫功能开发前期准备

    笔记 2.微信扫一扫功能开发前期准备         简介:讲解微信扫一扫功能相关开发流程和资料准备              1.微信开放平台介绍(申请里面的网站应用需要企业资料)          ...

随机推荐

  1. 什么是Redis的事务

    一.什么是Redis的事务 可以一次执行多个命令,本质上是一组命令的集合.一个事务中的所有命令都会序列化,然后按顺序地串行化执行,而不会被插入其它命令. 二.Redis的事务可以做什么 一个队列中,一 ...

  2. 洛谷P4593 [TJOI2018]教科书般的亵渎 【数学】

    题目链接 洛谷P4593 题解 orz dalao upd:经典的自然数幂和,伯努利数裸题 由题我们只需模拟出代价,只需使用\(S(n,k) = \sum\limits_{i = 1}^{n} i^{ ...

  3. 【BZOJ 3316】JC loves Mkk 01分数规划+单调队列

    单调栈不断吞入数据维护最值,数据具有单调性但不保证位置为其排名,同时可以按照进入顺序找出临近较值单调队列队列两端均可删除数据但只有队末可以加入数据,仍然不断吞入数据但同时可以额外刨除一些不符合条件的数 ...

  4. [NOIP2012] 文化之旅 dfs

    这道题就体现了聪明的搜索策略的重要性,如果我们正着搜,判断效率会明显下滑,所以我们就采用倒着搜索.(其实很玄学.....) #include <cstdio> #include <b ...

  5. 【BZOJ 4103】 [Thu Summer Camp 2015]异或运算 可持久化01Trie

    我们观察数据:树套树 PASS    主席树 PASS  一层一个Trie PASS 再看,异或!我们就把目光暂时定在01Tire然后我们发现,我们可以带着一堆点在01Trie上行走,因为O(n*q* ...

  6. Codeforces Round #534 (Div. 2) D. Game with modulo(取余性质+二分)

    D. Game with modulo 题目链接:https://codeforces.com/contest/1104/problem/D 题意: 这题是一个交互题,首先一开始会有一个数a,你最终的 ...

  7. 前端面试:css预处理

    css预处理定义: 定义了一种新的语言,其基本思想是用一种专门编程语言,为css增加了一些编程的特性,将css作为目标生成文件,然后开发者就只要使用这种语言进行编码工作. 几种预处理语言 sass l ...

  8. (转载)--SG函数和SG定理【详解】

    在介绍SG函数和SG定理之前我们先介绍介绍必胜点与必败点吧. 必胜点和必败点的概念:        P点:必败点,换而言之,就是谁处于此位置,则在双方操作正确的情况下必败.        N点:必胜点 ...

  9. 关于集合的size的操作

    1.创建集合: 创建指定大小的集合:(大小为5) db.createCollection(}) 2.插入五条数据: > db.colle1.insert({name:}) WriteResult ...

  10. jQuery获取表格隐藏域与ajax请求数据结合显示详情

    0.表格样式