为了完成小姐姐安排的打分系统,又熬了一个小时的夜补充视图与模板

橡皮擦,一个逗趣的互联网高级网虫。新的系列,让我们一起进入 Django 世界。

已经完成的文章

十三、视图与模板

第十二篇博客已经初步构建好了后台管理页面,接下来继续对 Django 的视图与模板进行学习。

13.1 打分系统的视图

Django 中每一个页面都是通过视图进行展示的,而视图背后对应的都是 Python 中的函数或者类中的方法,在 Django 中通过 URLconfs 进行视图匹配。这里涉及一个新的概念,叫做 URL 模式字符串,对应的浏览器地址栏里面的 /aaa/bbb/ccc 这类内容。

scoring/views.py 文件中添加如下代码,分别是 3 个视图,其中部分数据为测试用数据。

# 打分系统首页
def index(request):
    return HttpResponse("小姐姐打分系统")

# 客户详情&打分页面
def detail(request, _id):
    return HttpResponse(f"客户ID为{_id}")

# 客户分数查阅
def show_score(request, _id):
    totle = 0
    return HttpResponse(f"客户 {_id} 的总分是 {totle}")

views.py 文件中的内容添加完毕,即可修改 scoring/urls.py 中的 URL 模式字符串了,具体如下:

urlpatterns = [
    path("", views.index, name="index"),
    path("<int:_id>/", views.detail, name="detail"),
    path("<int:_id>/score", views.show_score, name="show_score"),
]

此时还需要关注的一个文件是 settings.py,在该文件中存在一个配置项如下:

ROOT_URLCONF = 'cutegirl.urls'

上述配置项决定了当用户访问的 URL 携带 scoring 时,Django 会自动跳转到 scoring.urls 中进行匹配。

现在可以通过访问下述地址获取不同的展示结果了。

http://127.0.0.1:8000/scoring/2/
http://127.0.0.1:8000/scoring/2/score

代码中 <int:_id> 在后续博客中会补充相应的说明,基本含义是前面是数据类型,后面是视图的参数名。

13.2 重拾模板

scoring 目录下新建一个目录叫做 templates ,然后在 templates 中再创建一个文件夹 ttt,这个文件名可以任意,甚至可以创建多套模板都没有问题。

在编写代码前,先通过命令行向 sqlite 中输入一些数据。

> python manage.py shell
>>> from scoring.models import Customer
>>> cus = Customer(1,"橡皮擦",15012345678)
>>> cus.save()
>>> cus = Customer(2,"1_bit",15066667777)
>>> cus.save()

数据准备完毕,可以通过下述代码输出数据进行基础测试,查看视图与模型之间的关联关系是否打通。
修改 views.py 文件,填入下述内容代码。

from django.http import HttpResponse
from .models import Customer

# 打分系统首页
def index(request):
    customers = Customer.objects.all()
    ret = ",".join([c.name for c in customers])
    return HttpResponse(ret)

此时访问 http://127.0.0.1:8000/scoring/,得到如下内容。

20210408221626480[1].png

接下来配合视图在对 views.py 中的内容进行修改。

from django.http import HttpResponse
from .models import Customer
from django.template import loader

# 打分系统首页
def index(request):
    customers = Customer.objects.all()
    template = loader.get_template("ttt/index.html")

    context = {
        "customers": customers
    }
    return HttpResponse(template.render(context, request))

上述代码中,优先导入了模型类与 template 中的 loader 模块,然后修改 index 函数,通过 Customer.objects.all() 获取之前录入的客户数据。
template = loader.get_template("ttt/index.html") 用于加载模板,最后将数据通过 context 传递到 index.html 页面中。

此时修改一下 index.html 页面逻辑,内容如下:

{% if customers %}
<ul>
  {% for c in customers %}
  <li><a href="/scoring/{{ c._id }}">{{ c.name }}</a></li>
  {% endfor %}
</ul>
{% else %}
<p>无客户</p>
{% endif %}

刷新页面,出现如下 BUG,原因是 c._id 导致,因 _ 开头的变量在模板中被当做私有变量。

TemplateSyntaxError at /scoring/ Variables and attributes may not begin with
underscores: 'c._id'

解决办法涉及新的模板标签知识点。
scoring 目录中新建立一个 templatetags 文件夹,其中创建两个文件 __init__.pygetid.py,目录结构如下:

20210409121823728[1].png

__init__.py 保持为空即可,getid.py 中增加如下代码。这里相当于在 Django 模板中手动创建了一个过滤器。顺便再回顾一下 Django 模板语法。

  • 变量:两个大括号括起来的 {{变量名}}
  • 标签:代码段 {% 代码块 %}
  • 过滤器:竖线(|);
  • 注释:{# 这里是注释 #}
from django import template
register = template.Library()

@register.filter(name='getid')
def getid(d):
    return d._id

完成准备工作之后,修改 index.html 文件。

{% load getid %} {% if customers %}
<ul>
  {% for c in customers %}
  <li><a href="/scoring/{{ c|getid }}">{{ c.name }}</a></li>
  {% endfor %}
</ul>
{% else %}
<p>无客户</p>
{% endif %}

再次运行代码,得到的页面源码如下:

<ul>
  <li><a href="/scoring/1">橡皮擦</a></li>
  <li><a href="/scoring/2">1_bit</a></li>
</ul>

views.py 代码中的函数会返回一个 HttpResponse 对象到浏览器,该处理逻辑经常使用,所以 Django 提供了一个内置好的简写函数,render

from django.shortcuts import render
# 打分系统首页
def index(request):
    customers = Customer.objects.all()
    context = {
        "customers": customers
    }
    return render(request, "ttt/index.html", context)

刚才已经提及了 Django 模板系统中的常见语法,对于模板系统还有如下内容需要补充。

修改模板中的超链接生成方式,在前文中使用字符串拼接的方式 <a href="/scoring/{{ c|getid }}">{{ c.name }}</a> 生成了一个超链接,该内容可以进行优化,在 scoring/urls.py 中,我们给每个 URL 模式都进行了命名。

urlpatterns = [
    path("", views.index, name="index"),
    path("<int:id>/", views.detail, name="detail"),
    path("<int:id>/score", views.show_score, name="show_score"),
]

通过上述命名,可以修改模板中超链接的生成方式为:

{% for c in customers %}
<li><a href="{% url 'detail' c|getid%}">{{ c.name }}</a></li>
{% endfor %}

在 Django 中任何功能都是以应用形式存在的,即会出现多个应用在一个项目内的场景,此时 URL 模式可能会出现相同内容。解决办法非常简单,通过在 urls.py 文件中增加 app_name 变量设置 URLconf 的命名空间。

from django.urls import path
from . import views

app_name = "scoring"
urlpatterns = [
    path("", views.index, name="index"),
    path("<int:id>/", views.detail, name="detail"),
    path("<int:id>/score", views.show_score, name="show_score"),
]

命名名称空间之后,就可以在 index.html 文件中增加名称空间相关数据。

{% for c in customers %}
<li><a href="{% url 'scoring:detail' c|getid%}">{{ c.name }}</a></li>
{% endfor %}

13.3 本篇博客小节

本篇我们再次对打分系统中的视图与模板进行了补充与学习,一起打卡吧。

相关阅读

  1. Python 爬虫 100 例教程,超棒的爬虫教程,立即订阅吧
  2. Python 游戏世界(更新中,目标文章数 50+,现在订阅,都是老粉)
  3. Python 爬虫小课,精彩 9 讲

今天是持续写作的第 <font color="red">131</font> / 200 天。
如果你想跟博主建立亲密关系,可以关注同名公众号 <font color="red">梦想橡皮擦</font>,近距离接触一个逗趣的互联网高级网虫。
博主 ID:梦想橡皮擦,希望大家<font color="red">点赞</font>、<font color="red">评论</font>、<font color="red">收藏</font>。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容