Django 致力于 API 的稳定性和向前兼容性。简而言之,这意味着你在一个 Django 版本开发的代码可以继续在未来的版本中使用。在升级你的项目使用的 Django 版本时,你可能需要做一些小的更改: 了解你要升级的一个或多个版本请参阅 发行版注解 中的“向后不兼容更改”部分。
在将 API 的稳定性作为一个非常重要的优先级的同时,Django 还致力于持续的改进,并致力于在我们提供的 API 中实现“一种方法”(最终)。这意味着,当我们发现明显更好的实现方式时,我们会弃用旧的方式,并最终将其移除。我们的目标是提供一个现代的、可靠的、高质量的 web 框架,帮助所有使用它的项目的使用最佳实践。通过使用渐进式的改进,我们试图避免停滞和大规模破坏性升级。
在此处,稳定意味着:
所有发布的 API (在文档中的一切 API )在不提供向后兼容的别名的情况下,都不会被移除或者重命名。
如果文档中的 API 添加了新特性(这是极有可能的),新特性不会导致现有方法罢工或者修改方法的含义。也就是说,“稳定性”并不意味着“不变性”。
假如因为某些原因,一个“稳定的” API 必须被移除或者被代替,它将会被弃用但仍然会被保留直到至少有两个新特性发布。当调用即将被弃用的方法时,会产生警告。
有关 Django 是如何编写版本号以及一些功能是如何被弃用的详细信息,请看: 正式发行。
如果一个 bug 或安全漏洞完全不可避免,我们才会直接打破这些 API 的向后兼容性而不走弃用过程。
5月 12, 2023