Lind.DDD.Domain.ISortBehavor~上移与下移

简介:
在进行列表排序时,有个“上移”和“下移”操作,这个一般在内存里完成,然后统一提交到数据库中,对于上移与下移的设计,大叔在LIND.DDD.DOMAIN里有一个ISortBehavor接口,主要是说,如果实体对象支持排序功能,可以实现这个接口,而在扩展库中,将有为本地结果集动态排序(上移和下移)的方法,这个设计类似于ABP项目里的软删除,当然在大叔LIND里也有对删除的逻辑操作。

ISortBehavor内容

class Entity { public int ID{ get; set; } }

interface ISortBehavor { int SortNumber{ get; set; } }
而上移与下移我们使用一个泛型方法来接收参数,这样扩展性更好一些,开发人员只要把需要上下移的集合传到方法里,之后你的集合就可以被排序,当然这里面会进行各个元素的移动操作!

复制代码
  /// <summary>
    /// 算法帮助类
    /// 作者:仓储大叔
    /// </summary>
    public class AlgorithmsHelper
    {
        /// <summary>
        /// 排序,上移和下移
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="list"></param>
        /// <param name="id"></param>
        /// <param name="newSort"></param>
        public static void Sortable_Up_Down<T>(List<T> list, int id, int newSort) where T : class
        {

            var old = list.Find(i => (i as Entity).Id == id);
            if (old == null || (old as ISortBehavor).SortNumber == newSort)
                return;


            if ((old as ISortBehavor).SortNumber > newSort)
            {
                (old as ISortBehavor).SortNumber = newSort;

                foreach (ISortBehavor item in list.FindAll(i => (i as Entity).Id != id && (i as ISortBehavor).SortNumber >= newSort))
                {

                    item.SortNumber += 1;
                }

            }
            else
            {
                (old as ISortBehavor).SortNumber = newSort;


                foreach (ISortBehavor item in list.FindAll(i => (i as Entity).Id != id && (i as ISortBehavor).SortNumber <= newSort))
                {

                    item.SortNumber -= 1;
                }
            }
            list.ForEach(i =>
            {
                Console.WriteLine((i as Entity).Id + "sort:" + (i as ISortBehavor).SortNumber);
            }
            );
        }
    }
复制代码
我们测试一下程序,看一下神奇的结果

复制代码
  class MainClass
    {
        public static void Main (string[] args)
        {
            List<Person> list = new List<Person> ();
            list.Add (new Person {ID=1,Name="zzl",SortNumber=1});
            list.Add (new Person {ID=2,Name="zzl2",SortNumber=2});
            list.Add (new Person {ID=3,Name="zzl3",SortNumber=3});

            Console.WriteLine ("Hello World!");
            Extenstion.Sortable (list, 1, 2);
            Extenstion.Sortable (list, 2, 3);

        }
    }
复制代码
单元测试里的结果如图

感谢各位中秋阅读!
本文转自博客园张占岭(仓储大叔)的博客,原文链接:Lind.DDD.Domain.ISortBehavor~上移与下移,如需转载请自行联系原博主。
目录
相关文章
|
SQL 缓存 Java
殷浩详解DDD系列 第三讲 - Repository模式
# 第三讲 - Repository模式 **写在前面** 这篇文章和上一篇隔了比较久,一方面是工作比较忙,另一方面是在讲Repository之前其实应该先讲Entity(实体)、Aggregate Root(聚合根)、Bounded Context(限界上下文)等概念。但在实际写的过程中,发现单纯讲Entity相关的东西会比较抽象,很难落地。所以本文被推倒重来,从Repository
36165 8
|
3月前
TDesign——Input指定光标插入内容
TDesign——Input指定光标插入内容
45 1
重构——57字段上移(Pull Up Field)
字段上移(Pull Up Field):两个子类拥有相同的字段;将该字段移至超类
1626 0
文件切割合并器&nbsp;7&nbsp;上层界面
文件切割合并器&nbsp;7&nbsp;上层界面
99 0
|
C#
WPF中类似使用tab键功能,可以向上向下定位
原文:WPF中类似使用tab键功能,可以向上向下定位 private void tbYyrs_KeyUp(object sender, KeyEventArgs e) { UIElement element = Keyboard.
854 0