UI与实体的映射

简介:
分享一个2006年的小组件。那会在.NET,比较流行的ORM就是NHiberate和IBatis.NET了。在用到这些ORM框架时,经常需要将界面的输入经过处理后转换成实体,最终通过ORM框架映射到数据库。不知道大家使用最简单的赋值还是使用类似UIMapper的组件。我的方法是自己设计了一个O-O Map的组件,将一个Object的值通过声明的特性转换到另一个Object,同时也支持反向映射。由于窗体也就是一个Object,该组件可以满足普通OO映射之外,还可以满足WinForm和WebForm映射。该组件示例如下:

(1)一个UI表单

(2) 相应的实体类 ,加上了映射特性
public class UserEntity
{
    ……
    [Member]  //表示实体类与窗体类成员Age的值想对应。
    public int Age;
    [Control]  //表示实体类与窗体类控件成员Name的值映射。
    public string Name 
    {
        get { return _name; }
        set { _name = value; }
    }
    [Control("CardNo.Text")]  //表示实体类与窗体类控件成员的Text属性相映射, 注意,可以指定Path格式。
    public string CardNo 
    {
        get { return _cardNo; }
        set { _cardNo = value;    }
    }
    ……
}
public class EmployeeEntity
{
    ……
    [Reference(typeof(UserEntity))]  //引用了UserEntity的映射。
    public UserEntity User
    {
        get { return _user; }
        set { _user = value; }
    }
    [Control]  //控件
    public float PostSalary 
    {
        get { return _postSalary; }
        set { _postSalary = value; }
    }
    ……    
}
(3)在 窗体类 中调用ObjectEngine实现OO映射。窗体就是一个继承Form的类,因此,O-O Mapper即可以支持普通映射,也可以支持UI to Entity映射。
1)实现表单类与实体类映射
private void Map_Click(object sender, System.EventArgs e)
{
    this.o = CZB.ObjectMapper.ObjectEngine.
Map(this,typeof(EmployeeEntity)) as EmployeeEntity;
}
2)实现实体类与表单类的映射
private void InverseMap_Click(object sender, System.EventArgs e)
{
    this.o.User.Name = "c.z.b in";
    this.o.User.Age = 19;
    this.o.CompoInsurance = 0;
    CZB.ObjectMapper.ObjectEngine.InverseMap(this,o);
}

这个小组件功能非常简单也很有限,仅供一些参考。Demo如附件。/Files/baihmpgy/CZB.ObjectMapper.Test.rar




本文转自道法自然博客园博客,原文链接:http://www.cnblogs.com/baihmpgy/archive/2009/09/03/1559939.html,如需转载请自行联系原作者

目录
相关文章
|
前端开发
怎样在swagger-ui中的Example Value 隐藏实体属性
怎样在swagger-ui中的Example Value 隐藏实体属性
怎样在swagger-ui中的Example Value 隐藏实体属性
|
23天前
|
开发框架 前端开发 JavaScript
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发一
本文介绍了方舟开发框架(ArkUI)及其两种开发范式:基于ArkTS的声明式开发范式和类Web开发范式。ArkUI是用于构建HarmonyOS应用界面的UI框架,提供极简UI语法和基础设施。声明式开发范式使用ArkTS语言,以组件、动画和状态管理为核心,适合复杂团队协作;类Web开发范式采用HML、CSS、JavaScript三段式开发,适用于简单界面应用,贴近Web开发者习惯。文中还概述了两者的架构和基础能力,帮助开发者选择合适的范式进行高效开发。
69 15
|
23天前
|
编解码 前端开发 Java
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发三
本文介绍了基于声明式UI范式的图形绘制与动画效果实现方法,涵盖绘制图形、添加动画效果及常见组件说明三部分内容。在绘制图形部分,详细讲解了如何通过Circle组件为食物成分表添加圆形标签,以及使用Path组件结合SVG命令绘制自定义图形(如应用Logo)。动画效果部分则展示了如何利用animateTo实现闪屏动画,包括渐出、放大效果,并设置页面跳转;同时介绍了页面间共享元素转场动画的实现方式。最后,文章列举了声明式开发范式中的各类组件及其功能,帮助开发者快速上手构建复杂交互页面。
66 11
|
23天前
|
存储 开发框架 API
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发二
本文详细介绍了基于声明式UI开发的健康饮食应用的设计与实现过程。内容涵盖从基础环境搭建到复杂功能实现的全流程,包括创建简单视图、构建布局(如Stack、Flex)、数据模型设计、列表与网格布局构建,以及页面跳转和数据传递等核心功能。 本文通过实际案例深入浅出地解析了声明式UI开发的关键技术和最佳实践,为开发者提供了宝贵的参考。
59 14
|
16天前
|
JavaScript 前端开发 UED
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发四
本文介绍了Web组件开发与性能优化的相关内容。在Web组件开发部分,涵盖创建组件、设置样式与属性、添加事件和方法以及场景示例,如动态播放视频。性能提升方面,推荐使用数据懒加载、条件渲染替代显隐控制、Column/Row替代Flex、设置List组件宽高及调整cachedCount减少滑动白块等方法,以优化应用性能与用户体验。
43 1
|
20天前
|
JavaScript 前端开发 开发者
09.HarmonyOS Next数据驱动UI开发:ForEach与动态渲染完全指南(上)
在现代前端开发中,数据驱动UI已成为主流开发范式。HarmonyOS Next的ArkTS语言和声明式UI框架完美支持这一理念,使开发者能够以更高效、更直观的方式构建复杂应用。
48 1
|
4月前
|
前端开发 安全 开发工具
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
278 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
16天前
|
编解码 UED 开发者
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发之常见布局
本文主要介绍了自适应布局与响应式布局的相关内容。自适应布局部分涵盖线性布局、层叠布局、弹性布局和网格布局,详细说明了各布局的特性及使用方法,例如线性布局中的排列、拉伸与缩放,弹性布局的方向、换行与对齐方式等。响应式布局则重点讲解了栅格系统和媒体查询,阐述如何通过栅格组件和媒体查询条件实现不同设备上的适配效果。这些技术帮助开发者灵活应对多尺寸屏幕的设计需求,提升用户体验。
50 0
|
2月前
|
人工智能 物联网 编译器
【01】优雅草星云物联网AI智控系统从0开发鸿蒙端适配完成流程-初始化鸿蒙编译器deveco studio项目结构-UI设计图切片下载-优雅草卓伊凡
【01】优雅草星云物联网AI智控系统从0开发鸿蒙端适配完成流程-初始化鸿蒙编译器deveco studio项目结构-UI设计图切片下载-优雅草卓伊凡
94 11
【01】优雅草星云物联网AI智控系统从0开发鸿蒙端适配完成流程-初始化鸿蒙编译器deveco studio项目结构-UI设计图切片下载-优雅草卓伊凡
|
7月前
|
搜索推荐 Android开发 开发者
探索安卓开发中的自定义视图:打造个性化UI组件
【10月更文挑战第39天】在安卓开发的世界中,自定义视图是实现独特界面设计的关键。本文将引导你理解自定义视图的概念、创建流程,以及如何通过它们增强应用的用户体验。我们将从基础出发,逐步深入,最终让你能够自信地设计和实现专属的UI组件。

热门文章

最新文章