1、Django介绍
它是一个WEB框架
Django--大而全
tornado、flask--小而精
2、Django安装
https://www.
3、创建django程序
手动创建
file--new project--Django--Location--create(打开后最好不要有上层目录)
命令创建
cmd>django-admin startproject sitename
4、程序目录
各文件作用:
settings.py--配置文件
urls.py--路由
wsgi.py--用那种wsgi方式(wsgi或者uwsgi)
templates--html模板
manage.py--主程序,启动程序
注意:不要轻易更改项目的名称,涉及的地方太多。
还有其他目录:
app--项目里的一个扩展,可以有多个,如前台和后台
5、 创建app目录
cmd> python manage.py startapp app01
app目录--项目里的一个扩展,可以有多个,如前台和后台
--models.py,对数据库进行操作
--views.py,视图,函数
--tests.py,测试用
--admin.py,后台管理程序 http://127.0.0.1:8000/admin/
6、生成超级用户
没有数据库要先创建表,不然生成用户会报错:no such table:auth_user
cmd> python manage.py syncdb
cmd> yes
此时创建的用户就能进入后台管理,另外生成了一个db.sqlite3数据库文件,用sqlite工具能看到具体信息,如navicat等。
如果要生成到mysql数据库,需要在settings.py里配置。
创建超级用户:
cmd> python manage.py createsuperuser
在后台的用户表里就能看到用户user和group了
7、启动服务
cmd> python manage.py runserver 127.0.0.1:8000
8、第一个Django程序
路由--urls.py
1
2
3
4
5
|
from app01
import
views
urlpatterns = [
url(r
'^admin/'
, admin.site.urls),
url(r
'^home/'
, views.home),
]
|
请求处理--views.py
1
2
3
|
from django.shortcuts
import
HttpResponse
def home(request): //必要参数request,包含请求的全部信息。
return
HttpResponse(
"ok"
) //Django返回的字符串需要用HttpResponse()包装,不能直接返回字符串。
|
9、模板渲染
路由--urls.py
同上
请求处理--views.py
1
2
3
4
|
from django.shortcuts
import
render
dic={
'arg'
:
'home1'
,}
def home(request):
return
render(request,
'home.html'
,dic) #读取home.html,并返回给请求者,dic是参数,传到页面中
|
模板--templates/home.html
1
2
3
4
|
from django.shortcuts
import
render
dic={
'arg'
:
'home1'
,
'user_list'
:[
'user1'
,
'user2'
]}
def home(request):
return
render(request,
'home.html'
,dic) #读取home.html,并返回给请求者,dic是参数,传到页面中
|
10、render的原理
打开html文件--open()
渲染模板和内容--Template()
返回字符串--HttpResponse()
1
2
3
4
5
6
7
8
9
10
|
import
datetime
from django
import
template
import
DjangoDemo.settings
now = datetime.datetime.now()
fp = open(settings.BASE_DIR+
'/templates/Home/Index.html'
)
t = template.Template(fp.read())
fp.close()
html = t.render(template.Context({
'current_date'
: now}))
return
HttpResponse(html)
|
11、模板语言
模板中也有自己的语言,该语言可以实现数据展示
{{ item }}
{% for item in item_list %} <a>{{ item }}</a> {% endfor %}
forloop.counter
forloop.first
forloop.last{% if ordered_warranty %} {% else %} {% endif %}
母板:{% block title %}{% endblock %}
子板:{% extends "base.html" %}
{% block title %}{% endblock %}帮助方法:
{{ item.event_start|date:"Y-m-d H:i:s"}}
{{ bio|truncatewords:"30" }}
{{ my_list|first|upper }}
{{ name|lower }}
方法有限,如果想使用跟多模板方法,需要自定义,看下面一节。
12、自定义方法--simple_tag
在app中创建templatetags模块
创建任意 .py 文件,如:xx.py
1234567891011121314from django
import
template
from django.utils.safestring
import
mark_safe
from django.template.base
import
resolve_
var
iable, Node, TemplateSyntaxError
register = template.Library()
@register.simple_tag
def my_simple_time(v1,v2,v3):
return
v1 + v2 + v3
@register.simple_tag
def my_input(id,arg):
result =
"<input type='text' id='%s' class='%s' />"
%(id,arg,)
return
mark_safe(result)
在使用自定义simple_tag的html文件开头导入之前创建的 xx.py 文件名
1{% load xx %}
html中使用simple_tag
1234<body>
{% my_simple_time
1
2
3
%}
{% my_input
'id_username'
'hide'
%}
</body>
在settings中配置当前app,不然django无法找到自定义的simple_tag
123456789INSTALLED_APPS = [
'django.contrib.admin'
,
'django.contrib.auth'
,
'django.contrib.contenttypes'
,
'django.contrib.sessions'
,
'django.contrib.messages'
,
'django.contrib.staticfiles'
,
'app01'
,
]
效果:
第一个函数是算加法,1、2、3是参数;
第二个函数是写一个标签,
'id_username'
'hide'
是参数。
13、母版,子版,include
templates里创建一个目录:master,目录里创建文件mother.html和son.html
母版mother.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
<head>
<meta charset=
"UTF-8"
>
<title>{% block title %}{% endblock %}</title>
<style>
.header{
height: 48px;
background-color: red;
}
.body{
background-color: antiquewhite;
}
.body .menu{
background-color: aqua;
width:
20
%;
float: left;
}
.body .content{
background-color: aquamarine;
width:
80
%;
float: left;
}
</style>
</head>
<body>
<div
class
=
"header"
>LOGO</div>
<div
class
=
"body"
>
<div
class
=
"menu"
>左侧菜单</div>
<div
class
=
"content"
>{% block content %}{% endblock %}</div>
</div>
</body>
</html>
|
子版son.html
1
2
3
4
5
6
7
8
9
10
|
{%
extends
"master/mother.html"
%}
{% block title %}
母版子版
{% endblock %}
{% block content %}
<h1>Son的右侧内容</h1>
{%
include
"include/input_group.html"
%}
{% endblock %}
|
路由urls.py
1
2
3
4
5
|
from app01
import
views
urlpatterns = [
url(r
'^admin/'
, admin.site.urls),
url(r
'^son/'
, views.son),
]
|
视图views.py
1
2
3
|
from django.shortcuts
import
render
def son(request):
return
render(request,
'master/son.html'
)
|
给son添加include内容,include功能
input_group.html
1
2
3
4
5
|
<h1>Include输入组合</h1>
<input type=
"text"
/>
<input type=
"text"
/>
<input type=
"text"
/>
<input type=
"text"
/>
|
效果:
注意点:
母版只能继承一个。
当某一小块功能用在很多页面中,用include。
son加css样式,{% block css %}{% endblock %}
son加js,{% block js %}{% endblock %}
14、Django中的静态文件
创建目录
配置文件settings.py
1
2
3
4
|
STATIC_URL =
'/static/'
STATICFILES_DIRS = (
os.path.join(BASE_DIR,
'static'
),
)
|
调用
1
|
<link ref=
"stylesheet"
href=
"/static/css/common.css"
>
|