理解 Django 的架构:MTV 模式
来源:dev.to
时间:2024-10-20 18:36:58 418浏览 收藏
学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《理解 Django 的架构:MTV 模式》,以下内容主要包含等知识点,如果你正在学习或准备学习文章,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!
django 遵循 mtv(模型-模板-视图)模式进行 web 开发。以下是每个组件的详细信息:
模型:定义您的数据结构并处理与数据库的交互,允许您存储和检索数据而无需手动编写 sql 查询。
模板:负责渲染 html 并将数据呈现给用户。您可以编写与 django 模板语言 (dtl) 混合的 html 来显示动态内容。
视图:充当业务逻辑层。它连接模型和模板,处理用户请求,与模型交互,并返回响应(通常是从模板渲染的 html)。
django 的请求-响应周期如何工作:
- 用户请求网页(通过 url)。
- django 将 url 匹配到视图。
- 视图从模型中获取数据并将其传递给模板。
- 模板将数据呈现为 html 并将其作为响应发送回给用户。
第 1 步:在 django 中创建一个新应用。
设置 django 后(如上一篇文章所述),让我们在您的项目中创建一个新应用程序。
运行这些命令:
cd mysite python3 manage.py startapp core
这会在您的 mysite 项目中创建一个名为 core 的应用程序。您的文件结构现在应如下所示:
. ├── core │ ├── admin.py │ ├── apps.py │ ├── __init__.py │ ├── migrations │ │ └── __init__.py │ ├── models.py │ ├── tests.py │ └── views.py ├── db.sqlite3 ├── manage.py └── mysite ├── asgi.py ├── __init__.py ├── settings.py ├── urls.py └── wsgi.py
第 2 步:在设置文件中注册您的应用程序。
为了让 django 知道新应用程序,您需要将其添加到 mysite/settings.py 中的 installed_apps 中:
installed_apps = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'core', # add this line ]
第 3 步:创建基本视图。
让我们创建一个返回“hello, world!”的简单视图。留言。
在核心应用程序中打开views.py并添加以下代码:
from django.http import httpresponse def learn(request): return httpresponse("hello, world!")
第 4 步:将 url 映射到视图。
要通过 url 访问此视图,您需要将其映射到 core/urls.py 文件中。如果该文件不存在,则创建该文件并添加以下内容:
from django.urls import path from . import views urlpatterns = [ path('learn/', views.learn, name='learn'), ]
接下来,将核心应用程序的 url 包含在主 mysite/urls.py 文件中:
from django.contrib import admin from django.urls import include, path urlpatterns = [ path('admin/', admin.site.urls), path('core/', include('core.urls')), # include the core app urls ]
现在,如果您运行服务器并访问 http://127.0.0.1:8000/core/learn/,您应该看到“hello, world!”显示。
第 5 步:创建并渲染模板
from django.shortcuts import render def learn(request): context = {'name': 'django'} return render(request, 'hello.html', context)
此视图现在将变量(名称)传递给名为 hello.html 的模板。
第 6 步:创建模板目录和 html 文件.
在您的核心应用程序中,创建一个 templates 文件夹和一个 hello.html 文件:
mkdir core/templates touch core/templates/hello.html
在 hello.html 中,添加以下 html 代码
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>hello template</title> </head> <body> <h1>hello, {{ name }}!</h1> </body> </html>
当您再次访问学习 url 时,您现在应该看到“hello, django!”在浏览器中。
第 7 步:创建基本模型.
让我们创建一个简单的 post 模型来存储博客文章。
在 core/models.py 中,添加以下代码:
from django.db import models class post(models.model): title = models.charfield(max_length=100) content = models.textfield() def __str__(self): return self.title
这个 postmodel 有两个字段:标题和内容。 __str__ 方法确保 post 对象在 django 管理或 shell 中显示及其标题
第 8 步:将模型应用到数据库。
要在数据库中创建相应的表,请运行以下命令:
python3 manage.py makemigrations python3 manage.py migrate
django 现在将为 post 模型创建一个数据库表。
通过执行这些步骤,您已成功创建了一个包含模型、视图和模板的基本 django 应用程序。现在,您可以通过添加更多功能来扩展此基础,例如处理用户输入、改进设计以及使应用程序更具交互性。
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
109 收藏
-
100 收藏
-
386 收藏
-
170 收藏
-
188 收藏
-
275 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习