【Django】高级用法

本文为 Django 学习总结,讲解 Django 的高级用法

运行环境

  • Windows 10
  • Pycharm Community Edition 2020.1.3
  • Django 3.0.8

所有的代码见【Django】系列

静态文件

包括 css、js、图片、Json 文件、字体文件等。静态文件一般放在 project 目录下的 static 文件夹下,与 templates 同级。在 static 文件夹下还要创建每个应用对应的文件夹,在对应文件夹下还要创建存放不同类型文件的文件夹。看起来可能有点绕,可以参考下图:

在这里插入图片描述

现在我们想将模板中的字体设置为红色的,可以直接在 style.css 中配置:

h1{
   
	color:red;
}

然后在 settings.py 中配置静态文件夹路径,在 settings.py 的最后一行加入:

# 设置用来访问这个文件夹的URL地址
STATIC_URL = '/static/'
# 把项目中的static文件夹设置为静态文件夹
STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static') # static对应前面创建的目录
]

使用下面的代码在 html 中引入 css 样式:

<head>
    <meta charset="UTF-8">
    <title>首页</title>
    <link rel="stylesheet" type="text/css" href="/static/myApp/css/style.css"/>
</head>
<body>
    <h1>Mike is a good man</h1>
</body>

得到结果:

在这里插入图片描述

想要使用 jquery-3.1.1.min.js 和 sunck.js 文件。其中 jquery-3.5.1.min.js 在 jquery 官网直接下载,并放到 js 目录下。sunck.js 中添加:

// sunck.js
console.log("good man")

需要在 link 后添加下面的代码。:

<script type="text/javascript"
        src="/static/myApp/js/jquery-3.5.1.min.js"></script>
<script type="text/javascript"
        src="/static/myApp/js/sunck.js"></script>

刷新后查看 Consule,得到值:

aGKxH0.png

再显示一张图片,在 h1 后添加下面的代码:

<img src="/static/myApp/img/IMG_0468.PNG"/>

在这里插入图片描述

但是,如果文件名发生了变化,html 文件中的所有路径都需要变化,工作量很大,我们可以采取类似反向解析的方法,给路径起“别名”。

首先在 html 文件第一行引入静态文件:

{% load static from staticfiles %}

图片就可以用下面的方式添加:

{
   % load static %} # django3中使用。django2中使用load static from staticfiles

得到结果:

在这里插入图片描述

将这些硬链接改为“别名”,如果我们修改了静态文件的名称,也无需修改 html 中的路径。

中间件

一个轻量级、底层的插件,可以介入 Django 的请求和相应,本质为一个 Python 类。settings.py 中的 MIDDLEWARE 即为系统提供的中间件

方法

__init__

不需要传参数,服务器响应第一个请求时自动调用,用于确认是否启用该中间件。

process_request(self, request)

在执行视图(分配 url 匹配视图)之前被调用,每个请求都会调用,返回 None 或 HttpResponse 对象

process_view(self, request, view_func, view_args, view_kwargs)

调用视图之前执行,每个请求都会调用,返回 None 或 HttpResponse 对象

process_template_response(self, request, response)

在视图刚好执行完后调用,每个请求都会调用&

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值