首页
学习
活动
专区
工具
TVP
发布

第一个Django应用,第1部分

安装Django。

pip3 install django==2.0.7

python3 -m django --version

2.0.7

如果这行命令输出了一个版本号,证明你已经安装了此版本的 Django;

django-admin startproject mysite

通过上述命令startproject创建了些什么:

.

|____mysite

| |______init__.py

| |____settings.py

| |____urls.py

| |____wsgi.py

|____manage.py

这些目录和文件的用处是:

最外层的:file: mysite/ 根目录只是你项目的容器, 可以将它重命名。

manage.py: 一个让你用各种方式管理 Django 项目的命令行工具。

里面一层的 mysite/ 目录包含你的项目,它是一个纯 Python 包。

mysite/__init__.py:一个空文件,告诉 Python 这个目录应该被认为是一个 Python 包。

mysite/settings.py:Django 项目的配置文件。

mysite/urls.py:Django 项目的 URL 声明,就像你网站的“目录”。

mysite/wsgi.py:作为你的项目的运行在 WSGI 兼容的Web服务器上的入口。

python3 manage.py runserver

出现以下信息:

Starting development server at

http://127.0.0.1:8000/

打开浏览器

http://localhost:8000/

你将会看到一个“祝贺”页面,随着一只火箭发射,服务器已经运行了。

更换端口

python manage.py runserver 8080

监听所有服务器的公开IP

python manage.py runserver 0:8000

会自动重新加载的服务器runserver

用于开发的服务器在需要的情况下会对每一次的访问请求重新载入一遍 Python 代码。所以你不需要为了让修改的代码生效而频繁的重新启动服务器。然而,一些动作,比如添加新文件,将不会触发自动重新加载,这时你得自己手动重启服务器。

项目 VS 应用

项目和应用有啥区别?应用是一个专门做某件事的网络应用程序——比如博客系统,或者公共记录的数据库,或者简单的投票程序。项目则是一个网站使用的配置和应用的集合。项目可以包含很多个应用。应用可以被很多个项目使用。

请确定你现在处于 manage.py 所在的目录下,然后运行这行命令来创建一个应用:

python manage.py startapp polls

将会创建一个polls目录,它的目录结构大致如下:

.

|____migrations

| |______init__.py

|____models.py

|______init__.py

|____apps.py

|____admin.py

|____tests.py

|____views.py

编写第一个视图

让我们开始编写第一个视图吧。打开 polls/views.py,把下面这些 Python 代码输入进去:

polls/views.py

from django.http import HttpResponse

def index(request):

return HttpResponse("Hello, world. You're at the polls index.")

这是 Django 中最简单的视图。如果想看见效果,我们需要将一个 URL 映射到它——这就是我们需要 URLconf 的原因了。

为了创建 URLconf,请在 polls 目录里新建一个 urls.py 文件。你的应用目录现在看起来应该是这样:

polls/

__init__.py

admin.py

apps.py

migrations/

__init__.py

models.py

tests.py

urls.py

views.py

在 polls/urls.py 中,输入如下代码:

polls/urls.py

from django.urls import path

from . import views

urlpatterns = [

path('', views.index, name='index'),

]

下一步是要在根 URLconf 文件中指定我们创建的 polls.urls 模块。在 mysite/urls.py 文件的 urlpatterns 列表里插入一个 include(), 如下:

mysite/urls.py

from django.contrib import admin

from django.urls import include, path

urlpatterns = [

path('polls/', include('polls.urls')),

]

我们设计 include() 的理念是使其可以即插即用。因为投票应用有它自己的 URLconf( polls/urls.py ),他们能够被放在 "/polls/" , "/fun_polls/" ,"/content/polls/",或者其他任何路径下,这个应用都能够正常工作。

何时使用 include()

你现在把 index 视图添加进了 URLconf。可以验证是否正常工作,运行下面的命令:

python manage.py runserver

用你的浏览器访问 http://localhost:8000/polls/,你应该能够看见 "Hello, world. You're at the polls index." ,这是你在 index 视图中定义的。

函数 path() 具有四个参数

两个必须参数:route 和 view

两个可选参数:kwargs 和 name。

现在,是时候来研究这些参数的含义了。

path() 参数: route

route 是一个匹配 URL 的准则(类似正则表达式)。当 Django 响应一个请求时,它会从 urlpatterns 的第一项开始,按顺序依次匹配列表中的项,直到找到匹配的项。

这些准则不会匹配 GET 和 POST 参数或域名。例如,URLconf 在处理请求 https://www.example.com/myapp/时,它会尝试匹配 myapp/ 。处理请求 https://www.example.com/myapp/?page=3 时,也只会尝试匹配 myapp/。

path() 参数: view

当 Django 找到了一个匹配的准则,就会调用这个特定的视图函数,并传入一个 HttpRequest 对象作为第一个参数,被“捕获”的参数以关键字参数的形式传入。

path() 参数: kwargs

任意个关键字参数可以作为一个字典传递给目标视图函数。

urls.py中

urlpatterns = [

path('', views.index,{'abc':"def","aaa":"bbb"}, name='index'),

]

views中获取参数

def index(request,**abc):

print(request)

print(abc)

return HttpResponse("Hello, world. You're at the polls index.")

打印的结果为:

{'abc': 'def', 'aaa': 'bbb'}

path() 参数: name

为你的 URL 取名能使你在 Django 的任意地方唯一地引用它,尤其是在模板中。这个有用的特性允许你只改一个文件就能全局地修改某个 URL 模式。

谢谢!

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180716G1REUY00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券