DDD领域模型企业级系统Unity(五)
添加程序集:
写一个接口:
public interface IPlayer
{
void Play();
}
两个实现类:
public class NewPlay : IPlayer
{
public void Play()
{
MessageBox.Show("NewPlay");
}
} public void Play()
{ MessageBox.Show("OldPlay");
}
ServiceLocator类:
public class ServiceLocator
{
IUnityContainer container = new UnityContainer();
public ServiceLocator()
{
container.RegisterType<IPlayer, NewPlay>("new");
container.RegisterType<IPlayer, OldPlay>("old");
} public IUnityContainer GetContainer()
{
return container;
}
}
调用:获取一个和全部
ServiceLocator servicelocator =
new ServiceLocator();
var iplay = servicelocator.GetContainer().Resolve<IPlayer>("new");
var iplays = servicelocator.GetContainer().ResolveAll<IPlayer>();
foreach(var iplay in iplays)
{
iplay.Play();
}
构造函数的调用:
[InjectionConstructor]
public OldPlay()
{
MessageBox.Show("构造函数被执行");
}
var iplay = servicelocator.GetContainer().Resolve<IPlayer>("old");
属性注入:
写一个类:
public class Person
{
public string Name { get { return "孙"; } }
public int Age { get { return 32; } }
}
[Dependency]
public Person person { get; set; }
自动实例化
public void Play()
{
MessageBox.Show("OldPlay "+person.Name);
}
方法调用注入:
public Person person { get; set; } public void Play()
{ MessageBox.Show("OldPlay");
} [InjectionMethod]
public void Auto(Person person)
{
MessageBox.Show("注入方法 "+person.Name);
}
依赖注入的原理:
添加ProductRepository的仓储:(给聚合根建立仓储)
public class ProductRepository:EFRepository<Product>
{ }
添加SalesOrderRepository的仓储:
public class SalesOrderRepository:EFRepository<SalesOrder>
{
}
添加ProductRepository的仓储:
public class ProductRepository:EFRepository<Product>
{ }
添加CustomerRepository的仓储:
public class CustomerRepository:EFRepository<Customer>
{
}
定义一个实现Product领域逻辑的部分类(继承聚合根):
public partial class Product:AggreateRoot
{
//定义仓储的接口
private IRepository<Product> irepository;
//由调用方指定具体仓储的实现
public Product(IRepository<Product> irepository)
{
this.irepository = irepository;
}
//默认构造函数
public Product()
{ } /// <summary>
/// 实现自身聚合根的职责
/// </summary>
/// <param name="name"></param>
/// <param name="color"></param>
/// <param name="size"></param>
/// <param name="count"></param>
/// <param name="unitprice"></param>
/// <param name="categoryname"></param>
/// <param name="description"></param>
public void CreateProduct(string name,string color,string size,int count,
decimal unitprice,string categoryname,string description)
{
var product = new Product();
product.Id = base.Id; //聚合根的ID
product.ProductName = name;
product.Color = color;
product.Size = size;
product.Count = count;
product.UnitPrice = unitprice;
//聚合根下面的实体和值对象
var productcategory = new ProductCategory(categoryname,description);
product.ProductCategory = productcategory;
//添加到仓储中把对象维护起来
irepository.Create(product); }
/// <summary>
/// 减少库存的责
/// </summary>
/// <param name="p"></param>
/// <param name="amount"></param>
/// <param name="irepository"></param>
public void ModifyCount(Product p,int amount,IRepository<Product> irepository)
{
p.Count = this.Count - amount;
irepository.Update(p);
} public Product GetProducyByName(string productname)
{
return irepository.GetByCondition(p => p.ProductName == productname)
.FirstOrDefault();
}
}
定义一个值对象:(负责维护自己的领域逻辑和状态信息)
public abstract class ValueObject : IValueObject
{
public Guid Id
{
get
{
var id = Guid.NewGuid();
return id;
}
}
} public interface IValueObject
{
Guid Id { get; }
}
产品类别的逻辑:
public partial class ProductCategory:ValueObject
{
public ProductCategory(string categoryname,string description)
{
this.Id = base.Id;
this.CategoryName = categoryname;
this.Description = description;
}
}
地址的值对象:
/// <summary>
/// 值对象
/// </summary>
public partial class Address:ValueObject
{
public Address(string state,string city,string street)
{
this.State = state;
this.City = city;
this.Street = street;
}
}
定义一个实现Customer领域逻辑的部分类(继承聚合根):
public partial class Customer:AggreateRoot
{
//定义仓储接口
private IRepository<Customer> irepository;
//构造函数
public Customer(IRepository<Customer> irepository)
{
this.irepository = irepository;
} public void CreateCustomer(string name,string mobile,string state,string city,
string street)
{
Customer customer = new Customer();
customer.Id = base.Id;
customer.Name = name;
customer.Mobile = mobile;
addcustomeraddress(customer, state, city, street);
irepository.Create(customer);
} /// <summary>
/// 添加地址
/// </summary>
/// <param name="customer"></param>
/// <param name="state"></param>
/// <param name="city"></param>
/// <param name="street"></param>
private void addcustomeraddress(Customer customer,string state,string city,string street)
{
//值对象
var address = new Address(state, city, street);
//添加地址
customer.Address.Add(address);
} public void AddCustomerOtherAddress(Customer customer,string state,string city,
string street)
{
addcustomeraddress(customer, state, city, street);
irepository.Update(customer);
} public Customer GetCustomerByName(string name)
{
return irepository.GetByCondition(p => p.Name == name).FirstOrDefault();
}
}
单元测试(添加引用):
单元测试:
EFRepositoryContext context =
new EFRepositoryContext();
[TestMethod]
public void CreateProduct()
{
//Product product = new Product(new ProductRepository());
ProductAppService product = new ProductAppService();
product.CreateProduct("P1", "Red", "Small", 100, 55, "C1", "T恤类产品");
product.CreateProduct("P2", "Green", "Big", 200, 40, "C2", "运动类产品");
context.Commit();
Assert.IsNotNull(product.GetProductByName("P1")); } [TestMethod]
public void CreateCustomer()
{
Customer customer = new Customer(new CustomerRepository());
customer.CreateCustomer("sun", "13458629365", "sanxi", "sanxi", "sanxi");
context.Commit();
Assert.IsNotNull(customer.GetCustomerByName("sun"));
}
DDD领域模型企业级系统Unity(五)的更多相关文章
- DDD领域模型企业级系统(二)
用户层: 1.请求应用层获取用户显示的信息 2.发送命令给应用层要求执行某个命令 应用层: 对用户界面提供各种应用功能(包括信息获取与命令执行),应用层不包含业务逻辑,业务层是由应用层调用领域层(领域 ...
- DDD领域模型企业级系统(一)
领域模型的基本构造块: 1.实体(Entity):有业务生命周期,使用标识进行跟踪. 2.值对象(Value Object):无业务生命周期,用来描述实体. 3.服务(Service):无状态的行为类 ...
- DDD领域模型企业级系统Linq的CRUD(四)
建造一个Product Module类: ProductDBContextDataContext dbcontext = new ProductDBContextDataContext(); publ ...
- DDD领域模型企业级系统(三)
相关代码: public static void ShowArray() { //数据源 int[] arrayas = new int[] { 1, 2, 3, 4 }; //创建查询 var qu ...
- DDD领域模型和充血对象
DDD领域模型 官方说法 领域驱动设计,它是对面向对象的的分析和设计(OOAD,Object Orient Analysis Design)的一个补充,对技术框架进行了分层规划,同时对每个类进行了策略 ...
- Android系统的五种数据存储形式(一)
Android系统有五种数据存储形式,分别是文件存储.SP存储.数据库存储.contentprovider 内容提供者.网络存储.其中,前四个是本地存储.存储的类型包括简单文本.窗口状态存储.音频视频 ...
- 【百度地图API】建立全国银行位置查询系统(五)——如何更改百度地图的信息窗口内容?
原文:[百度地图API]建立全国银行位置查询系统(五)--如何更改百度地图的信息窗口内容? 摘要: 酷讯.搜房.去哪儿网等大型房产.旅游酒店网站,用的是百度的数据库,却显示了自定义的信息窗口内容,这是 ...
- Android系统--输入系统(五)输入系统框架
Android系统--输入系统(五)输入系统框架 1. Android设备使用场景: 假设一个Android平板,APP功能.系统功能(开机关机.调节音量).外接设备功能(键盘.触摸屏.USB外接键盘 ...
- DDD领域模型实现依赖注入(六)
添加下订单的值对象: public partial class CustomerInfo:ValueObject { /// <summary> /// 下订单的值对象 /// </ ...
随机推荐
- 使用AutoMapper实现Dto和Model的自由转换(上)
在实际的软件开发项目中,我们的“业务逻辑”常常需要我们对同样的数据进行各种变换.例如,一个Web应用通过前端收集用户的输入成为Dto,然后将Dto转换成领域模型并持久化到数据库中.另一方面,当用户请求 ...
- js中的async await
JavaScript 中的 async/await 是属于比较新的知识,在ES7中被提案在列,然而我们强大的babel粑粑已经对它进行列支持! 如果开发中使用了babel转码,那么就放心大胆的用吧. ...
- docker--从仓库下载镜像到推送自己的项目到仓库步骤详解
怎样从仓库下载的镜像,变成容器,并在容器中制作项目,再将容器变成镜像,然后将镜像推送到仓库? 一:从官网下载镜像 官方的https://hub.docker.com/提供了数十万个镜像提供大家下载 以 ...
- Day24-Ajax操作、图片验证码、KindEditor使用-转
参考源:http://blog.csdn.net/fgf00/article/details/54917439 三.Ajax操作 ajax操作基于浏览器的xmlHttpRequest对象,IE低版本是 ...
- 学习3__STM32--DMA传输模式---
DMA传输模式 记录 2018-01-26 开始小记 > mode1: Peripheral to Memory 说明: 工程实现的云盘链接 > mode2: Memory to Peri ...
- 洛谷 P1309 瑞士轮 解题报告
P1309 瑞士轮 题目背景 在双人对决的竞技性比赛,如乒乓球.羽毛球.国际象棋中,最常见的赛制是淘汰赛和循环赛.前者的特点是比赛场数少,每场都紧张刺激,但偶然性较高.后者的特点是较为公平,偶然性较低 ...
- 消除JQuery Mobile 列表样式右侧箭头
有时候我们看到JQM上面有一些呈现跟我们要的很像如下面这个Listview效果 程序代码如下: view sourceprint? 1.<ul data-role="listvie ...
- insserv: Script <name> is broken: incomplete LSB comment.
insserv: Script <name> is broken: incomplete LSB comment. insserv: missing `Required-Start:' e ...
- xen list_domains stat 解析
XenServer中可以使用list_domains命令来查看所有VM以及Dom0的运行状态以及简单的资源消耗,如下: [root@xenserver ~]# list_domains id | uu ...
- github与gitlab与git三个基佬的故事
我们了解了git是以个人为中心,但是人人都得数据交互呀..python程序员每天都忙着进行py交易 交互数据的方式 使用github或者码云等公有代码仓库,托管代码的地方,谁都可以看 公司内部使用gi ...