(四)Django2——视图与模板

25 篇文章 0 订阅
13 篇文章 0 订阅

上一篇中了解了如何建立模型,添加应用等,

那这一篇,将会引入自定义视图(html)

在 Django 中,网页和其他内容都是从视图派生而来。每一个视图表现为一个简单的 Python 函数(或者说方法,如果是在基于类的视图里的话)。Django 将会根据用户请求的 URL 来选择使用哪个视图(更准确的说,是根据 URL 中域名之后的部分)。

在你上网的过程中,很可能看见过像这样美丽的 URL: "ME2/Sites/dirmod.asp?sid=&type=gen&mod=Core+Pages&gid=A6CD4967199A42D9B65B1B" 。别担心,Django 里的 URL 规则 要比这优雅的多!

一个 URL 模式定义了某种 URL 的基本格式——举个例子:/newsarchive/<year>/<month>/。

为了将 URL 和视图关联起来,Django 使用了 'URLconfs' 来配置。URLconf 将 URL 模式映射到视图。

本本章只会介绍 URLconf 的基础内容,你可以看看 URL调度器 以获取更多内容。

创建视图

blog/views.py代码如下

from django.shortcuts import render,get_object_or_404
from django.http import Http404
from .models import *

# index
def index(request):
    articles_list = Articles.objects.all()
    sort_list = Sorts.objects.all()
    context = {
        'articles_list': articles_list,
        'sort_list' : sort_list,
    }
    return render(request, 'index.html', context)

# article info 
def info(request,article_id):
    article = get_object_or_404(Articles,id = article_id)
    return render(request, 'info.html', {'article':article})

获取文章列表、及接收参数根据文章id查询文章详情

把这些新视图添加进 blog/.url.py模块里,只要添加几个 url() 函数调用就行:

from django.urls import path

from . import views

urlpatterns =[
    path('index/',views.index),
    path('article/info/<int:article_id>/', views.info , name ='articleInfo')
]

然后看看你的浏览器,如果你转到 "article/info/1" ,Django 将会运行 info() 方法并且展示你在 URL 里提供的article_id。

当某人请求你网站的某一页面时——比如说, "article/info/1" ,Django 将会载入 mysite.urls 模块,因为这在配置项 ROOT_URLCONF 中设置了。然后 Django 寻找名为 urlpatterns 变量并且按序匹配正则表达式。在找到匹配项 'article/info',它切掉了匹配的文本("article/info/"),将剩余文本——"1/",发送至 'blog.urls' URLconf 做进一步处理。在这里剩余文本匹配了 '<int:article_id>/',使得我们 Django 以如下形式调用 info()

每个视图必须要做的只有两件事:返回一个包含被请求页面内容的 HttpResponse 对象,或者抛出一个异常,比如 Http404 。至于你还想干些什么,随便你。

你的视图可以从数据库里读取记录,可以使用一个模板引擎(比如 Django 自带的,或者其他第三方的),可以生成一个 PDF 文件,可以输出一个 XML,创建一个 ZIP 文件,你可以做任何你想做的事,使用任何你想用的 Python 库。

Django 只要求返回的是一个 HttpResponse ,或者抛出一个异常。

Rander()

「载入模板,填充上下文,再返回由它生成的 HttpResponse对象」是一个非常常用的操作流程。于是 Django 提供了一个快捷函数。

抛出 404 错误get_object_or_404()

尝试用 get()函数获取一个对象,如果不存在就抛出Http404错误也是一个普遍的流程。Django 也提供了一个快捷函数,下面是修改后的详情 detail() 视图代码:

代码如上blog/views.py展示的代码

为什么我们使用辅助函数 get_object_or_404() 而不是自己捕获 ObjectDoesNotExist 异常呢?还有,为什么模型 API 不直接抛出 ObjectDoesNotExist 而是抛出 Http404 呢?

因为这样做会增加模型层和视图层的耦合性。指导 Django 设计的最重要的思想之一就是要保证松散耦合。一些受控的耦合将会被包含在 django.shortcuts 模块中。

使用模板

截下来来创建我们的静态页面

在blog/目录创建static,templates文件夹,现在我们的目录是这样

在setting文件中修改

STATIC_URL = '/static/'
STATICFILES_DIRS = (
    os.path.join(BASE_DIR, 'static/'),
)

现在再来编辑我们的html页面,首先是index.html

在html页面顶部引入

{% load staticfiles %}

所有引入静态页面参考如下方式

<link href="{% static 'css/base.css'  %}" rel="stylesheet">

然后通过标签,展示我们的文章列表

    {% if articles_list %}
      {% for article in articles_list %}
      <li>
        <h3><a href="/article/info/{{ article_id }}/">{{article.art_title}}</h3>
        <p>{{article.art_content}}</p>
        <span>{{article.art_date}}</span><span>阅读数:{{article.art_views}}</span><span>评论数:{{article.art_comment_count}}</span>
      </li>
      {% endfor %}
    {% endif %}

模板系统统一使用点符号来访问变量的属性。在示例 {{ article.art_views }} 中,首先 Django 尝试对 article 对象使用字典查找(也就是使用 obj.get(str) 操作),如果失败了就尝试属性查找(也就是 obj.str 操作),结果是成功了。如果这一操作也失败的话,将会尝试列表查找(也就是 obj[int] 操作)。

在{% for %}进行循环遍历

去除模板中的硬编码 URL

上述中我们的a标签写到

<a href="/article/info/{{ article_id }}/"

问题在于,硬编码和强耦合的链接,对于一个包含很多应用的项目来说,修改起来是十分困难的。然而,因为你在 blog.urls 的url() 函数中通过 name 参数为 URL 定义了名字,你可以使用 {% url %} 标签代替它:

<a href="{% url 'articleInfo' article.id %}">

这个标签的工作方式是在blog.urls 模块的 URL 定义中寻具有指定名字的条目。你可以回忆一下,具有名字 'info' 的 URL 是在如下语句中定义的:

   path('article/info/<int:article_id>/', views.info , name ='articleInfo')

所以以后更改只需要更改 name就可以了

ok现在打开我们的页面看看效果吧

项目地址(码云):传送门

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值