Farseer.net轻量级开源框架 入门篇:分类逻辑层
上一篇:Farseer.net轻量级开源框架 入门篇: 缓存逻辑层
下一篇:Farseer.net轻量级开源框架 入门篇: 添加数据详解
分类逻辑层,主要用在一些需要支持无限递归的树数据。树数据是:必须有一个根节点,根节点有无限个子节点,没有节点限制。比如我们常用的有:(频道、xxx分类)
这里与BaseCacheModel的操作是完全一致。唯一不同的是,BaseCateModel是继承自ModelCateInfo。这个类提供了默认的几个字段:
/// <summary>
/// 分类基类
/// </summary>
public class ModelCateInfo : ModelInfo
{
/// <summary>
/// 所属ID
/// </summary>
[Display(Name = "所属分类")]
public virtual int? ParentID { get; set; } /// <summary>
/// 标题
/// </summary>
[Display(Name = "标题"), StringLength(), Required]
public virtual string Caption { get; set; } /// <summary>
/// 排序
/// </summary>
[Display(Name = "排序")]
public virtual int? Sort { get; set; }
}
首先,我们先创建一个实体。(数据库就不放上来了)
它继承了BaseCateModel基类。
namespace FS.Model.Web
{
/// <summary>
/// 频道
/// </summary>
[DB(Name = "Web_ChlDB")]
public class ChlDB : BaseCateModel<ChlDB> { }
}
看到这里,大家是否觉得奇怪?怎么没有属性呢?因为我们继承了ModelCateInfo,而ModelCateInfo又继承了ModelInfo。所以ID、Caption、Sort、ParentID 都是默认支持的。因此这个类是“空”的属性。
当然。你会说,你的数据库字段的属性名不叫这个啊。别忘了。类的属性与数据库的字段的映射是通过特性来建立的。也就是说,不管你的类属性名称是什么,只要特性申明中,对应好字段名称就可以了。
并且这些父类的属性都是可重写的,因此根据你的项目选择性进行重写即可。
BaseCacheModel有的功能,BaseCateModel都有
BaseCateModel在这个基础下扩展了一系列针对“树”的操作。(扩展方法的命名空间:using FS.Extend)
扩展方法提供了一系列上下级节点的搜索方法。比如查询父级、顶级、下级等等操作。当然里面的方法有很多。具体大家在:FS.Extend.ListExtend 类中查看。
它是在 对象名.Cache() 下的扩展,也就是说是在:List<实体类> 并且 实体类是继承BaseCateModel 的 如图:
/// <summary>
/// Cate扩展工具
/// </summary>
public static partial class ListExtend
{
/// <summary>
/// 获取指定ParentID的ID列表
/// </summary>
/// <param name="isContainsSub">是否获取子节点</param>
/// <param name="ID">上级ID</param>
/// <param name="isAddMySelf">是否添加自己</param>
/// <param name="lstCate">分类列表</param>
public static List<int> GetSubIDList<TInfo>(this List<TInfo> lstCate, int? ID, bool isContainsSub = true, bool isAddMySelf = false) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取指定ParentID的ID列表
/// </summary>
/// <param name="caption">分类标题</param>
/// <param name="isContainsSub">是否获取子节点</param>
/// <param name="isAddMySelf">是否添加自己</param>
/// <param name="lstCate">分类列表</param>
public static List<int> GetSubIDList<TInfo>(this List<TInfo> lstCate, string caption, bool isContainsSub = true, bool isAddMySelf = false) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取指定ParentID的ID列表
/// </summary>
/// <param name="ID">上级ID</param>
/// <param name="isContainsSub">是否获取子节点</param>
/// <param name="isAddMySelf">是否添加自己</param>
/// <param name="lstCate">分类列表</param>
public static List<TInfo> GetSubList<TInfo>(this List<TInfo> lstCate, int? ID, bool isContainsSub = true, bool isAddMySelf = false) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取指定ParentID的ID列表
/// </summary>
/// <param name="caption">分类标题</param>
/// <param name="isContainsSub">是否获取子节点</param>
/// <param name="isAddMySelf">是否添加自己</param>
/// <param name="lstCate">分类列表</param>
public static List<TInfo> GetSubList<TInfo>(this List<TInfo> lstCate, string caption, bool isContainsSub = true, bool isAddMySelf = false) where TInfo : ModelCateInfo, new(); /// <summary>
/// 通过标题,获取分类数据
/// </summary>
/// <param name="caption">分类标题</param>
/// <param name="isNullAdd">true:不存在则自动创建</param>
/// <param name="lstCate">分类列表</param>
public static int GetID<TInfo>(this List<TInfo> lstCate, string caption, bool isNullAdd = false) where TInfo : ModelCateInfo, new(); /// <summary>
/// 通过标题,获取分类数据
/// </summary>
/// <param name="caption">分类标题</param>
/// <param name="isNullAdd">true:不存在则自动创建</param>
/// <param name="lstCate">分类列表</param>
public static TInfo GetInfo<TInfo>(this List<TInfo> lstCate, string caption, bool isNullAdd = false) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取根节点分类数据
/// </summary>
/// <param name="ID">当前分类数据ID</param>
/// <param name="lstCate">分类列表</param>
public static int GetFirstID<TInfo>(this List<TInfo> lstCate, int? ID) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取根节点分类数据
/// </summary>
/// <param name="ID">当前分类数据ID</param>
/// <param name="lstCate">分类列表</param>
public static TInfo GetFirstInfo<TInfo>(this List<TInfo> lstCate, int? ID) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取根节点分类数据
/// </summary>
/// <param name="caption">分类标题</param>
/// <param name="lstCate">分类列表</param>
public static int GetFirstID<TInfo>(this List<TInfo> lstCate, string caption) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取根节点分类数据
/// </summary>
/// <param name="caption">分类标题</param>
/// <param name="lstCate">分类列表</param>
public static TInfo GetFirstInfo<TInfo>(this List<TInfo> lstCate, string caption) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取上一级分类数据
/// </summary>
/// <param name="ID">当前分类数据ID</param>
/// <param name="lstCate">分类列表</param>
public static int GetParentID<TInfo>(this List<TInfo> lstCate, int? ID) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取上一级分类数据
/// </summary>
/// <param name="ID">当前分类数据ID</param>
/// <param name="lstCate">分类列表</param>
public static TInfo GetParentInfo<TInfo>(this List<TInfo> lstCate, int? ID) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取上一级分类数据
/// </summary>
/// <param name="caption">分类标题</param>
/// <param name="lstCate">分类列表</param>
public static int GetParentID<TInfo>(this List<TInfo> lstCate, string caption) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取上一级分类数据
/// </summary>
/// <param name="caption">分类标题</param>
/// <param name="lstCate">分类列表</param>
public static TInfo GetParentInfo<TInfo>(this List<TInfo> lstCate, string caption) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取所有上级分类数据(从第一级往下排序)
/// </summary>
/// <param name="ID">当前分类数据ID</param>
/// <param name="isAddMySelf">是否添加自己</param>
/// <param name="lstCate">分类列表</param>
public static List<int> GetParentIDList<TInfo>(this List<TInfo> lstCate, int? ID, bool isAddMySelf = false) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取所有上级分类数据(从第一级往下排序)
/// </summary>
/// <param name="ID">当前分类数据ID</param>
/// <param name="isAddMySelf">是否添加自己</param>
/// <param name="lstCate">分类列表</param>
public static List<TInfo> GetParentList<TInfo>(this List<TInfo> lstCate, int? ID, bool isAddMySelf = false) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取所有上级分类数据(从第一级往下排序)
/// </summary>
/// <param name="caption">分类标题</param>
/// <param name="isAddMySelf">是否添加自己</param>
/// <param name="lstCate">分类列表</param>
public static List<int> GetParentIDList<TInfo>(this List<TInfo> lstCate, string caption, bool isAddMySelf = false) where TInfo : ModelCateInfo, new(); /// <summary>
/// 获取所有上级分类数据(从第一级往下排序)
/// </summary>
/// <param name="caption">分类标题</param>
/// <param name="isAddMySelf">是否添加自己</param>
/// <param name="lstCate">分类列表</param>
public static List<TInfo> GetParentList<TInfo>(this List<TInfo> lstCate, string caption, bool isAddMySelf = false) where TInfo : ModelCateInfo, new(); /// <summary>
/// 绑定到DropDownList
/// </summary>
/// <param name="ddl">要绑定的ddl控件</param>
/// <param name="selectedValue">默认选则值</param>
/// <param name="parentID">所属上级节点</param>
/// <param name="isUsePrefix">是否需要加上前缀</param>
/// <param name="lstCate">分类列表</param>
public static void Bind<TInfo>(this List<TInfo> lstCate, DropDownList ddl, int selectedValue, int parentID, bool isUsePrefix = true) where TInfo : ModelCateInfo, new(); /// <summary>
/// 绑定到DropDownList
/// </summary>
/// <param name="ddl">要绑定的ddl控件</param>
/// <param name="selectedValue">默认选则值</param>
/// <param name="where">筛选条件</param>
/// <param name="isContainsSub">筛选条件是否包含子节点</param>
/// <param name="isUsePrefix">是否需要加上前缀</param>
/// <param name="lstCate">分类列表</param>
public static void Bind<TInfo>(this List<TInfo> lstCate, DropDownList ddl, int selectedValue = , Func<TInfo, bool> where = null, bool isContainsSub = false, bool isUsePrefix = true) where TInfo : ModelCateInfo, new(); /// <summary>
/// 递归绑定
/// </summary>
private static void Bind<TInfo>(this List<TInfo> lstCate, DropDownList ddl, int parentID, int tagNum, Func<TInfo, bool> where, bool isContainsSub, bool isUsePrefix) where TInfo : ModelCateInfo, new();
}
这篇基本上都介绍了BaseCateModel的使用。
相对于BaseCacheModel,增加了额外对“树”数据结构的操作。
上一篇:Farseer.net轻量级开源框架 入门篇: 缓存逻辑层
下一篇:Farseer.net轻量级开源框架 入门篇: 添加数据详解
QQ群:116228666 (Farseer.net开源框架交流) 请注明:Farseer.Net
Farseer.Net是一款ORM框架 + 常用工具 + 扩展集合。
Farseer 意为:先知、预言家 通常在某些场合时,提供计谋、策略。也希望该框架能给大家提供最大化的便捷。
ORM:其英文全称是:Object(对象) Relational(关系) Mapping(映射)
Farseer.Net的目标是:快速上手、快速开发、简单方便。
new User { ID = , Name = "张三" }.Insert()
Farseer.net轻量级开源框架 入门篇:分类逻辑层的更多相关文章
- Farseer.net轻量级开源框架 入门篇:逻辑层的选择
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 入门篇:增.删.改.查操作演示 下一篇:Farseer.net轻量级开源框架 入门 ...
- Farseer.net轻量级开源框架 入门篇:添加数据详解
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 分类逻辑层 下一篇:Farseer.net轻量级开源框架 入门篇: 修改数据详解 ...
- Farseer.net轻量级开源框架 入门篇:使用前说明
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 框架性能测试 下一篇:Farseer.net轻量级开源框架 入门篇: 增.删.改. ...
- Farseer.net轻量级开源框架 入门篇:修改数据详解
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 添加数据详解 下一篇:Farseer.net轻量级开源框架 入门篇: 删除数据详解 ...
- Farseer.net轻量级开源框架 入门篇:删除数据详解
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 修改数据详解 下一篇:Farseer.net轻量级开源框架 入门篇: 查询数据详解 ...
- Farseer.net轻量级开源框架 入门篇:查询数据详解
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 删除数据详解 下一篇:Farseer.net轻量级开源框架 中级篇: Where条 ...
- Farseer.net轻量级开源框架 入门篇:Where条件的终极使用
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 查询数据详解 下一篇:Farseer.net轻量级开源框架 中级篇: 事务的使用 ...
- Farseer.net轻量级开源框架 中级篇:事务的使用
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: Where条件的终极使用 下一篇:Farseer.net轻量级开源框架 中级篇: ...
- Farseer.net轻量级开源框架 中级篇:动态数据库访问
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 自定义配置文件 下一篇:Farseer.net轻量级开源框架 中级篇: 数据库切换 ...
随机推荐
- C# 插件热插拔 .NET:何时应该 “包装异常”? log4.net 自定义日志文件名称
C# 插件热插拔 所谓热插拔就是插件可以 在主程序不重新启动的情况直接更新插件, 网上有很多方案: https://www.cnblogs.com/happyframework/p/3405811 ...
- Python爬虫开发【第1篇】【正则表达式】
非结构化数据:HTML(正则表达式.XPath.CSS选择器) 结构化数据:JSON文件(JSON Path.转化为Python类型进行操作) XML文件(转化成Python类型.XPath.CSS选 ...
- 满足qps 同时兼顾 数据生产速率
满足qps 同时兼顾 数据生产速率
- 协议解析Bug分析
协议解析Bug分析 源自邮件协议RPC(远程过程调用)处理的Request请求数据包的bug. 一.Bug描写叙述 腾讯收购的Foxmailclient能够作为outlookclient ...
- Silverlight调用一般性处理程序模拟Silverlight调用WCF效果(2)
[置顶] Silverlight调用一般性处理程序模拟Silverlight调用WCF效果(2) 分类: 技术2012-03-31 12:51 548人阅读 评论(0) 收藏 举报 silverlig ...
- [Codeforces 482A] Diverse Permutation
[题目链接] https://codeforces.com/contest/482/problem/A [算法] 首先构造一个(k + 1)个数的序列 , 满足它们的差为1-k 对于i > k ...
- ZOJ1450 Minimal Circle 最小圆覆盖
ZOJ1450 给定N个点(N<=100)求最小的圆把这些点全部覆盖 考虑对于三角形,可以唯一的找到外接圆,而多边形又可以分解为三角形,所以对于多边形也可以找到唯一的最小覆盖圆. #includ ...
- MSD3458开发资料
MSD3458HB是mstar最新推出的普通4K数字电视解决方案,不带操作系统,是一个低成本的4K方案,156脚的LQFP普通封装,开发难度低,支持HDMI2.0输入,支持4K输出.1. Suppor ...
- shell判断文件,目录是否存在或者具有权限 (转载)
转自:http://cqfish.blog.51cto.com/622299/187188 文章来源:http://hi.baidu.com/haigang/blog/item/e5f582262d6 ...
- 如何过滤 adb logcat 输出(转载)
转自:http://www.cnblogs.com/imouto/archive/2012/12/11/filtering-adb-logcat-output.html 简介: 本文介绍如何在 she ...