zoukankan      html  css  js  c++  java
  • Django简介

    一 MVC与MTV模型

    1.1 MVC

    Web服务器开发领域里著名的MVC模式,所谓MVC就是把Web应用分为模型(M),控制器(C)和视图(V)三层,他们之间以一种插件式的、松耦合的方式连接在一起,模型负责业务对象与数据库的映射(ORM),视图负责与用户的交互(页面),控制器接受用户的输入调用模型和视图完成用户的请求,其示意图如下所示:

    image-20200924175052910

    1.2 MTV

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

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

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

    image-20200924175204537

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

    二 Django的下载与基本命令

    2.1 下载Django

      方式一:在命令行输入:pip3 install django

        pip install django==1.11.9 -i http://pypi.hustunique.org/simple 指定版本号,指定国内镜像

      方式二:用pycharm安装

      方式三:用pycharm的Terminal的命令行安装

    2.2 创建一个django project

    django-admin.py startproject mysite
    

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

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

    2.3 在mysite目录下创建应用

    python manage.py startapp blog
    
    image-20200924175406936

    2.4 启动django项目

    python manage.py runserver 8001
    

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

    image-20200924175446249

    三 基于Django实现的一个简单示例

    3.1 URL控制器

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

    3.2 视图

    from django.shortcuts import render
    
    def index(request):
    
        import datetime
        now=datetime.datetime.now()
        ctime=now.strftime("%Y-%m-%d %X")
    
        return render(request,"index.html",{"ctime":ctime})
    

    3.3 模版

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    
    <h4>当前时间:{{ ctime }}</h4>
    
    </body>
    </html>
    

    四 Django静态文件配置

    4.1 static

    新建一个目录叫:static,我们的css文件,js文件,图片文件都放在这下面

    STATIC_URL = '/static/'
    STATICFILES_DIRS = [
        os.path.join(BASE_DIR, 'static'),
    ]
    

    4.2 mycss.css

    h4{
        color:red;
    }
    

    4.3 myjs.js

    $('h4').click(function () {
        $(this).css("color","green");
    })
    

    4.4 insex.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <link rel="stylesheet" href="/static/mycss.css">
        <script src="/static/jquery-3.3.1.js"></script>
    
    </head>
    <body>
    <h4>我是红色,点击变绿</h4>
    </body>
    <script src="/static/myjs.js"></script>
    </html>
    

    五 Django请求生命周期

    image-20200924175613811

    六 Django与其他web框架

    '''
    a socket服务端
    b 根据url不同返回不同的内容
        url---视图函数
    c 字符串返回给用户
        特殊字符替换
    
    Web框架种类:
    a         b   c     Tornado
    别人的a   b    c     django(a用的wsgiref)
    别人a     b   别人c  flask(c用的jinja2)
    另一种分类:
    Django和其它
    
    '''

    Django的下载与基本命令

    • 下载Django:pip3 install django==2.0.1
    • 创建一个django project: django-admin startproject luffy
    • 在mysite目录下创建应用:python manage.py startapp app01
    • 启动django项目:python manage.py runserver 8080 我们访问:http://127.0.0.1:8080/时就可以看到:
    • python manage.py makemigrations
    • python manage.py migrate
    • 清空数据库python manage.py flush
    • python manage.py createsuperuser
    • 修改用户密码python manage.py changepassword username
    • 命令行查看django版本:python -m django --version
    • python manage.py inspectdb > models.py
    • 生成requirements.txt文件:pip freeze > requirements.txt
    • 安装requirements.txt依赖:pip install -r requirements.txt
    • 更多命令python manage.py
    python manage.py migrate       # django中同步数据库时出现错误:
    
    错误代码1050:
    pymysql.err.InternalError: (1050, "Table 'tb_books' already exists")
    
    解决方法:
    python manage.py migrate app01 --fake 
    其中app01是应用名。

    使用PyCharm创建

    可以使用PyCharm的manage.py工具来执行命名。在主菜单栏中选择Tools,在下拉菜单中选择Run manage.py task,会出现如下图所示的工具对话框:

    在弹出的命令窗口中直接输入下面的命令便可创建app:

    startapp app01

    使用PyCharm的manage.py工具执行命令时,只用输入命令及参数即可,不再输入python manage.py了。

    #3、STATIC文件还可以配置STATICFILES_DIRS,指定额外的静态文件存储位置。
        #  STATIC_URL的含义与MEDIA_URL类似。
    
        # ----------------------------------------------------------------------------
        #注意1:
            #为了后端的更改不会影响前端的引入,避免造成前端大量修改
    
            STATIC_URL = '/static/'               #引用名
            STATICFILES_DIRS = (
                os.path.join(BASE_DIR,"statics")  #实际名 ,即实际文件夹的名字
            )
    
            #django对引用名和实际名进行映射,引用时,只能按照引用名来,不能按实际名去找
            #<script src="/statics/jquery-3.1.1.js"></script>
            #------error-----不能直接用,必须用STATIC_URL = '/static/':
            #<script src="/static/jquery-3.1.1.js"></script>
    
        #注意2(statics文件夹写在不同的app下,静态文件的调用):
    
            STATIC_URL = '/static/'
    
            STATICFILES_DIRS=(
                ('hello',os.path.join(BASE_DIR,"app01","statics")) ,
            )
    
            #<script src="/static/hello/jquery-1.8.2.min.js"></script>
    
        #注意3:
            STATIC_URL = '/static/'
            {% load staticfiles %}
           # <script src={% static "jquery-1.8.2.min.js" %}></script>
    static配置
  • 相关阅读:
    Spread for Windows Forms快速入门(11)数据筛选
    Spread for Windows Forms高级主题(7)自定义打印的外观
    Spread for Windows Forms高级主题(6)数据绑定管理
    使用WiX制作具有时间限制的安装包
    Spread for Windows Forms高级主题(2)理解单元格类型
    如何添加ActiveReports 6导出PDF时的安全设置和数字签名
    Spread for Windows Forms快速入门(10)绑定到数据库
    当心那些有歧义的命名
    【翻译】会有Silverlight6吗?
    Spread for Windows Forms快速入门(12)数据分组(Outlook风格)
  • 原文地址:https://www.cnblogs.com/bubu99/p/13766520.html
Copyright © 2011-2022 走看看