MVC 架构
django-admin.py startproject blog,创建一个项目
python manage.py startapp xxx,创建一个应用
python manage.py makemigrations,生成策略文件
python manage.py migrate,执行策略文件中的策略
python manage.py runserver,运行服务器
python manage.py createsuperuser,创建管理员账号
设置
- BASE_DIR
当前文件setting.py的绝对路径的上层目录的上层目录,也就是项目的根目录
import os
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
- DEBUG
当设置DEBUG = True,浏览页面出错时,会暴露内部的代码,所以如果在生产环境中,需要关闭
- INSTALLED_APPS
安装的应用,有一些是 django 自带的,当我们使用python manage.py startapp创建自定义应用后,需要在这里添加,并生成策略文件,执行策略。
- MIDDLEWARE_CLASSES
WSGI中的中间件,便于扩展、修改、替换。可以在接收请求、发送响应的过程中进行额外的处理。
- ROOT_URLCONF
根URL配置,当 django 收到请求时,由根URL配置对用户访问的URL进行正则表达式的模式匹配,从而将request传递给指定应用的指定页面,或将URL剩下的部分交给应用的URL配置文件进一步匹配处理。
- TEMPLATES
页面模板相关配置,包括模板所在目录(用os.path.join,连接BASE_DIR和"template"),默认的上下文处理器,后端
APP_DIRS设置为True, Django 自动在每个应用包中寻找一个templates/子目录,用作后备
- DATABASES
用于与数据库对接,引擎、数据库名称、用户名、密码等
- LANGUAGE_CODE
语言
- TIME_ZONE
时区
- STATIC_URL
静态文件,例如:CSS、图像、javascript 等文件所在的目录
与数据库对接
apps
python manage.py startapp xxx,创建应用
需要在setting.py中INSTALLED_APPS添加
python manage.py makemigrations,生成策略文件
python manage.py migrate,执行策略文件中的策略
模型
MVC 中的 M,与数据库直接交互
打开应用中的models.py
from django.db import models
用继承models.Model的类表示每一个模型
定义储存于数据库的字段、字段的数据类型、可选项
管理后台
应用中的admin.py文件
导入当前应用中models.py定义的模块,对应用中的数据进行管理
from .models import SignUp # 导入模型
admin.site.register(SignUp) # 注册模型
class SignUpAdmin(admin.ModelAdmin):,通过继承 admin.ModelAdmin 的类定义字段显示形式
admin.site.register(SignUp, SignUpAdmin),第一个参数为模型名称,第二个参数为模型的形式
-
fields简单定义对象内字段顺序 -
fieldsets变量,分标题、标题内顺序、标题内容展现形式 -
inlines,模型内联显示。-
admin.StackedInline,内联的堆叠显示 -
admin.TabularInline,内联的表格显示,可以显示更多条目,更多字段
-
-
list_display,自定义显示的字段,模型中定义的变量或方法 -
list_filter过滤器 -
search_fields搜索框
访问http://127.0.0.1:8000/admin/,用创建的管理员账号登陆管理后台
视图
MVC 中的 V
打开应用中的views.py
-
导入模型
-
函数
每个视图是一个函数,接受一个request作为参数
使用request中的POST放入模型,创建一个实例
根据request中的内容,进行查询、修改、保存、删除等操作
.objects.filter,查询数据
.save(commit=False),创建,但不保存新的实例
.save()更新有修改的字段
get_object_or_404()函数,将 django 模块作为第一个参数,还有任意数量的关键字参数。如果对象存在,返回对象,如果对象不存在,报出Http404错误。
get_or_create,如果存在,返回,如果不存在,创建。
- 表格
当使用请求中的数据和模型类创建一个实例后
通过is_valid()方法判断数据是否符合类中定义的字段的要求
.cleaned_data方法可以获得经过清洗后,符合要求的字段的信息
在一个forms.ModelForm子类中的clean_<fieldname>() method方法,使用表格的字段属性代替<fieldname>,检查特定属性是否正确。可以覆盖进行重写。
- 返回结果页面
return HttpResponse
return render(请求,模板,上下文字典)
return HttpResponseRedirect
模板
- 模板语言
django 模板语言的语法包括四个结构:
变量
变量通过{{和}}标记。
使用点运算符进行 字典查找,属性查找 和 列表索引查找。
My first name is {{ first_name }}. My last name is {{ last_name }}.
With a context of {'first_name': 'John', 'last_name': 'Doe'}, this template renders to:
My first name is John. My last name is Doe.
{{ my_dict.key }}
{{ my_object.attribute }}
{{ my_list.0 }}
标签
一个标签可以输出内容,作为一个内容控制结构等等。一个if语句或一个for循环,从数据库抓取内容,甚至能够访问其他模板的标签。
标签用{%和%}标记。
{% if user.is_authenticated %}Hello, {{ user.username }}.{% endif %}
{% for choice in question.choice_set.all %} <li>{{ choice.choice_text }}</li> {% endfor %}
过滤
过滤器 转换\翻译 变量的值 和 标记参数。
{{ django|title }}将django内容转为标题格式,即首字母大写
{'django': 'the web framework for perfectionists with deadlines'}
The Web Framework For Perfectionists With Deadlines
有些过滤器有一个大纲
{{ my_date|date:"Y-m-d" }}
注释
{# this won't be rendered #}
{% comment %} 、 {% endcomment %}提供多行注释
{% comment "Optional note" %}
<p>Commented out text with {{ create_date|date:"c" }}</p>
{% endcomment %}
- 模板系统
模板有继承功能
include
将一个模板完整放入另一个模板
保存一个navbar.html模板到template
在base.html的body中添加{% include 'navbar.html' %},{% include 'navbar.html' %}语句会被navbar.html的内容替换
block
允许我们用当前模板的部分内容替换另一个模板的部分内容,同时保留其余部分
也可以用于插入
如果当前模板中block为空,就默认使用替换的模板的内容
在视图指定的模板中,第一行添加{% extends "base.html" %}
在需要替换的部分,上下添加
{% block content %}
<p>a</p>
{% endblock %}
另一种方法:
保留母模板特定内容,并添加新内容
{% block content %}
{{ block.super }}
Hi
{% endblock %}
-
HTML
-
静态文件
setting.py中的
INSTALLED_APPS有django.contrib.staticfiles
STATIC_URL = '/static/'
或者,使用STATICFILES_DIRS存放多个目录,供 django 的静态文件查找器查找,必须都在根目录下
STATICFILES_DIRS = (
os.path.join(BASE_DIR, "static_in_pro", "our_static"),
"/home/polls.com/polls/static",
)
是项目根目录下的static_in_pro目录下的our_static目录
调用静态文件,在模板第一行使用一下命令
{% load staticfiles %}
<img src="{% static "my_app/myexample.jpg" %}" alt="My image"/>
会在setting.py中的STATICFILES_DIRS下查找这个指定的静态文件
收集静态文件,目录可以在项目根目录以外
STATIC_ROOT = os.path.join(os.path.dirname(BASE_DIR), "static_in_env")
python manage.py collectstatic
URL
urls.py中的urlpatterns是url()函数列表
url()函数传递四个参数,两个必须:regex、view,两个可选:kwargs、name。在这一点上,值得了解这些参数是什么。
- regex
regex这个术语是 正则表达式 常用的简写,是一个匹配字符串模式的语法,在本例中,是 URL 模式。
django 从第一个正则表达式开始,顺着列表向下,比较请求的URL与每一个正则表达式,直到找到一个匹配。
注意,这些正则表达式不会搜索 GET和POST 参数 或 域名。例如,一个对于http://www.example.com/myapp/的请求,URLconf将查找myapp/。对于http://www.example.com/myapp/?page=3的请求,URLconf也会查找myapp/。
-
view
当 django 找到一个匹配的正则表达式,django 会调用指定的 视图函数,并将 HttpRequest 对象作为第一个参数 、 任何被正则表达式捕获的值作为其他参数。如果正则表达式使用简单的捕获,值会通过位置参数传递;如果使用命名的参数,值通过关键字参数传递。我们会给一个这样的例子。 -
kwargs
任何关键字参数都可以放入字典中传递给目标视图。在这个教程中,我们不会使用这个特性。 -
name
命名你的 URL 让你能够明确地参考从其他地方来的 django 特殊模板。
urlpatterns = [
url(r'^polls/', include('polls.urls')),
url(r'^contact/$', 'newsletter.views.contact', name='contact'),
url(r'^admin/', include(admin.site.urls)),
]








网友评论