在上一篇文章《前后端分离之领域模型的思考》中,我们介绍了在前端开发中所遇到的一个问题。即:
对于我们的几个不同业务情景下,我们只使用同一个后台API的情形。如下图所示:

在我们的Blog Model里,我们有Author、Title、Slug、Content、Data几个字段。
而在我们使用的时候,我们需要依据这个模型应用到不同的场景下:
Tag、Title、Author、Date、Content五个字段。Tag、Title、Date、基于Content的Description四个字段。Title、Author、Date、Content、Slug五个字段。如果我们使用的是同一个模型,那么我们就很难做到分离上下文。并且在三种不同的场景下,Blog Model的含义都是不一样的:

于是,我们就需要想办法去区分不同的模型——这在后台来说是一件很容易的事:

但是在前台谁想这样做?在这其中使用复杂的OO思想?
所以,我们有了DDM。
我也想不起来为什么是Domain Double Model,大概是Frontend算是一个Model,后台算是一个Model。反正这个库就是叫这个名字了。
对于前台来说,一种理想的方式就是直接Clone一个Blog对象,然后从中获取所需要的字段了。

在一些博客里,如我的Django驱动的博客,Tag是属于另外一个API,就需要另外ADD

对于一些复杂的例子,我们就需要一个简单的Handle函数,如:

突然发现这里少了一个例子是:把Content变成Description,然后减少字符。。。
就这么简单和任性。
GitHub: https://github.com/phodal/ddm
据说,当前的测试覆盖率是100%;