Django--初始化

1、Django介绍

它是一个WEB框架

  • Django--大而全

  • tornado、flask--小而精


2、Django安装

    https://www.djangoproject.com/download/


3、创建django程序

  • 手动创建

file--new project--Django--Location--create(打开后最好不要有上层目录)

  • 命令创建

cmd>django-admin startproject sitename


4、程序目录

827870-20160310104937538-237410312.jpg

各文件作用:
  • 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的原理

  1. 打开html文件--open()

  2. 渲染模板和内容--Template()

  3. 返回字符串--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

  1. 在app中创建templatetags模块

    827870-20160310104938022-1850814620.png

  2. 创建任意 .py 文件,如:xx.py

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    from 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)
  3. 在使用自定义simple_tag的html文件开头导入之前创建的 xx.py 文件名

    1
    {% load xx %}
  4. html中使用simple_tag

    1
    2
    3
    4
    <body>
         {% my_simple_time 1 2 3 %}
         {% my_input 'id_username' 'hide' %}
    </body>
  5. 在settings中配置当前app,不然django无法找到自定义的simple_tag 

    1
    2
    3
    4
    5
    6
    7
    8
    9
    INSTALLED_APPS = [
         'django.contrib.admin' ,
         'django.contrib.auth' ,
         'django.contrib.contenttypes' ,
         'django.contrib.sessions' ,
         'django.contrib.messages' ,
         'django.contrib.staticfiles' ,
         'app01' ,
    ]
效果:827870-20160310104938429-1614365906.png
  • 第一个函数是算加法,1、2、3是参数;

  • 第二个函数是写一个标签,'id_username' 'hide'是参数。


13、母版,子版,include

templates里创建一个目录:master,目录里创建文件mother.html和son.html

827870-20160310104938882-77462070.png

母版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功能

827870-20160310104939491-1391550098.png

input_group.html
1
2
3
4
5
<h1>Include输入组合</h1>
<input type= "text" />
<input type= "text" />
<input type= "text" />
<input type= "text" />
效果:
827870-20160310104939897-357809774.png

827870-20160310104940241-599572230.png

注意点:
  • 母版只能继承一个。

  • 当某一小块功能用在很多页面中,用include。

  • son加css样式,{% block css %}{% endblock %}

  • son加js,{% block js %}{% endblock %}


14、Django中的静态文件

创建目录

827870-20160310104940850-1482029496.png

配置文件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" >
















转载于:https://www.cnblogs.com/daliangtou/p/5260970.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值