使用django + REST框架时,django MVC的哪些部分变得无关紧要?

时间:2018-04-07 20:26:04

标签: django rest model-view-controller web-architecture

最近开始学习Django。 长话短说 -
如果我选择合并:

  • 我服务器端的django框架
  • REST作为中间件层
  • 一些客户端框架(例如React,Angular等)

django&{s} MVC components中的哪一个会变得无关紧要?
我假设 templates 组件。在这种情况下是否还有其他必要的基本组件(模型/视图......)?

1 个答案:

答案 0 :(得分:0)

根据你的帖子假设你使用Django只是从数据库中提取数据并以JSON格式将其提供给客户端,并且你的模板将呈现在客户端(使用例如Angular)然后你就是纠正你可能不会需要Django模板。但是,您仍然需要某种模型(无论是使用Django模型还是其他模型),还需要控制器(Django称之为 views )以便:

  1. 执行URL路由(即将某些URL绑定到某个控制器/视图 功能)。
  2. 进行某种服务器端处理。即使你的应用程序 是一个单页面的应用程序,并进行了大量的客户端处理, 您仍然可能需要实施不同类型的业务 服务器端的要求和验证。其中一些 您可能会附加到模型的要求,但您可能会有其他要求 需要在控制器中实现。
  3. 因此,虽然你的控制器(也就是视图)可能很多,但是更健康的"由于您构建应用程序的方式,他们在某种程度上仍然是必要的。如果您想为数据库提供一些干净且一致的API,则始终需要使用模型。

    编辑:要进一步扩展这一点 - 虽然有一个名为Django REST Framework的Python库,但它确实可以帮助您构建RESTful API。您当然可以使用Django自己构建RESTful API,而无需利用它或任何其他库。正如用户D. Shawley在回答这个问题时的回答 - What exactly is RESTful programming? - RESTful API基本上只是一个资源由持久性标识符(在本例中为URI)标识的资源,其中资源是使用一组通用动词(在本例中为HTTP方法,如GET,POST,DELETE等)进行操作。因此,使用URI的名词作为名词和HTTP方法作为动词,您的Django框架可能支持以下RESTful操作:

    • GET https://your-app.com/product/123 - 此操作获取由ID 123
    • 标识的产品
    • POST https://your-app.com/product - 此操作会创建新产品
    • PUT https://your-app.com/product/123 - 此操作会更新由ID 123
    • 标识的产品
    • DELETE https://your-app.com/product/123 - 此操作会删除由ID 123
    • 标识的产品

    从这些操作返回的数据并不一定需要采用任何特定格式(无论是JSON,XML还是其他格式)。在一个严格遵守REST原则的应用程序中,客户端(RESTful API的使用者,在本例中是您的前端应用程序)将能够指定(使用HTTP Accept标头)他们想要的格式消耗数据。

    我希望这不会太混乱,但实际上我想说明REST架构只是一套原则,而网络程序员开发的API可能不一定100%遵循这些原则。您的应用程序是否必须严格遵守RESTful原则取决于您的特定要求。那么问自己的一个问题是你希望通过使用Django构建RESTful API来实现什么目标?对于很多开发人员来说,答案很简单,因此我的Angular / React /等界面易于使用。用于检索和更新服务器端资源的应用程序。"