你如何在项目中实际使用可重用的django应用程序?

时间:2014-02-16 13:36:11

标签: python django code-reuse reusability django-apps

这个问题一直困扰着我好几天了,我试过在很多地方寻求建议,但似乎没人能清楚地回答它,甚至提供答案的参考。

我也尝试过搜索教程,但是我找不到任何类型的教程来解释如何使用可重复使用的第三方django应用程序(大多数教程解释了如何编写它们,没有解释如何使用它们)

另外,我看了一下:

How to re-use a reusable app in Django - 它没有解释如何在项目本身中实际使用它

在这里:

How to bind multiple reusable Django apps together? - aquaplanet的回答是有道理的,但我想我会问这个问题来解决我在试图理解这个问题时面临的心理障碍。


为了最好地解释这一点,请允许我举例说明(注意,这不是我实际构建的内容)。

我正在创建一个像Reddit一样的项目。我会有用户,链接和投票/积分。基于这个粗略的例子,我想重用3个(任意的)第三方应用程序:用户,投票/点和链接。

我决定将它们中的每一个用作任何其他python包(意味着它们将被视为包,并且不应该触及它们的代码)[这种方法实际上会起作用吗?或者你必须能够编辑第三方应用程序来构建项目??)

现在我的项目中有这些应用程序,我将使用主应用程序处理所有模板内容(意味着我在前端看到的所有内容都将在一个应用程序中)。

然后,我将使用相同的主应用程序进行自定义逻辑(在views.py中)或者我将在不同的应用程序之间分解该逻辑(但仍将使用单个前端应用程序)。

从上面3段开始,这个结构是否适用(或者它可以工作)?


现在我们可以说这个结构适用,我正在使用一个主应用程序用于前端和自定义逻辑。

我会在models.py中写些什么?如何将3个可重用应用程序中的内容集成到 models.py文件中?

我如何在views.py中引用可重用的应用程序?让我们以contrib.auth

为例

使用这个内置的应用程序,我会写出:

from django.contrib.auth import authenticate, login, logout
@login_required
def user_logout(request):
logout(request)

return HttpResponseRedirect('/home/')

虽然上面的代码很简单,但基本上是如何使用任何可重用的应用程序完成的?

我的问题很长,但我认为这个可重用的应用程序问题是许多开发人员对自己不太清楚的事情,也许这个答案会帮助很多其他听过可重用应用程序承诺的人,但不明白如何实际使用它们。

2 个答案:

答案 0 :(得分:3)

TL; DR:

Nope&这取决于......

一些(非常)常见的可重用应用

......这些都是可重复使用的Django应用程序,恰好与Django一起发布(大部分都不是,在某个时间点)

好的,其他一些不带Django的可重用应用程序:

这些都是真正可重复使用的应用程序,并没有更少。还有很多类似的应用程序。

他们是如何做到的?

对我而言,您的问题看起来更像是“我如何构建可重用的应用程序”,然后是“如何使用它们”。实际上使用它们从应用程序到应用程序是非常不同的,因为它们做了非常不同的事情。只有一条规则:RTFM也没办法。

通常,他们依赖以下一项或多项:

  • settings.py
  • 中的其他值
  • 添加(通常一个include语句)到urls.py
  • 模型,表单,字段,视图等的子类化和/或混合。
  • 模板标签和/或过滤器
  • 管理命令
  • ...

这些都是强大的方式,您的应用可以提供功能到其他应用。没有配方(AFAIK)来制作可重复使用的应用程序,因为需要考虑很多不同的方案。这一切都取决于你的应用程序应该做什么。

可重复使用的应用提供功能

我认为重要的是不要将可重用的应用程序视为与其他应用程序“协同工作”,而是要认识到它们“提供了功能”。提供的功能的详细信息应该规定目标开发人员应该使用您的库的方式。

并非一切都应该可以重复使用

显然,尽管许多应用程序“原则上”可以重复使用,但这样做通常没有多大意义,因为它可以更快地将事物聚集在一起(并使它们只是“一起工作”)。

答案 1 :(得分:0)

我不确定为什么你认为你需要一个主要应用程序的“前端”的东西。可重用应用程序的重点在于它会处理所有事情,您只需添加(通常)单个URL以包含应用程序的urls.py,以及您自己的模板和样式。

除非您特别想要覆盖某些功能,否则您当然不需要在自己的视图中包含应用程序的视图。

我完全不了解你的模特问题。没有“主要”模型文件,使用可重复使用的应用程序模型与使用任何自己的应用程序中的模型相同。

通常情况下,您不会编辑第三方应用,因此很难整合更新。只需在你的virtualenv中安装应用程序(你当然是使用virtualenv!)和pip,它将把它放在lib目录中,你可以像任何其他应用程序一样引用它。确保将其添加到INSTALLED_APPS。