”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > Django 适合所有人。

Django 适合所有人。

发布于2024-09-05
浏览:329

Django is for everyone.

即使对于“小型”网站,Django 也很棒

我认为人们倾向于认为 Django 要么用于构建老式的、工业强度的整体应用程序,要么用于 API 并使用 React 之类的东西作为前端。我在这里告诉您,即使对于您的个人网站,普通的 Django 也是一个不错的选择!在我看来,如果你需要数据库,你应该使用 Django1.

为什么是姜戈?

Django 被认为是一个“包含电池”的框架,这些电池非常棒。这些是让我继续使用 Django 而不是其他框架的原因。

对象关系映射器 (ORM)

Django ORM 是使用该框架的一个重要原因。令我惊讶的是,并非所有 Web 框架都包含 ORM。除非您非常喜欢从头开始编写 SQL,否则这是构建应用程序的正确方法。您定义模型,从这些模型创建数据库迁移(大部分自动),在数据库上运行迁移,然后就可以开始了!无需编写半途而废的模型以及一系列可以推断模式的迁移2所有您需要的有关数据的信息都在您的 models.py 文件中,一切都从中产生。

管理员

这是一件大事。它不是 CMS;而是 CMS。它更像是 ORM 的 GUI。定义模型后,您可以通过非常少的配置来管理该数据,而无需编写任何 CRUD 代码。它不是您应用程序的前端。它不是面向最终用户的 CMS(可能)。这是管理员轻松更改网站的一种方式。

渐进增强

这对我来说非常重要,但我们行业的大多数其他人似乎已经忘记了。简单地说;即使 JavaScript 失败,基本级别的功能也应该是可能的。您的应用程序至少应该能够在没有前端脚本的情况下运行。使用 SPA 来做到这一点是一场噩梦。使用真正的后端框架加上 htmx 或 Unpoly 等工具来完成此操作是微不足道的。你只需要把你的观点从现状转向常识。

需要牢记的概念

音乐电视

虽然传统的应用程序框架使用模型、视图、控制器设计模式; Django 对元素的命名略有不同。

  • 模型
    • 好吧,这个是一样的。
  • 模板
    • 这相当于传统的View.
  • 看法
    • 这基本上相当于传统的控制器

数据库迁移

这是 Django 中已解决的问题。真是太好了!还有很多东西需要了解,您应该在运行生成的迁移文件之前查看它们,有时您需要更手动地执行这些操作,但是这就是使用它的关键:

./manage.py makemigrations
# It tells you what it did.

./manage.py migrate
# Database updated!

就是这样! ?

如何开始

火焰马

这是我自己的小项目的地方。对于您(我想正在阅读本文的独立开发人员)来说,好消息是它可以免费用于非商业用途。如果您最终使用它并且它帮助您构建了一个商业应用程序,那么只需 100 美元一次。来吧,这太值了!

即使您最终没有使用整个套件,我也强烈建议您查看我在代码中使用的技术。几乎从一开始就使用 Django 后,这是来之不易的东西。我经历了将它与 Docker 和 Postgres 一起使用的阶段,但我真的相信这对于 99% 想要尝试 Django 的人来说是 的方式。 SQLite 太棒了。

部署

不幸的是,这是选择 Django 而非其他针对个人网站的选项的主要缺点。对于 Blaze.horse,我试图让您轻松度过,但它仍然比应有的更复杂。有一些即将到来的项目给了我希望,例如 Button 和 Appliku,但我个人目前对 Fly 很满意。

后续步骤

读完本文后,我希望您下次需要构建某些东西时能够记住 Django。如果我能帮忙请告诉我!


  1. 如果您需要 CMS,您应该使用 Kirby。如果您需要 CMS,您当然不应该使用静态站点生成器。 FFS ↩

  2. Laravel ↩

版本声明 本文转载于:https://dev.to/battlecat/django-is-for-everyone-3dkp?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • React:了解 React 的事件系统
    React:了解 React 的事件系统
    Overview of React's Event System What is a Synthetic Event? Synthetic events are an event-handling mechanism designed by React to ach...
    编程 发布于2024-11-05
  • 为什么在使用 Multipart/Form-Data POST 请求时会收到 301 Moved Permanently 错误?
    为什么在使用 Multipart/Form-Data POST 请求时会收到 301 Moved Permanently 错误?
    Multipart/Form-Data POSTs尝试使用 multipart/form-data POST 数据时,可能会出现类似所提供的错误消息遭遇。理解问题需要检查问题的构成。遇到的错误是 301 Moved Permanently 响应,表明资源已被永久重定向。当未为 multipart/f...
    编程 发布于2024-11-05
  • 如何使用日期和时间对象确定 PHP 中的时间边界?
    如何使用日期和时间对象确定 PHP 中的时间边界?
    确定 PHP 中的时间边界在此编程场景中,我们的任务是确定给定时间是否在预定义的范围内。具体来说,我们得到三个时间字符串:当前时间、日出和日落。我们的目标是确定当前时间是否位于日出和日落的边界时间之间。为了应对这一挑战,我们将使用 DateTime 类。这个类使我们能够表示和操作日期和时间。我们将创...
    编程 发布于2024-11-05
  • 如何使用 CSS 变换比例修复 jQuery 拖动/调整大小问题?
    如何使用 CSS 变换比例修复 jQuery 拖动/调整大小问题?
    jQuery 使用 CSS 变换缩放拖动/调整大小问题: 当应用 CSS 变换时,特别是变换:矩阵(0.5, 0, 0, 0.5, 0, 0);,对于一个 div 并在子元素上使用 jQuery 的draggable() 和 resizing() 插件,jQuery 所做的更改变得与鼠标位置“不同步...
    编程 发布于2024-11-05
  • 如何修复 TensorFlow 中的“ValueError:无法将 NumPy 数组转换为张量(不支持的对象类型浮点)”错误?
    如何修复 TensorFlow 中的“ValueError:无法将 NumPy 数组转换为张量(不支持的对象类型浮点)”错误?
    TensorFlow:解决“ValueError: Failed to Convert NumPy Array to Tensor (Unsupported Object Type Float)”工作时遇到的常见错误TensorFlow 的错误是“ValueError:无法将 NumPy 数组转换为...
    编程 发布于2024-11-05
  • 如何高效判断本地存储项是否存在?
    如何高效判断本地存储项是否存在?
    确定本地存储项目是否存在使用 Web 存储时,在访问或修改特定项目之前验证它们是否存在至关重要。在本例中,我们想要确定 localStorage 中是否设置了特定项目。当前方法检查项目是否存在的当前方法似乎是:if (!(localStorage.getItem("infiniteScro...
    编程 发布于2024-11-05
  • Java 中的原子是什么?了解 Java 中的原子性和线程安全
    Java 中的原子是什么?了解 Java 中的原子性和线程安全
    1. Java 原子简介 1.1 Java 中什么是原子? 在Java中,java.util.concurrent.atomic包提供了一组支持对单个变量进行无锁线程安全编程的类。这些类统称为原子变量。最常用的原子类包括 AtomicInteger 、 Atomic...
    编程 发布于2024-11-05
  • 前端/后端主要配置文件
    前端/后端主要配置文件
    从 DevOps 的角度来看,了解 Java 和 Node.js(后端和前端)代码库中的配置文件对于管理构建流程、部署和环境设置至关重要。以下是在 Java 和 Node.js 应用程序中需要注意的配置文件的完整列表: Java 应用程序 后端 pom.xml (Maven): 管理...
    编程 发布于2024-11-05
  • Python 中出现“意外缩进”错误的原因以及如何解决?
    Python 中出现“意外缩进”错误的原因以及如何解决?
    Python 中意外缩进的意义是什么?在 Python 编程领域,精心制作的缩进起着至关重要的作用定义代码的结构和流程。当这个缩进不经意间被打乱时,就会出现“unexpected indent”错误,提示需要立即纠正。错误信息背后:Unexpected Indent本质Python 的语法要求代码块...
    编程 发布于2024-11-05
  • 在 Node.js 中什么时候应该使用 `setImmediate` 和 `process.nextTick`?
    在 Node.js 中什么时候应该使用 `setImmediate` 和 `process.nextTick`?
    了解 setImmediate 和 nextTick 之间的差异Node.js 版本 0.10 引入了 setImmediate,这是一个旨在补充 process.nextTick 的新 API。这两个函数都提供了异步执行回调的方法,但它们具有控制其使用的独特特征。nextTick:快速和同步pro...
    编程 发布于2024-11-05
  • jQuery中如何高效获取隐藏元素的高度?
    jQuery中如何高效获取隐藏元素的高度?
    在 jQuery 中获取隐藏元素的高度处理隐藏元素时,检索其高度可能具有挑战性。暂时显示元素以测量其高度然后再次隐藏它的传统方法似乎效率低下。有没有更优化的解决方案?jQuery 1.4.2 方法这是一个使用 jQuery 1.4.2 的示例:$select.show(); optionHeight...
    编程 发布于2024-11-05
  • 为什么我不能在 Go Struct 标签中使用变量?
    为什么我不能在 Go Struct 标签中使用变量?
    在 Go 结构体标签中使用变量在 Go 中,结构体标签用于指定有关结构体中字段的元数据。虽然可以使用字符串文字定义标签,但尝试在其位置使用变量会导致错误。无效用法:const ( TYPE = "type" ) type Shape struct { Type s...
    编程 发布于2024-11-05
  • Qopy:作为开发人员我最喜欢的剪贴板管理器
    Qopy:作为开发人员我最喜欢的剪贴板管理器
    作为一名开发人员,我一直在寻找可以使我的工作流程更顺畅、更高效的工具。最近,我偶然发现了 Qopy,一个可以在 Linux 和 Windows 上运行的开源剪贴板管理器。 什么是Qopy? Qopy 是一个简单的剪贴板管理器,旨在改进标准剪贴板体验。它的设计宗旨是用户友好、可靠且快速...
    编程 发布于2024-11-05
  • 为什么我的按钮上的悬停效果不起作用?
    为什么我的按钮上的悬停效果不起作用?
    更改悬停时的按钮颜色:替代解决方案尝试更改悬停时按钮的颜色时,如果出现以下情况,可能会令人沮丧该解决方案未能产生预期的效果。考虑提供的示例代码:a.button { ... } a.button a:hover{ background: #383; }此解决方案尝试在链接悬停在“按钮...
    编程 发布于2024-11-05
  • 仅使用 Python 构建前端
    仅使用 Python 构建前端
    对于专注于后端的开发人员来说,前端开发可能是一项艰巨的、甚至是噩梦般的任务。在我职业生涯的早期,前端和后端之间的界限是模糊的,每个人都被期望能够处理这两者。 CSS,尤其是,是一场持续不断的斗争;这感觉像是一个不可能完成的任务。 虽然我喜欢前端工作,但 CSS 对我来说仍然是一个复杂的挑战,特别是因...
    编程 发布于2024-11-05

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3