python-Django基础知识点 (待完善)

Django
基础python开发的 开源的web应用框架
优点:
快速开发
低耦合
开发快捷
部署方便
可重用性高
维护成本低等


python 加Diango 是快速开发、设计、部署的最佳组合
特点:
强大的数据库功能
自带强大的后台功能
优雅的网址


模型:
使用的是类似mvc框架的MTV框架
MTV框架:
M :Model 模型层 编写程序应有的功能,负责业务对象与数据库的映射ORM
T: Template: 负责如何把页面展示给用户
V View 视图,负责业务逻辑,并在适当额时候调用Model 和Template
URL分发器

Django安装
官网下载:
源码安装方法
下载源码包:https://www.djangoproject.com/download/

输入以下命令并安装:

tar xzvf Django-X.Y.tar.gz # 解压下载包
cd Django-X.Y # 进入 Django 目录
python setup.py install # 执行安装命令

 

pip安装:(推荐)
pip install Django==4.1.7

安装成功后 Django 位于 Python 安装目录的 site-packages 目录下。


django 的使用
__init__.py: 初始化文件
settings.py: 配置文件
urls.py: url 路径配置文件
views.py: 视图文件
wsgi.py

-----------------
django 的输出
views 产生输出数据,render(self,目标模板页面,发送数据)

urls 文件里 通过Path 方法 完成 访问路由 和 views.函数 的绑定

template 文件下的模板页面 index.html
通过 {{ 数据键名 }} 绑定输出数据
-----------------

 

模板:

输出变量:
<p>{{ name }}</p>
<p>{{ views_list }}</p> # 取出整个列表
<p>{{ views_list.0 }}</p> # 取出列表的第一个元素
<p>{{ views_dict }}</p>
<p>{{ views_dict.name }}</p>
模板语法:
{{ 变量名 | 过滤器:可选参数 }}
支持管道:
{{ name|lower }}
支持管道套接:
{{ my_list|first|upper }}
有些过滤器有参数。 过滤器的参数跟随冒号之后并且总是以双引号包含。 例如:

{{ bio|truncatewords:"30" }}
这个将显示变量 bio 的前30个词。

管道 过滤器:
{{ 变量名 | 过滤器:可选参数 }}
default

其他过滤器:

addslashes : 添加反斜杠到任何反斜杠、单引号或者双引号前面。

date : 按指定的格式字符串参数格式化 date 或者 datetime 对象,实例:
{{ pub_date|date:"F j, Y" }}
length : 返回变量的长度。

default

default 为变量提供一个默认值。
如果 views 传的变量的布尔值是 false,则使用指定的默认值。
以下值为 false:
0 0.0 False 0j "" [] () set() {} None

filesizeformat
以更易读的方式显示文件的大小
集合返回的是键值对的数量,集合返回的是去重后的长度
{{ num|filesizeformat}}

date
根据给定格式对一个日期变量进行格式化
格式 Y-m-d H:i:s返回 年-月-日 小时:分钟:秒 的格式时间。
{{ time|date:"Y-m-d" }}
truncatechars
如果字符串包含的字符总个数多于指定的字符数量,那么会被截断后面的部分
截断的字符串将以...结尾
safe
将字符串标记为安全,不需要转义
!要保证views.py 传过来的数据绝对安全,才能用safe
和后端views.py 的 make_safe 效果相同。
会使html标签生效

if/else 标签
基本语法格式如下:
{% if condition %}
... display
{% endif %}
或者:
{% if condition1 %}
... display 1
{% elif condition2 %}
... display 2
{% else %}
... display 3
{% endif %}
根据条件判断是否输出。if/else 支持嵌套。

for 标签
{% for x in y %} :允许我们在一个序列上迭代。
{% endif %} 每一次循环都会渲染在 for 和endfor 之间的所有内容
<ul>
{% for athlete in athlete_list %}
<li>{{ athlete.name }}</li>
{% endfor %}
</ul>

给标签增加一个 reversed 使得该列表被反向迭代:
{% for athlete in athlete_list reversed %}
...
{% endfor %}

遍历字典: 可以直接用字典 .items 方法,用变量的解包分别获取键和值。

{%for%} 标签里可以通过{{forloop}}变量获取循环序号
forloop.counter:顺序获取循环序号,从1开始计算
forloop.counter0:顺序获取循环序号,从0开始计算
forloop.revcounter:倒序获取循环序号,结尾序号为0
forloop.revcounter0:倒序获取循环序号,结尾序号为0
forloop.first(一般配合if标签使用):第一条数据返回True,其他数据返回False
forloop.last(一般配合if标签使用):最后第一条数据返回True,其他数据返回False
{% for i in listvar %}
{{ forloop.counter }}
{{ forloop.counter0 }}
{{ forloop.revcounter }}
{{ forloop.revcounter0 }}
{{ forloop.first }}
{{ forloop.last }}
{% endfor %}

{% empty %}
可选的 {% empty %} 从句:在循环为空的时候执行(即 in 后面的参数布尔值为 False )。
{% for i in listvar %}
{{ forloop.counter0 }}
{% empty %}
空空如也~
{% endfor %}

可以嵌套使用 {% for %} 标签:
{% for athlete in athlete_list %}
<h1>{{ athlete.name }}</h1>
<ul>
{% for sport in athlete.sports_played %}
<li>{{ sport }}</li>
{% endfor %}
</ul>
{% endfor %}

ifequal/ifnotequal 标签
{% ifequal %} 比较两个值,当他们相等时,显示在{% ifequal %}和{%endifequal%} 之后所有的值
{% ifequal section 'sitenews' %}
<h1>Site News</h1>
{% else %}
<h1>No News Here</h1>
{% endifequal %}

注释标签
{# 这是一个注释 #}

include 标签
{% include %} 标签允许在模板中包含其他的模板内容。
{% include "nav.html" %}

csrf_token
c{% csrf_token %} 用于form表单中,用于跨站请求伪造保护
如果不用 {% csrf_token %} 标签,在用 form 表单时,要再次跳转页面会报 403 权限错误。

用了{% csrf_token %} 标签,在 form 表单提交数据时,才会成功。
解析:
首先,向服务器发送请求,获取登录页面,此时中间件 csrf 会自动生成一个隐藏input标签,该标签里的 value 属性的值是一个随机的字符串,用户获取到登录页面的同时也获取到了这个隐藏的input标签。

然后,等用户需要用到form表单提交数据的时候,会携带这个 input 标签一起提交给中间件 csrf,原因是 form 表单提交数据时,会包括所有的 input 标签,中间件 csrf 接收到数据时,会判断,这个随机字符串是不是第一次它发给用户的那个,如果是,则数据提交成功,如果不是,则返回403权限错误。

自定义标签和过滤器
1、在应用目录下创建 templatetags 目录(与 templates 目录同级,目录名只能是 templatetags)。
2、在 templatetags 目录下创建任意 py 文件,如:my_tags.py。
3、my_tags.py 文件代码如下:
from django import template

register = template.Library() #register的名字是固定的,不可改变
修改 settings.py 文件的 TEMPLATES 选项配置,添加 libraries 配置:
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [BASE_DIR, "/templates",],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
"libraries":{ # 添加这边三行配置
'my_tags':'templatetags.my_tags' # 添加这边三行配置
} # 添加这边三行配置
},
},
]
4、利用装饰器 @register.filter 自定义过滤器。
注意:装饰器的参数最多只能有 2 个。
@register.filter
def my_filter(v1, v2):
return v1 * v2
5、利用装饰器 @register.simple_tag 自定义标签。
@register.simple_tag
def my_tag1(v1,v2,v3):
return v1 * v2 * v3
6、在使用自定义标签和过滤器前,要在 html 文件 body 的最上方中导入该 py 文件。
{% load my_tags %}
7、在 HTML 中使用自定义过滤器。
{{ 11|my_filter:22 }}
8、在 HTML 中使用自定义标签。
{% my_tag1 11 22 33 %}
9、语义化标签
在该 py 文件中导入 mark_safe。
from django.utils.safestring import mark_safe

配置静态文件
1 在项目根目录下创建statics目录

2 在 settings 文件的最下方配置添加以下配置

STATIC_URL = '/static/' # 别名
STATICFILES_DIRS = [
os.path.join(BASE_DIR, "statics"),
]
3 statics下创建子文件夹
css目录 :css文件
js 目录: js 文件
images 目录: 图片
plugins 目录:插件


模板继承
父模板
{% block 名称 %}
预留给子模板的区域,可以设置设置默认内容
{% endblock 名称 %}

子模版
使用extend 继承父模板
{% extend "父模板路径"%}

Django 模型层
创建app
django-admin startapp TestModel

命令行运行
$ python manage.py migrate #创建表结构
$ python manage.py makemigrations TestModel # 让Django 知道我们在我们的模型有一些变更
$ python manage.py migrate TestModel #创建表结构

表名组成结构为:应用名_类名(如:TestModel_test)
注意:尽管我们没有在 models 给表设置主键,但是 Django 会自动添加一个 id 作为主键。

 

posted on 2023-03-23 15:45  Mlianga  阅读(36)  评论(0编辑  收藏  举报

导航