• Django下载与简介


    一、MVC与MTV模型

    1.1 MVC模型

    Web服务器开发领域里著名的MVC模式,所谓MVC就是把Web应用分为模型(M)、控制器(C)、视图(V)三层,它们之间以一种插件式的、松耦合的方式连接在一起。

    • 模型负责业务对象与数据库的映射(ORM);
    • 视图负责与用户的交互页面;
    • 控制器接收用户的输入调用模型和视图完成用户的请求;

    示意图如下:

    MVC与MTV架构模型图

    1.2 MTV模型

    Diango的MTV模式本质上和MVC是一样的,也是为了各组件间保持松耦合关系,只是定义上有些不同,Diango的MTV分别是指:

    • M代表模型(Model):负责业务对象和数据库的关系映射(ORM);
    • T代表模板(Template):负责如何把页面展示给用户(html);
    • V代表视图(View):负责业务逻辑,并在适当时候调用Model和Template;

    除了以上三层之外,还需要一个URL分发器,它的作用是将一个个URL的页面请求分发给不同的View处理,View再调用相应的Model和Template,MTV的响应模式如下所示:

    MVC与MTV工作流程图

    一般是用户通过浏览器向我们的服务器发起一个请求(request),这个请求会去访问视图函数,(如果不涉及数据调用,那么这个时候视图函数返回一个模板也就是一个网页给用户),视图函数调用模型,模型去数据库查找数据,然后逐级返回,视图函数把返回的数据填充到模板中空格中,最后返回网页给用户。

    二、django的下载和基本命令

    2.1 下载django

    $ pip3 install django
    

    2.2 创建一个django project

    $ django-admin.py startproject mysite
    

    当前目录下会生成mysite的工程,目录结构如下:

    diango mysite目录结构图

    • manage.py : Django项目里面的工具,通过它可以调用django shell和数据库等。
    • settings.py : 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。
    • urls.py : 负责把URL模式映射到应用程序。

    2.3 在mysite目录下创建应用

    $ python manage.py startapp blog
    

    diango blog目录结构图

    2.4 启动django

    $ python manage.py runserver 8080
    

    这样我们的django就启动起来了!当我们访问:http://127.0.0.1:8080/时就可以看到:

    django访问成功页面

    三、简单示例

    需求:利用Django实现一个查看当前时间的web页面。

    基于MTV模型,设计步骤如下:

    • step1:在urls.py中设计url与视图的映射关系。
    • step2:在views.py中构建视图函数。
    • step3:将变量嵌入到模板中返回客户端。

    目录结构:

    2021-05-11_202400

    url.py

    from django.contrib import admin
    from django.urls import path
    from app01 import views
    
    urlpatterns = [
        path('admin/', admin.site.urls),
        path('index/', views.timer),
    ]
    

    views.py

    from django.shortcuts import render,HttpResponse
    
    # Create your views here.
    
    import datetime
    
    def timer(request):
    
        s = datetime.datetime.now().strftime("%Y-%m-%d %X")
        return render(request,"timer.html",{"now_time":s})
    

    templates中的timer.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            .c1 span{
                color: red;
            }
        </style>
    </head>
    <body>
    <div class="c1">当前时间:<span>{{ now_time }}</span></div>
    </body>
    </html>
    

    显示效果:

    2021-05-11_202307

    *************** 当你发现自己的才华撑不起野心时,就请安静下来学习吧!***************
  • 相关阅读:
    JavaScript语言和jQuery技术--2
    Mybatis框架--1
    数据接口请求异常:parsererror
    Callable和Future?
    如何实现拦截器?
    window.onload()函数和jQuery中的document.ready()有什么区别?
    SpringBoot框架 1.什么是 Spring Boot?
    什么是 JavaConfig?
    jquery中$.get()提交和$.post()提交有区别吗?
    什么是线程?
  • 原文地址:https://www.cnblogs.com/lvzhenjiang/p/14757202.html
Copyright © 2020-2023  润新知