从0到1写一个网站(2)需求设计

简介: 这是《从0到1写一个网站》系列第二篇文章。这篇文章主要描述我要做的这个网站的功能,以及我对这些功能的拆分,然后使用事件风暴的方式,归纳出主要的领域模型和领域事件。

这是《从0到1写一个网站》系列第二篇文章。

这篇文章主要描述我要做的这个网站的功能,以及我对这些功能的拆分,然后使用事件风暴的方式,归纳出主要的领域模型和领域事件。


需求描述

整个网站应该分为管理端和门户端。管理端用于我自己在后台管理整个网站,包括发布文章、管理评论等等。管理端需要登录,但不需要做太复杂的权限管理,因为只有我一个用户。

门户端是给其它人用的,也就是大家现在看到的我的个人网站的样子,可以在上面看到我发布的文章,也可以对文章进行评论,对网站留言等等。

管理端

我用思维导图归纳了管理端的主要功能:

网络异常,图片无法展示
|

主要核心的还是文章。但我把标签和素材单独拿了出来,是想到以后网站可能会继续开发新的功能,比如类似于朋友圈、相册、电商等功能。那这样信息分类、文件素材等等能力其实是可以通用的。

除此之外,还对网站版本、公告、邮件订阅等等小功能也有一定的支持。

门户端

网络异常,图片无法展示
|

门户端会相对简单一些,因为很多东西都是只读的,少了很多操作。门户端全程是不需要登录的,包括留言操作。所以这里可能要注意一下安全性的问题,包括防刷和幂等。

在最初设计的时候,我认为有些文章可能是需要密码的,有些页面也可能是需要密码的,比如我们可以把求职简历放在上面。


事件风暴

我使用了事件风暴对整个需求进行了分析,试图寻找可以用于实现这些需求的领域模型、领域行为和领域事件。

我用三种颜色的便利贴来标识它们:

网络异常,图片无法展示
|

最终,我得到了下面9张图:

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

网络异常,图片无法展示
|

其中,页面配置是想把网站上的一些东西做成配置化的,包括一些页面的背景图和文案等,现在也实现了这个功能:

网络异常,图片无法展示
|

网络异常,图片无法展示
|

按道理说,标签、素材、密码其实也可以放在文章里面,成为文章这个聚合的一部分。但是这里单独拿了出来,是考虑到以后可能会有其它场景也会用到标签、素材、密码。

理论上来说,它们也可以成为单独的领域模型,对外提供服务。事实上很多公司也是这么做的,所谓业务中台,其实就是业务能力的复用。比如标签这个东西,它其实是一个信息管理的能力,既可以用在文章上,也可以用在商品上,还可以用在客户上。

但后来我想了一下,这样做是方便扩展了,但对于现在来说可能会加大开发成本。尤其是在找“标签”和“密码”的时候,我是非常纠结的。

于是,我砍掉了一些不那么核心的领域模型,更聚焦在核心的领域模型上面。最终剩下这么6个领域模型:

网络异常,图片无法展示
|

那标签和素材怎么办?


还是简单粗暴的处理方式,放在文章内部。因为其实现在也主要是文章会用到这两个东西,完全可以把它们作为文章这个领域模型的一个值对象。其实我现在线上这个版本也是这么做的:

网络异常,图片无法展示
|


当然了,从实现上来讲,可能底层的存储会和现在的实现有些不一样,因为之前就是在信息分类这块没做好,所以产生了“文集”、“主题”、“标签”等等一堆概念。但其实只需要标签就可以了,基于标签来做分类、搜索、推荐的功能。所以标签可能在DB层面是一个单独的表,但如何实现不是在这个阶段需要思考的,现在我们只需要关心领域模型就行了。


密码这个东西,现在看起来不是非要不可,而且想设计一个对多种资源加密的密码管理,开发成本较大,尤其是前端。所以我直接去掉了密码这个领域模型,也砍掉了与之相关的需求。以后如果有文章加密的需求,也可以作为文章的一个值对象来处理。

所谓DDD,最后一个D就是Design,没有绝对正确和标准的领域模型,只有合适的领域模型。设计总会有所权衡和取舍。在设计过程中,也会发现有些需求可能不合理或者实现成本比较大,可以做适当的调整。


没有再细分子域和限界上下文。因为目前来看,个人网站的功能还是比较简单的,没有必要再细分。真要细分的话,我觉得可以分为“文章域”、“网站管理域”和评论域,其中文章、订阅等属于文章域的,页面配置、公告、版本介绍等属于网站管理域。评论单独拿了出来,因为它是一个通用的子域,它既可以用于文章评论,也可以用于网站留言板。


为什么评论不拆开,一个是“文章评论”,一个是“留言板”?因为我认为两者其实是一个东西,都是用户在网站上留下一段话,也可以回复别人。只是评论的主体不同而已,一个是文章,一个是网站本身。所以我认为它是一个独立的领域模型。

整个网站的需求拆分、模型设计都已经搞好了,下一步需要做的就是开始搭建开发环境啦,敬请期待!

目录
相关文章
|
4月前
|
前端开发 JavaScript 测试技术
30个前端和设计必备网站,让你的工作更轻松!
30个前端和设计必备网站,让你的工作更轻松!
369 0
|
3月前
|
搜索推荐 语音技术 UED
网页可访问性设计的重要性、无障碍阅读的原则以及实现网页无障碍的具体方法
【6月更文挑战第14天】在数字化时代,网页可访问性设计至关重要,旨在确保所有用户,包括残障群体,能平等使用互联网。良好的可访问性符合法律法规要求,提升社会责任感,优化用户体验。无障碍阅读原则包括文本可读性、图像可感知性、音频视频可访问性和交互性设计。实现无障碍的方法有遵循WCAG标准、使用语义化HTML、支持辅助技术、进行无障碍测试及提供帮助。这不仅是技术挑战,更是设计者的社会责任。
75 0
|
XML 前端开发 Java
设计一个属于自己的网站
设计一个属于自己的网站
111 0
|
搜索推荐 UED 索引
整站优化怎么做好?做好整站优化的方法
整站优化考虑的是全站优化,不是个别或者极少数关键词优化,很多企业还停留在一两个关键词排名的思路上,这种思路即使关键词排名上来了,为企业带来的有效用户也是很少的,那么整站优化怎么做好?做好整站优化的方法又有哪些?接下来一起来看看吧。
7012 0
|
搜索推荐 UED SEO
整站优化有什么特点?整站优化有什么好处
整站优化采用符合搜索引擎的白帽技术进行网站优化,尽可能满足所有搜索引擎抓取的需要,同时获得较佳的搜索引擎排名位置,让企业网站通过搜索引擎带来潜在用户,具备获客能力。接下来一起来看看整站优化的特点与好处吧。
111 0
|
监控 搜索推荐 安全
一起来学习网站SEO优化工作流程到底怎么做?
垃圾外链指的就是没有质量,没有价值的链接,也就是说你的回帖没有质量,没有价值,完全是为了制造链接才回帖的比如你回帖是一些“不错,顶一下,路过”之类的词语可以算是垃圾外链,所以,做论坛回帖的签名链接回帖一定要认真回主题贴,千万不要随便打个字灌水式的回帖
256 0
一起来学习网站SEO优化工作流程到底怎么做?
|
XML 搜索推荐 前端开发
SEO优化中代码的使用要点以及对网站的影响
1、查询网站是否为静态页面 f12 调用,右键打开控制台。输入: alert(document.lastModified); 查看时间,当前时间为伪静态页面 一、HTML标签权重分值排列 内部链接文字: 标题title: 域名:
192 0
|
JavaScript 搜索推荐 UED
做SEO优化时需要注意的几个细节
很多站长说他们把自己的新站做好以后,在做网站优化的时候经常没什么效果,这个时候一般问题就是出现在细节上面,今天淄博SEO小编在这里列出了有多朋友都不怎么注意的细节问题供大家参考。 1.在关键词的选择上不够合理 我们都知道,选取好了一个合理的关键词那么网站就成功了一半,那么我们如何来选择合理.
1501 0
|
搜索推荐 SEO 数据安全/隐私保护
|
搜索推荐 UED SEO
想要做好SEO优化,你必须懂得SEO的核心因素
相信做网站的朋友都想通过SEO获得流量,都想在搜索引擎中获得更好的排名。说实在的,时至今日SEO手段和优化方法都是半斤八两。而影响SEO往往都是个人因素,是否有坚持、是否付出了耐心等。那么除了个人因素之外,什么才是影响SEO的核心因素呢?
1936 0