django1

作者: christinazou | 来源:发表于2019-03-02 21:12 被阅读0次

    1. 创建项目——在当前路径下创建了一个mysite目录

    django-admin startproject mysite
    
    

    2. 目录结构

    |-- mysite
    |   |-- __init__.py
    |   |-- settings.py
    |   |-- urls.py
    |   `-- wsgi.py
    `-- manage.py
    
    • 外部mysite/根目录:项目的容器。
    • manage.py:一个实用的命令行工具,可让你以各种方式与该 Django 项目进行交互。
    • mysite/init.py:一个空文件,告诉 Python 该目录是一个 Python 包。
    • mysite/settings.py:该 Django 项目的设置/配置。
    • mysite/urls.py:该 Django 项目的 URL 声明; 一份由 Django 驱动的网站"目录"。
    • mysite/wsgi.py:一个 WSGI 兼容的 Web 服务器的入口,以便运行你的项目。

    3. 运行服务器

    python manage.py runserver 0.0.0.0:8000
    
    

    让其它电脑可连接到开发服务器,8000 为端口号。如果不说明,那么端口号默认为 8000。
    在浏览器输入你服务器的ip及端口号,如果正常启动,输出结果如下:

    命令行内应该也有如下输出,证明启动无误:

    
    System check identified no issues (0 silenced).
    
    You have unapplied migrations; your app may not work properly until they are applied.
    Run 'python manage.py migrate' to apply them.
    
    January 11, 2019 - 15:50:53
    Django version 2.1, using settings 'mysite.settings'
    Starting development server at [http://127.0.0.1:8000/](http://127.0.0.1:8000/)
    Quit the server with CONTROL-C.</pre>
    
    
    • 不要在生产环境中使用此服务器。它仅用于开发时使用
    • 默认情况下,该runserver命令在端口8000的内部IP上启动开发服务器,要改变端口直接跟在命令最后即可,python manage.py runserver 8080
    • 如果要更改服务器的IP,请将其与端口一起传递,python manage.py runserver 0:8000

    4. 创建 APP

    执行python manage.py命令式请确定与manage.py在同一路径下)

    python manage.py startapp myapp
    
    

    项目与应用程序的关系

    应用程序主要是负责执行操作,实现功能,类似博客里面的评论,登陆等等,而项目是特定网站的配置和应用程序的集合。项目可以包含多个应用程序。一个应用程序可以在多个项目中。执行应用创建命令之后会在当前路径下建立如下目录

    |-- mysite
    |   |-- __init__.py
    |   |-- settings.py
    |   |-- urls.py
    |   `-- wsgi.py
    |-- myapp
    |   |-- __init__.py
    |   |-- admin.py
    |   |-- models.py
    |   |-- tests.py
    |   `-- views.py
    `-- manage.py
    

    5. 应用结构

    i. 视图

    这里从单词就能看出来作用,类似MVC里面的views,主要是与页面视图相关的逻辑代码,并返回数据给页面使用

    from django.http import HttpResponse
    
    def index(request):
        return HttpResponse("Hello, world. You're at the polls index.")
    
    
    • HttpResponse是系统http模块方法,可通过它直接返回字符串,返回页面更多的使用render函数

    ii. URL映射

    要调用视图,我们需要将其映射到URL

    这里的映射配置一般写在urls.py里面,可以直接写在大项目目录下的urls.py里面,但是为了区分不同应用间的功能,我们往往会在每个应用中独立出一个urls.py配置文件(配置类似,可以直接复制过去更改相应path),在最外部项目下面的urls.py里面调用include方法配置即可

    这里配置好应用的urls之后我们去项目配置中设置URLconfig指向,这里需要导入include方法,该include()函数允许引用其他URLconf。每当Django遇到时include(),它都会删除与该点匹配的URL的任何部分,并将剩余的字符串发送到包含的URLconf以进行进一步处理。

    urls里面关于path的设置涉及四个参数,两个必需: route和view,以及两个可选:kwargs,和name。

    route: route(路由)是一个包含URL模式的字符串。访问时请求的路径,处理请求时,Django从第一个模式开始urlpatterns并沿着列表向下移动,将请求的URL与每个模式进行比较,直到找到匹配的模式。这里不会对请求方法(GET/POST)进行区分

    view: 当Django找到匹配的模式时,它调用指定的视图函数,其中一个HttpRequest对象作为第一个参数,并且路由中的任何“捕获”值作为关键字参数。相当于传递一个视图函数中的方法,我们稍后会给出一个例子。

    kwargs: 任意关键字参数可以在字典中传递到目标视图。我们不打算在教程中使用Django的这个功能(目前用处不多)

    name: 命名您的URL可以让您从Django的其他地方明确地引用它,特别是在模板中。此强大功能允许您在只触摸单个文件的同时对项目的URL模式进行全局更改。相当于是给你调用的视图函数起一个名字,之后在返回的模板页面里面方便调用


    polls/的urls.py

    from django.urls import path
    
    from . import views
    
    urlpatterns = [
        path('', views.index, name='index'),
    ]
    
    

    mysite/的urls.py

    from django.contrib import admin
    from django.urls import include, path
    
    urlpatterns = [
        path('polls/', include('polls.urls')),
        path('admin/', admin.site.urls),
    ]
    
    

    至此我们已经完成了第一个Django项目的第一部分,可以执行服务器然后去页面看一下效果,应该就是你视图函数里面编写的字符串内容,记得安装创建的应用哦

    • 应用创建并且编写好视图函数以及urls等配置时记得去settings里面安装应用,将应用名字添加进INSTALLED_APPS即可

    相关文章

      网友评论

          本文标题:django1

          本文链接:https://www.haomeiwen.com/subject/osiyuqtx.html