API 的稳定性

Django 致力于 API 的稳定性和向前兼容性。简而言之,这意味着你在一个 Django 版本开发的代码可以继续在未来的版本中使用。在升级你的项目使用的 Django 版本时,你可能需要做一些小的更改: 了解你要升级的一个或多个版本请参阅 发行版注解 中的“向后不兼容更改”部分。

在将 API 的稳定性作为一个非常重要的优先级的同时,Django 还致力于持续的改进,并致力于在我们提供的 API 中实现“一种方法”(最终)。这意味着,当我们发现明显更好的实现方式时,我们会弃用旧的方式,并最终将其移除。我们的目标是提供一个现代的、可靠的、高质量的 web 框架,帮助所有使用它的项目的使用最佳实践。通过使用渐进式的改进,我们试图避免停滞和大规模破坏性升级。

什么是“稳定”?

在此处,稳定意味着:

  • 所有发布的 API (在文档中的一切 API )在不提供向后兼容的别名的情况下,都不会被移除或者重命名。

  • 如果文档中的 API 添加了新特性(这是极有可能的),新特性不会导致现有方法罢工或者修改方法的含义。也就是说,“稳定性”并不意味着“不变性”。

  • 假如因为某些原因,一个“稳定的” API 必须被移除或者被代替,它将会被弃用但仍然会被保留直到至少有两个新特性发布。当调用即将被弃用的方法时,会产生警告。

    有关 Django 是如何编写版本号以及一些功能是如何被弃用的详细信息,请看: 正式发行

  • 如果一个 bug 或安全漏洞完全不可避免,我们才会直接打破这些 API 的向后兼容性而不走弃用过程。

稳定的 API

一般来说,文档中的一切都确定是稳定的,除开 内部区域

例外

这种稳定性和向后兼容性承诺有一些例外。

安全修复

如果我们发现了安全问题 --希望报告者遵照我们的 安全报告政策--我们会尽一切努力解决它。 这可能意味着打破向后兼容性; 安全性优先于兼容性保证。

标记为内部的 API

某些API在几种方式中被明确标记为 "内部" :

  • 一些文档提及了这些 API 并标为“内部”,如果确实如此,我们保留修改它的权利。
  • 一些函数,方法以及其他对象以下划线“_”开头,这是 Python 声明其为“私有”的标准方式,如果一个方法以单下划线“_”开头,那么这意味着它是 Django 内部的一个 API。