Django,一个用Python编写的开源Web应用框架,以其高效、简洁和强大的功能而闻名。它遵循MTV(模型-模板-视图)架构模式,帮助开发者快速构建安全、可扩展的Web应用。

本文将引导你入门Django,从安装到创建第一个简单应用,带你领略Django的魅力。

1. 安装Django

首先,确保你的系统上已经安装了Python。Django官方推荐使用虚拟环境来管理项目依赖,避免版本冲突。

python -m venv env
source env/bin/activate
pip install django

2. 创建Django项目

使用​django-admin​命令行工具创建新项目:

django-admin startproject myproject

这将在当前目录下创建一个名为myproject的文件夹,包含以下文件:

  • manage.py:Django项目管理脚本,用于执行各种任务,例如启动服务器、创建应用等。
  • myproject/:包含项目配置的Python包。
  • settings.py:Django项目的配置文件,例如数据库设置、INSTALLED_APPS等。
  • urls.py:Django项目的URL路由配置文件,用于将URL请求映射到相应的视图函数。
  • wsgi.py:用于与WSGI服务器交互的入口文件。
  • asgi.py:用于与ASGI服务器交互的入口文件。

3. 创建Django应用

Django项目由多个应用组成,每个应用负责实现特定的功能。使用以下命令创建名为`myapp`的应用:

python manage.py startapp myapp

这将在myproject目录下创建myapp文件夹,包含以下文件:

  • models.py:定义应用数据模型的文件,使用Python类来描述数据库表结构。
  • views.py:包含视图函数的文件,用于处理HTTP请求并返回响应。
  • admin.py:用于注册模型到Django管理后台的文件。
  • apps.py:应用的配置文件。
  • tests.py:编写应用测试用例的文件。

4. 编写视图函数

在myapp/views.py中添加一个简单的视图函数:

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('', include('myapp.urls')),
]

该函数接收一个​request​对象(表示HTTP请求),并返回一个​HttpResponse​对象,内容为”Hello, world! This is my first Django app.”。

5. 配置URL路由

打开myproject/urls.py,将myapp的URL模式包含进来:

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('', include('myapp.urls')),
]

然后在myapp目录下创建urls.py文件,并将index视图函数映射到根URL:

from django.urls import path
from . import views

urlpatterns = [
    path('', views.index, name='index'),
]

6. 运行开发服务器

一切就绪,现在可以启动Django开发服务器了:

python manage.py runserver

在浏览器中访问http://127.0.0.1:8000/,你将看到”Hello, world! This is my first Django app.”的页面。

总结

本文只是Django的入门介绍,Django还有更多强大的功能等待你去探索,例如:

  • 数据库ORM:使用Python对象操作数据库,无需编写SQL语句。
  • 模板系统:使用模板语言动态生成HTML页面,实现前后端分离。
  • 表单处理:简化表单数据的验证和处理逻辑。
  • 用户认证:提供用户注册、登录、权限管理等功能。

希望本文能激发你学习Django的兴趣,开始你的Web开发之旅! 

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。