◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
以下是 Django 中的一些关键术语,以及详细解释:
在 Django 中,模型是定义数据库结构的类。它充当创建、读取、更新和删除数据的蓝图。每个模型对应一个数据库表,模型的每个属性代表该表中的一个字段。模型使用 Django 的对象关系映射 (ORM) 与数据库交互,使您能够使用 Python 代码编写数据库查询。
Django 中的视图是一个接受 Web 请求并返回 Web 响应的函数或类。它包含处理用户请求、与模型交互和渲染模板所需的逻辑。视图充当 MVC(模型-视图-控制器)架构中的控制器,尽管 Django 将其模式称为 MTV(模型-模板-视图)。
模板是带有动态数据占位符的 HTML 文件。它们定义如何向用户显示内容。 Django 使用其模板语言将数据动态呈现为 HTML,从而允许代码重用和跨页面的一致呈现。模板将表示层与业务逻辑分开。
URL Dispatcher 是将 URL 映射到视图的配置。也称为 urls.py,它根据 URL 模式将传入请求路由到适当的视图。这使您可以为您的 Web 应用程序定义干净、可读的 URL,从而使用户更轻松地浏览您的网站。
ORM 是 Django 使用 Python 代码而不是原始 SQL 查询与数据库交互的技术。它允许开发人员通过创建Python对象(模型)来操作数据库,并提供执行CRUD(创建、读取、更新、删除)操作、查询优化和表之间关系的方法。
Django Admin 是一个内置工具,提供基于 Web 的界面来管理数据库内容。它允许管理员在数据库中添加、修改和删除记录,而无需编写任何代码。管理界面是高度可定制的,有助于快速应用程序开发和测试。
中间件是请求和响应周期之间的一层。它在请求到达视图之前对其进行处理,并在将响应发送到客户端之前对其进行处理。中间件可以执行身份验证、会话管理和修改请求/响应标头等任务。它有助于添加横切功能。
Django 中的表单用于处理用户输入数据。它们可用于创建 HTML 表单、验证表单数据和处理表单提交。 Django 表单具有内置的验证和安全措施,减少了手动输入处理的需要,并确保数据在保存到数据库之前是干净的。
QuerySet 是数据库查询的集合,用于从模型中检索、过滤或操作数据。它表示一组符合特定条件并允许链接操作的记录。查询集是惰性的,这意味着它们在显式评估之前不会访问数据库,从而优化性能。
静态文件是指图像、CSS 文件、JavaScript 和其他在应用程序执行过程中不会更改的文件。 Django 提供了在开发期间提供静态文件的机制,并帮助收集它们以进行部署。
迁移是 Django 用于将对模型所做的更改传播到数据库架构中的文件。 Django 不是编写原始 SQL,而是自动为您创建迁移,这确保根据您的模型定义创建、更改或删除数据库表和列。
DRF 是 Django 的扩展,有助于构建 RESTful API。它简化了创建 Web API 的过程,并提供了用于序列化、身份验证、权限和视图集的工具。它遵循 REST(表述性状态传输)的原则,使得构建可以与前端应用程序或第三方客户端交互的 Web 服务变得更加容易。
DRF 中的序列化器将查询集和模型实例等复杂数据类型转换为本机 Python 数据类型,然后可以轻松呈现为 JSON、XML 或其他内容类型。它们还处理反序列化,允许在验证传入数据后将解析的数据转换回复杂类型。
Django 具有内置的 CSRF 保护,可确保恶意用户无法欺骗经过身份验证的用户在网站上提交不需要的操作。它使用 CSRF 令牌来验证每个 POST 请求是否来自受信任的来源。
信号允许解耦应用程序在应用程序中其他地方发生某些操作时收到通知。例如,您可以使用信号在用户注册时自动为其创建个人资料。它们有助于保持关注点分离并减少组件之间的紧密耦合。
上下文处理器是将某些数据注入到每个模板的上下文中的函数。这允许您使变量在模板中全局可用,而无需在每个视图中显式传递它们。它对于添加需要在所有页面上访问的数据非常有用,例如用户信息或站点设置。
这些术语和组件共同作用,使 Django 成为构建可扩展 Web 应用程序的强大框架。
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。