0

0

理解 Django 的架构:MTV 模式

花韻仙語

花韻仙語

发布时间:2024-10-18 20:24:10

|

718人浏览过

|

来源于dev.to

转载

理解 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 文件中:

magento(麦进斗)
magento(麦进斗)

Magento是一套专业开源的PHP电子商务系统。Magento设计得非常灵活,具有模块化架构体系和丰富的功能。易于与第三方应用系统无缝集成。Magento开源网店系统的特点主要分以下几大类,网站管理促销和工具国际化支持SEO搜索引擎优化结账方式运输快递支付方式客户服务用户帐户目录管理目录浏览产品展示分析和报表Magento 1.6 主要包含以下新特性:•持久性购物 - 为不同的

下载
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 代码




    
    
    hello template


    

hello, {{ name }}!

当您再次访问学习 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 应用程序。现在,您可以通过添加更多功能来扩展此基础,例如处理用户输入、改进设计以及使应用程序更具交互性。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

676

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1094

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

675

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

571

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

414

2024.04.29

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

9

2026.01.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号