演示地址: http://mxonline.mtianyan.cn
教程仓库地址1: https://github.com/mtianyan/DjangoGetStarted
教程仓库地址2: https://github.com/mtianyan/Mxonline2
教程仓库地址3: https://github.com/mtianyan/Mxonline3
7-1 django templates模板继承1
- 机构可以筛选类别
- 机构可以根据所在地区进行分类
右侧我要学习功能: form表单提交
右下:授课机构排名
页面头部与底部为全局头和全局底部。
Django template 共用头部底部机制
将head和foot放在两个html中,然后在写其他需要这两个部分的页面时include进来。
Django也是支持include机制的。
include的问题
include的进来的死页面,这时候该怎么办?
解决这种问题:进行模板的继承机制。定义一个父类的框架,子类可以替换其中一部分block,子类只需要重写自己需要改变的block。
template中新建base.html
将课程机构列表页。orglist拷贝进template目录
将orglist内容替换base内容。
data:image/s3,"s3://crabby-images/82fe9/82fe96285b00aa047d910eb017601f943fd34c44" alt=""
将div收起来
data:image/s3,"s3://crabby-images/ee74f/ee74f89d7a6ad3a12954f380ec1310cbf156e982" alt=""
loadstaticfiles & 修改静态文件路径为static
这个步骤做过太多遍了,自行完成。耐心就行了。
定义父模板: 包含head & footer
title应该是可以被子页面替换的所以要包起来。
data:image/s3,"s3://crabby-images/5b011/5b011b4f71450c294de7f8b204a01b57be38e9ab" alt=""
css有共用的部分,也有可以被子页面替换的部分。
data:image/s3,"s3://crabby-images/abbe3/abbe3820e4849773aaabc57d78b0cb98f2a6c4a1" alt=""
js同理
data:image/s3,"s3://crabby-images/ec0ad/ec0ad3afc477ea82593415e2268985904fa0bf21" alt=""
面包屑是需要被各个页面自己替换的。
data:image/s3,"s3://crabby-images/a648e/a648e0196279358ac4cbd111c03c77071a5d0183" alt=""
将正文内容包起来;
data:image/s3,"s3://crabby-images/36c21/36c213d31789d3536b8a1e50edcfdc7742c26e2e" alt=""
此时base页面就制作好了
7-2 开始orglist编写
第一步:清空所有内容
- 继承base页面
data:image/s3,"s3://crabby-images/4b992/4b99266a71e570aec5909dc178fa80b7210bc77e" alt=""
- 覆盖父类的title
data:image/s3,"s3://crabby-images/01045/01045fbbfd36d085ff5f188b22c231f01776590c" alt=""
- 书写课程机构view
organization/views.py
# encoding: utf-8
from django.views.generic.base import View
# 处理课程机构列表的view
class OrgView(View):
def get(self,request):
return render(request, "org-list.html", { })
- Django2.0.1配置课程机构首页url
# 课程机构首页url
path('org_list/', OrgView.as_view(), name="org_list"),
- Django1.9.8配置url:
# 课程机构首页url
url(r'^org_list/$', OrgView.as_view(), name="org_list"),
修改面包屑
-
base中只保留首页
-
org中重写block custom_bread
-
block之间没有先后顺序。
-
将base中block content拿到orglist重写
data:image/s3,"s3://crabby-images/2be2e/2be2e7a17f74d444356860c5bcd1517e4ad81996" alt=""
- 然后将base中block中间section删除掉
data:image/s3,"s3://crabby-images/7d068/7d068a1b90706570499e95202239cda46a5038e0" alt=""
orglist开始loadstaticfiles
ctrl+d
快速删除
data:image/s3,"s3://crabby-images/3398b/3398b9213a67ffbfcad349de3460114885fda120" alt=""
页面的继承关系使得变量也可以直接用
比如user中的form数据传递到register文件当中.如果register继承的是base页面。
base页面当中也是可以用这些数据的。参数的向上传递
每个request对象都会传递到html中来,如果继承了base,request也会向上传递到base。
base中就可以加入我们的逻辑: 用户是否登录等。
小节结束对应commit:
完成Django templates的继承关系了解,机构列表展示页。对应7-1 & 2
7-3 课程机构列表页数据展示1
确定由后台传过来的动态数据:
授课机构列表本身, 授课机构的排名,所在地区(后台取出所有地区), 机构类别写成静态,因为一般不怎么变动。
在xadmin中添加城市信息,课程信息。
添加城市
data:image/s3,"s3://crabby-images/a8968/a89689a88397bd0dede9be5135b2d312c5af8525" alt=""
添加机构。
插播知识点:
data:image/s3,"s3://crabby-images/34890/34890e0ade7c1d9754a43a847ae841bea81d3ea9" alt=""
这里指定的路径是一个相对路径
setting中要配置我们把文件存放在哪个根目录之下
# 设置我们上传文件的路径
MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
在项目根目录创建media文件夹
在后台上传图片
data:image/s3,"s3://crabby-images/e93ad/e93ad6ca4df3ecc60e0f93b4965237ca5d14d6a1" alt=""
data:image/s3,"s3://crabby-images/0e36c/0e36c59715e066b53683164cb6ad763a76f391e8" alt=""
修改机构信息中封面图为logo
自行添加十个课程机构
models中添加机构类别
organization/models.py:
class CourseOrg(models.Model):
ORG_CHOICES =(
("pxjg", u"培训机构"),
("gx", u"高校"),
("gr", u"个人"),
)
name = models.CharField(max_length=50, verbose_name=u"机构名称")
# 机构描述,后面会替换为富文本展示
desc = models.TextField(verbose_name=u"机构描述")
# 机构类别:
category = models.CharField(max_length=20, choices=ORG_CHOICES, verbose_name=u"机构类别", default="pxjg")
修改了models之后做数据库的变动:
makemigrations organization
migrate organization
data:image/s3,"s3://crabby-images/bf951/bf9514c9f1c5b6482ba40981b11dd0edb014262b" alt=""
完成之后打开Navicat进行验证:
data:image/s3,"s3://crabby-images/d21de/d21decf985eded15d28651315f47743fb6f441a6" alt=""
可以看到新增了。
完善我们的view
将列表里的静态数据变成后台获取的动态数据
organization/views.py
from .models import CourseOrg, CityDict
class OrgView(View):
def get(self,request):
# 查找到所有的课程机构
all_orgs = CourseOrg.objects.all()
# 取出所有的城市
all_citys = CityDict.objects.all()
return render(request, "org-list.html", {
"all_orgs":all_orgs,
"all_citys": all_citys,
})
网友评论