最近全国各地全是高温状态,中午睡个觉都是被热醒的,整天晕乎乎的,之前被Django弄得一脸懵逼,各个py文件之间紧密联系。现在,趁着清醒,来说说。
上次已经讲过怎样创建项目和应用。现在,借着之前已经创建好的应用内容跟大家介绍下。应用名:myblog
(一)创建第一个简单页面(响应)
-
这会儿我们不需要操作什么,只需编辑blog.views,改改(总目录)myblog/urls.py
- 小知识:
a、每个响应对应一个函数(),对应一个URL,并且函数必须返回一个响应
b、函数必须存在一个参数,一般约定为request
效果:
- 配置URL
编辑urls.py
- 小知识:
a、每个URL都以url的形式写出来
b、url函数放在urlpatterns列表中
c、url函数有三个参数:URL(正则),对应的方法,名称
代码:
from django.conf.urls import url
from django.contrib import admin
import blog.views as bv
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^index/', bv.index)
]
- 第二种URL配置(包含其他url)
修改根目录;在应用目录新建一个urls.py (可以直接复制根的urls.py到应用下,把多余的内容删掉)并且修改内容
- 小知识:
a、在根urls.py中引入include
b、在APP(应用)目录下创建urls.py 文件,格式与根的urls.py相同,删掉多余的
c、在根urls.py中url函数的第二个参数改为include('blog.urls')
代码:
a、根 urls.py
from django.conf.urls import url, include
from django.contrib import admin
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^blog/', include('blog.urls')),
]
b、应用 urls.py
from django.conf.urls import url
from .import views
urlpatterns = [
url(r'^index/', views.index),
]
效果:
注意事项:
根urls.py 针对APP配置的URL名称是该APP所有的url的总路径,配置url时注意正则表达式结尾符号$和/
小结:两种URL配置方法都可以达到相同的效果,但是建议采用第二种,易于维护、管理,同时避免总项目的urlpatterns庞大
(二)Templates介绍
- 什么是templates?
一个一个使用了Django模板语言(Django Template Language,DTL)的HTML文件。当然,也可以使用第三方模板(jinja2) - 开发第一个Template
步骤:
a、在APP(应用)的根目录下创建名叫template的目录(directory)
b、在该目录下,可以添加我们想要的HTML文件
c、在views.py中返回render()。render函数,将HTML界面响应给浏览器,render()函数传递一般三个参数(请求对象,HTML文件,后台往前端输送的数据)
views.py
from django.shortcuts import render
def index(request):
return render(request, 'index.html')
-
render()函数传递的第三个参数
render()函数中支持一个dict字典(键值对)类型的参数;
该字典是后台传递到模板的参数,键为参数名,在模板中使用{{参数名}}来直接使用
譬如:
- 小知识:
a、当一个项目中添加有多个应用时,Django按照INSTALLED_APPS中的添加顺序查找Templates,不同的应用下Templates的html文件名字相同造成冲突
b、解决办法:在APP的Templates目录下创建以APP名为名称的目录,将html文件放入新创建的目录下
(三)Models介绍
1.Models是什么?
通常,一个Model对应数据库的一张数据表。Django中Models以类的形式表现,它包含了一些基本字段以及数据的一些行为。采用ORM(对象关系映射)实现了对象与数据库之间的映射,隐藏了数据访问的细节,不需要编写任何SQL语句,对类的操作相当于是对数据库的操作。
2.编写Models步骤
a、创建类,继承models.Model,该类即是一张数据表
b、在类中创建字段(类里面的属性)
models.py
from django.db import models
class Article(models.Model):
title = models.CharField(max_length=32)
content = models.TextField(null=True)
3.生成数据表
现在类已经写好了,就要把类与数据库对应起来。注意,每次修改了models.py文件里面的内容,一定操作一下步骤,才会修改有效不会报错
a、命令行中manage.py 同级目录,执行python manage.py makemigrations blog
(对应app的名称)
若不写app的名称,则默认该项目下所有应用都生成数据迁移
b、再执行python manage.py migrate
c、数据表(迁移文件)的查看
Django会自动在app/migrations/目录下生成移植文件;执行python manage.py sqlmigrate 应用名 文件的id
查看SQL语句
(四)Admin简介
什么是Admin?
Admin是Django自带的一个功能强大的自动化数据管理界面,被授权的用户可直接在Admin中管理数据库,Django提供了许多针对Admin的定制功能。
1.配置Admin
创建超级用户:
pyhton manage.py createsuperuser
进行用户名、邮箱地址、密码的设置
登录网址:http://127.0.0.1:8000/admin/ 查看admin管理网站
改变页面成为中文界面:修改settings.py中的LANGUAGE_CODE = 'en-us'
为LANGUAGE_CODE = 'zh_Hans'
- 配置应用
在应用下admin.py 文件中引入自身的models模块(或里面的模型类)
编辑admin.py: admin.site.register(Article)
admin.py:
from django.contrib import admin
from blog.models import Article
admin.site.register(Article)
配置应用后的界面:
配置应用前:
Tips:下次介绍完善页面基本内容操作