探索Django 5:从零开始,打造你的第一个Web应用

Django是一个高级的Python Web框架,它能够帮助开发者快速构建高效且可扩展的Web应用。Django的设计理念强调可重用性和“不要重复自己”(DRY)。在本文中,我们将逐步构建一个简单的Web应用。

环境准备

首先,确保你已经安装了Python(推荐使用Python 3.8及以上版本)。然后,通过pip安装Django 5:

pip install django

安装完成后,你可以通过以下命令检查Django的版本:

python -m django --version

创建项目

接下来,我们将创建一个新的Django项目。打开终端或命令行工具,输入以下命令:

django-admin startproject myproject

进入项目目录:

cd myproject

你会看到一个名为myproject的文件夹,里面包含了Django项目的基本结构。

运行开发服务器

在本示例中,我们将启动Django的开发服务器,以确保一切正常工作。输入以下命令:

python manage.py runserver

打开浏览器,访问http://127.0.0.1:8000/,如果看到Django的欢迎页面,那就表示我们创建的项目成功了。

创建应用

在Django中,项目由多个应用组成。现在,我们将创建一个名为blog的应用:

python manage.py startapp blog

这将会在项目目录下创建一个名为blog的文件夹。

定义模型

接下来,我们将在blog/models.py中定义一个简单的数据库模型。我们将创建一个博客文章的模型。打开models.py文件,并添加以下代码:

from django.db import models

class Post(models.Model):
    title = models.CharField(max_length=200)
    content = models.TextField()
    created_at = models.DateTimeField(auto_now_add=True)

    def __str__(self):
        return self.title

在这个模型中,我们定义了三个字段:title(标题)、content(内容)和created_at(创建时间)。

注册模型

要让Django知道我们新创建的模型,我们需要在blog/admin.py中注册它。打开admin.py文件,并添加以下代码:

from django.contrib import admin
from .models import Post

admin.site.register(Post)

数据库迁移

接下来,我们需要生成和应用数据库迁移,以便在数据库中创建我们的模型。运行以下命令:

python manage.py makemigrations
python manage.py migrate

创建超级用户

为了能够登录管理后台,我们需要创建一个超级用户。运行以下命令:

python manage.py createsuperuser

按照提示输入用户名、电子邮件和密码。

启动开发服务器并访问管理后台

再次启动开发服务器:

python manage.py runserver

现在打开浏览器,访问http://127.0.0.1:8000/admin。输入刚才创建的超级用户的用户名和密码,你将看到Django管理后台。在后台你可以看到Posts,并可以添加新博客文章。

创建视图和模板

最后,我们将创建一个简单的视图,以显示所有博客文章。首先,打开blog/views.py并添加以下代码:

from django.shortcuts import render
from .models import Post

def post_list(request):
    posts = Post.objects.all()
    return render(request, 'blog/post_list.html', {'posts': posts})

接下来,我们需要创建一个模板来展示这些文章。在blog目录下创建一个名为templates的文件夹,再在templates中创建一个名为blog的文件夹。然后在blog文件夹中创建post_list.html

<!DOCTYPE html>
<html>
<head>
    <title>Blog Posts</title>
</head>
<body>
    <h1>Blog Posts</h1>
    <ul>
        {% for post in posts %}
            <li>{{ post.title }} - {{ post.created_at }}</li>
        {% endfor %}
    </ul>
</body>
</html>

最后,我们需要在项目的urls.py中指定这个视图。在myproject/urls.py中添加以下代码:

from django.contrib import admin
from django.urls import path
from blog.views import post_list

urlpatterns = [
    path('admin/', admin.site.urls),
    path('', post_list, name='post_list'),
]

运行并查看结果

现在,启动开发服务器,访问http://127.0.0.1:8000/,你将看到你的第一个Web应用,列出所有的博客文章。

结论

本文介绍了如何从零开始使用Django 5构建一个简单的Web应用。通过创建模型、视图和模板,我们成功实现了一个能够展示博客文章的应用。接下来,你可以进一步探索Django的更多特性,如表单处理、用户认证和REST API等。Django是一个强大且灵活的框架,无论你是新手还是有经验的开发者,都能在其中找到乐趣和灵感。

点赞(0) 打赏

微信小程序

微信扫一扫体验

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部