django基础之urls及view

Django

环境

环境为 python 3.X + Django 1.11,若安装的 Django 版本不一致,可先卸载然后指定版本安装。

1
2
3
4
# 卸载
pip uninstall Django
# 指定版本安装
pip install Django==1.11

简介

Django 使用 MVC/MTV 模式,其本质是为了保持各组件之间松耦合关系。

  • Model(模型):负责业务对象与数据库的对象(ORM)
  • Template(模版):负责如何把页面展示给用户
  • View(视图):负责业务逻辑,并在适当的时候调用 Model 和 Template

此外,Django 还有一个 url 分发器,它的作用是将一个个的 URL 页面请求分发给不同的 view 请求, view 再调用相应的 Model 和 Template 。

Django流程

Django 包括 MTV 和 url 分发器,那么具体的处理流程如何呢?
django-process

用户访问,首先通过urls进行访问路径的匹配,然后转到匹配到的方法或函数,转到 views 进行逻辑处理。
若需要访问数据库,则通过 models 访问数据库,获取需要的数据,返回给 views
views 处理完成后,若是API调用方式,直接返回数据给用户;否则通过 template 对指定的模板进行渲染,然后将对应的 html 返回给页面。

urls及view基础

创建

使用 pycharm 创建对应的 django 项目,具体步骤如下
文件 –> New Project ,然后选择 Diango
django-create
Location 选择对应位置,Djangotest 是对应的 project 名称。
Application name 填写具体的应用名称,不填写则不创建。
创建完成后对应的目录结构如下
django-content

第一个实例

在 urls 中添加一个 login 登录
/demo/Djangotest/urls.py

1
2
3
4
5
6
7
8
from django.conf.urls import url
from django.contrib import admin
from demo import views # 此处需要import

urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^login/$', views.login), # 此处第一个参数是正则匹配,第二个参数是对应的方法或者函数
]

此处 views.login 无此方法,需要在 views 中添加
/demo/views.py

1
2
3
4
5
6
7
8
9
10
from django.shortcuts import render,HttpResponse,redirect

def login(request):
if request.method == 'GET':
data = 'helo demo'
msg = 'aming pythono'

return render(request, 'login.html', {'data':data,'msg':msg})
# return render(request, 'login.html', locals())
# return HttpResponse('hello demo')

  1. views 中的方法要求必须返回数据。
  2. 返回数据常用的是render/HttpResponse/redirect 3个方法。
  3. locals()方法等价于上面的通过字典传参数,更常用locals()。
    上面代码跳转至 login.html 页面,在 /demo/templates 添加 login.html 页面

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="UTF-8">
    <title>demo01</title>
    </head>
    <body>

    <h3>{{ data }}</h3>

    <h4>{{ msg }}</h4>

    </body>
    </html>
  4. 2个大括号是django使用的参数绑定的方法。

  5. 此处的 data 和前面 views 中 return 返回的字典中的 key 是一致的。

然后运行该项目,默认访问 http://127.0.0.1:8000/login/ 即可得到对应页面。
django-result

总结

处理流程

在不涉及 models (数据库交互)的情况下,一般的处理流程

  1. 在 urls 中匹配并跳转至对应的方法
  2. 在 views 中根据方法或函数的逻辑进行数据处理
  3. 根据 views 结果,跳转至 templates 中进行渲染

创建流程

创建流程和新建流程其实是一致的

  1. 根据应用实际情况,在 urls 添加路径匹配,并指定 views 对应的函数或方法
  2. 在 views 中创建对应的方法或函数,进行响应的逻辑处理,最后返回数据
  3. 在 templates 中创建 html 页面,并根据 views 中返回的数据进行数据绑定

更复杂的包含 models 的涉及数据库交互的内容后面学习。

Recommended Posts