如何一步一步用DDD设计一个电商网站(十)—— 一个完整的购物车

news/2024/5/17 12:59:09/文章来源:https://blog.csdn.net/weixin_30629653/article/details/94945177

本系列所有文章

如何一步一步用DDD设计一个电商网站(一)—— 先理解核心概念

如何一步一步用DDD设计一个电商网站(二)—— 项目架构

如何一步一步用DDD设计一个电商网站(三)—— 初涉核心域

如何一步一步用DDD设计一个电商网站(四)—— 把商品卖给用户

如何一步一步用DDD设计一个电商网站(五)—— 停下脚步,重新出发

如何一步一步用DDD设计一个电商网站(六)—— 给购物车加点料,集成售价上下文

如何一步一步用DDD设计一个电商网站(七)—— 实现售价上下文

如何一步一步用DDD设计一个电商网站(八)—— 会员价的集成

如何一步一步用DDD设计一个电商网站(九)—— 小心陷入值对象持久化的坑

如何一步一步用DDD设计一个电商网站(十)—— 一个完整的购物车

如何一步一步用DDD设计一个电商网站(十一)—— 最后的准备

如何一步一步用DDD设计一个电商网站(十二)—— 提交并生成订单

如何一步一步用DDD设计一个电商网站(十三)—— 领域事件扩展

 

 

 

阅读目录

  • 前言
  • 回顾
  • 梳理
  • 实现
  • 结语

 

一、前言

  之前的文章中已经涉及到了购买商品加入购物车,购物车内购物项的金额计算等功能。本篇准备把剩下的购物车的基本概念一次处理完。

 

二、回顾

  在动手之前我对之前的购买上下文内对象做了一次回顾。先梳理一下已经在上下文内出现的领域对象,如图1所示:

 

                          【图1】

  在梳理的过程中,我把原来Cart.AddCartItem(string productId, int quantity, decimal price)重构为了Cart.AddCartItem(Product product, int quantity),这样的好处的是2个:

  1.更清晰的表述出了在购物车中添加商品的意思。

  2.约束了外部只能通过Product对象来进行商品的添加,这样在Product构造函数中的约束在这里无需再次验证(如salename不能空等)。

 

三、梳理

  目前的购物车中在操作上的方法只有一个。参照目前主流电商平台的设计,我们需要增加:

  1.修改数量

  2.删除

  3.选择参与的促销(如果存在多个非单品级促销)

  4.收藏商品

  前面3个比较简单,都是购物车自身的概念,只有其中第四点超出了购物车自身的范畴,并且笔者认为收藏本就不是购物车特有的概念,而是在任何看得到商品的地方都可以做添加收藏的操作。那么自然引出了一个新的概念——收藏夹。看下最新的UML图,如图2所示:

 

                          【图2】

  我想会有一部分同学在设计收藏夹(Favorites)的时候会以另外的方式来做,比如像下图3这样:

                          【图3】

  这里我认为这样考虑的原因可能是由于DBFirst的思想导致的,因为图2中的“收藏夹”仅仅是维护了一个“用户”与“收藏项”之间的关系,那么只要在“收藏项”上增加一个UserId就直接可以省去了这一层关系,并且数据结构更加简单。这时候我们就需要注意了,千万不能有DBFirst思想去影响领域的建模,这样的方式会把“添加购物项”这类的业务含义泄露到了Repository层或者Application层去实现,导致无法用通用语言进行完整的业务描述了。

  并且在这个场景下,我个人观点认为,收藏商品其实只是为商品的展示途径中增加了一种途径而已,所以它应该被设计为独立存在的,由它自身来管理这些“被收藏的商品”,它的存在与否都不影响其它领域对象。

 

四、实现

  要实现这4个操作,那么需要在ICartService中增加下面4个接口:

        Result ChangeQuantity(string userId, string id, int quantity);Result DeleteCartItem(string userId, string id);Result AddToFavorites(string userId, string productId);Result ChangeMultiProductsPromotion(string userId, string productId, string selectedMultiProductsPromotionId);

  其中的部分实现如下:

        public Result AddToFavorites(string userId, string productId){var cart = _confirmUserCartExistedDomainService.GetUserCart(userId);if (cart.IsEmpty()){return Result.Fail("当前购物车中并没有商品");}var cartItem = cart.GetCartItem(productId);if (cartItem == null){return Result.Fail("该购物项已不存在");}var favorites = DomainRegistry.FavoritesRepository().GetByUserId(userId) ?? new Favorites(userId, null);favorites.AddFavoritesItem(cartItem);DomainRegistry.FavoritesRepository().Save(favorites);return Result.Success();}

  其中关于Favorites的构造函数我是这么做的:

        public Favorites(string userId, IEnumerable<FavoritesItem> favoritesItems){if (string.IsNullOrWhiteSpace(userId))throw new ArgumentNullException("userId");this.UserId = userId;this._favoritesItems = new List<FavoritesItem>();if (favoritesItems != null && favoritesItems.Any()){foreach (var favoritesItem in favoritesItems){AddFavoritesItem(favoritesItem);}}}

  这样可以重用AddFavoritesItem中的一些守卫操作,保证在业务产生变动之后历史数据从DB取出来的时候经过一次最新的业务验证,确保数据在流转过程中的合法性。这个方式可以择机运用在任何聚合的构造函数中。

 

五、结语

  本篇主要的观点还是在建模上的思维惯性,抛开DB,抛开DB,抛开DB,重要的事情说3遍。

   

 

 

本文的源码地址:https://github.com/ZacharyFan/DDDDemo/tree/Demo10。

 

作者:Zachary_Fan
出处:http://www.cnblogs.com/Zachary-Fan/p/DDD_10.html

 

 

▶关于作者:张帆(Zachary,个人微信号:Zachary-ZF)。坚持用心打磨每一篇高质量原创。欢迎扫描右侧的二维码~。

定期发表原创内容:架构设计丨分布式系统丨产品丨运营丨一些思考。

 

如果你是初级程序员,想提升但不知道如何下手。又或者做程序员多年,陷入了一些瓶颈想拓宽一下视野。欢迎关注我的公众号「跨界架构师」,回复「技术」,送你一份我长期收集和整理的思维导图。

如果你是运营,面对不断变化的市场束手无策。又或者想了解主流的运营策略,以丰富自己的“仓库”。欢迎关注我的公众号「跨界架构师」,回复「运营」,送你一份我长期收集和整理的思维导图。

转载于:https://www.cnblogs.com/Zachary-Fan/p/DDD_10.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_782100.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

服务器2008r2 iis配置asp网站,在2008 R2 Server Core中配置IIS站点

在前面的在2008 R2 Server Core中安装ASP.Net文中我们讨论了如何在Windows Server 2008 R2 Server Core中安装APS.NET并安装IIS管理服务&#xff0c;这些步骤完成后我们为在Server Core中配置一个IIS站点做好了准备&#xff0c;在下文中我们将继续讨论Server Core中IIS站点的配…

怎么把网站挂载服务器,如何将本地项目挂载到云服务器

如何将本地项目挂载到云服务器 内容精选换一换企业管理是提供给企业客户的与多层级组织和项目结构相匹配的云资源管理服务。主要包括企业项目管理、人员管理、财务管理和应用管理。统一身份认证(Identity and Access Management&#xff0c;简称IAM)是提供用户身份认证、权限分…

SwiftUI——获取网站api中的JSON,并且显示其中的文本

这是开发中非常常见的使用场景。 首先&#xff0c;我们需要知道要获取的json是什么样的&#xff0c;有两种方式得知&#xff1a; 第一&#xff0c;查询API文档&#xff1a; 一般在网站API文档中会介绍&#xff0c;如下&#xff1a; 第二种&#xff0c;通过使用crul -H获取&…

[基础常识]阿里云ecs从购买到环境搭建和建站!!(phpstudy一件包)

首先如何购买ECS&#xff1f;发现有些人购买5G硬盘&#xff0c;我个人认为买硬盘应该购买20以上&#xff01;这样以后好处理&#xff01; 进入http://www.aliyun.com/product/ecs/?spm5176.7189909.201.2.CVdddr 点击后面后选择配置&#xff0c;你也可以选择镜像市场&…

如何使用Jekyll在GitHub Pages上搭建网站(个人博客)

前言 本文很长&#xff0c;建议使用侧边栏进行跳转。 Jekyll 是一个基于 Ruby 语言的&#xff0c;用于搭建静态网站的生成器&#xff0c;主要用于搭建博客网站&#xff08;官方自己的介绍为&#xff1a;Jekyll is a blog-aware, static site generator in Ruby&#xff09;。但…

使用WebDeployment Project改善VS2005发布网站问题 (三) 常见问题

一、发布后网站浏览时出现乱码(http://www.cnblogs.com/chy710)如果页面编码是gb2312&#xff0c;可能会有此问题&#xff0c;请使用utf-8编码&#xff0c;vs2005中打开页面切换到HTML视图&#xff0c;选择[文件] / [高级保存选项],选择utf-8,保存&#xff0c;OK。二、发现不明…

web 2.0 网站推荐

web 2.0是一个很热的话题&#xff0c;作为一条小网虫&#xff0c;自然也会凑凑这个热闹。当然了&#xff0c;网上讲述web 2.0的文章可谓铺天盖地了&#xff0c;看了那么多&#xff0c;看了那么久&#xff0c;我也没有看出个所以然来。总之&#xff0c;所谓2.0就是1.0的升级版呗…

png图标搜索网站

推荐一个png图标搜索网站&#xff1a; http://www.iconpng.com/ 能找到很多好东东&#xff0c;设计网站的时候帮了我不少忙

安装好IIS后发布网站

首先&#xff0c;进行网站发布是需要IIS支持的&#xff0c;此处默认已经安装好IIS&#xff0c;并进行了Asp.net注册过程&#xff08;此步骤必需 &#xff0c;因为我是先安装的 .net 环境 &#xff0c;再安装的IIS&#xff09;。 其次&#xff0c;以下步骤可以方便指导新手如何…

一些免费的WebService的服务网站(转发)

免费&#xff1a;网站首页 http://www.webxml.com.cn/zh_cn/web_services.aspx 例如&#xff1a; [新] 中文<->英文双向翻译WEB服务 获得标准数据Endpoint: http://fy.webxml.com.cn/webservices/EnglishChinese.asmx Disco: http://fy.webxml.com.cn/webservices/En…

为了打击网站被黑作弊行为,360搜索上线悟空算法2.0

我们在搜索浏览网页的时候&#xff0c;经常会出现正常网页跳转至含有色情&#xff0c;博彩等信息的恶意站点上去。这样严重影响到了用户的搜索体验&#xff0c;为了打击此类行为&#xff0c;360搜索正式上线了&#xff1a;“悟空算法2.0”网站被黑是一种较为常见的现象&#xf…

html搜索迎,老网站的域名来新建网站(保留原站内容与链接)

我们维护了一段时间网站&#xff0c;发现这个网站不是我们想要的那个样子&#xff0c;如果选择直接不要原来的内容&#xff0c;一来感觉可惜了&#xff0c;二来是不利于搜索引擎优化。今天&#xff0c;错误博客( cuowu.com )带来的是《网站的域名来新建网站(保留原站内容与链接…

极域电子教室软件怎么脱离控制_企业官网推广seo排名优化的优势?seo排名方法怎么样?...

seo排名影响的因素有很多&#xff0c;在做排名优化的时候&#xff0c;我们需要对相关的排名方法进行充分的了解&#xff0c;比如seo排名优化的优势有哪些?seo排名方法怎么样?下面就跟宝丞网小编一起来了解seo排名优化的优势。seo排名优化的优势seo排名优化的优势1.节省费用&a…

服务器网站打开慢跟什么有关系吗,服务器网站打开慢是什么原因 | 帮助信息-动天数据...

服务器网站打开慢是什么原因作者&#xff1a;dthost |时间&#xff1a;2018-01-02 |5,709 次阅读笔者是销售虚拟主机的&#xff0c;不管是买空间的&#xff0c;还是没有卖空间的&#xff0c;都会经常遇见反应网站慢&#xff0c;或者服务器慢的情况&#xff0c;我们下面把我们自…

java网站优化_什么是java 网站性能优化?

信息技术的发展&#xff0c;各种软件的研发&#xff0c;给我们生活带来了许多方便和乐趣。不同的软件都是不同编程语言做的&#xff0c;java也是众多编程语言的一种&#xff0c;想做好一个好的java软件&#xff0c;java 网站性能优化你应该了解。一、什么是java语言Java是一门面…

asp.net mvc2网站部署在IIS6的方法

部署环境&#xff1a; Server 2003 IIS6 1.先安装好IIS6&#xff0c;再安装.net framework 4.0和asp.net mvc 安装包(主要是里面的一个dll&#xff0c;不安装也可以&#xff0c;只需要找到这个dll&#xff0c;将mvc.dll 放入网站bin目录下&#xff0c;这个dll文件的默认路径是C…

删除 Windows Azure 网站上的标准服务器头

编辑人员注释&#xff1a; 本文章由 Windows Azure 网站团队的项目经理 Erez Benari 撰写。 请求和响应中包含的 HTTP 头是Web 服务器和浏览器之间的 HTTP 通信过程的一部分。例如&#xff0c;以下是一个典型网站上某个 Web 请求的典型响应中记录的头&#xff1a; HTTP 头是客户…

第二章:SE简单对话 【闲话家常---《SEO通俗入门精谱》】

在上一章中&#xff0c;我们谈到了当前的搜索引擎的具体工作原理&#xff0c;本章将接着上面的内容而来&#xff0c;为大家进一步阐述SE的分类&#xff0c;以及SE的未来发展方向等两方面的内容&#xff0c;以期让大家更加明确的知道SE到底是干什么的&#xff0c;以及SE在发展过…

nginx服务器实现网站的301跳转

网站不带3W的域名在访问时自动跳转到带3w的域名&#xff0c;这是做网站seo最基本的要求。nginx服务器如何做301跳转呢&#xff1f; 1.进入vhost目录&#xff1a; /usr/local/nginx/conf/vhost 这里存放的是网站的配置文件&#xff0c;找到您相应的配置文件&#xff0c;使用vi打…

如何进行网站流量分析(一)

如何进行网站流量分析&#xff08;一&#xff09; 流量分析整体来说是一个内涵非常丰富的体系&#xff0c;整体过程是一个金字塔结构&#xff1a; 金字塔的顶部是网站的目标&#xff1a;投资回报率&#xff08;ROI&#xff09;。 网站流量分析模型举例 1 网站流量质量分析&a…