集合属性的持久化——用集合编辑器编辑集合属性并自动生成代码

本文介绍了在控件开发中遇到的集合属性持久化问题,当在WinForm窗体上编辑TableLayoutPanel的集合属性FirmControl后,运行时发现未保存添加的项。原因是缺少了[DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]特性,该特性决定属性内容是否序列化。同时,集合属性必须实现IList或CollectionBase。文章还列举了其他设计时属性,如Bindable、Browsable、Category、Description等的相关特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天在进行控件开发的时候,遇到了一个棘手的问题,问题描述如下:

       public class CoreTableLayoutPanel : TableLayoutPanel

    {

        private List<ControlBoxItem> _firmControl=new List<ControlBoxItem>();

        [Browsable(true)]

        [Description("设定不可移动的控件集合")]

        public List<ControlBox> FirmControl// ControlBox为一实体类,此处为显示

        {

            get

            {

                return this._firmControl;

            }

        }

         .

         ..

     }

该控件继承自TableLayoutPanel,根据实际需要,在控件中定义了一个名为FirmControl的集合属性,控件进行编写完成后,被放到一个WinForm窗体上,找到该控件的FirmControl属性,然后对其进行添加项的操作,如下所示:

      

添加完以后,点击确定按钮。本以为添加成功了,然后开始运行程序,程序运行效果和预期的不一样,然后对程序进行跟踪,发现FirmControlCount属性竟然为0,奇怪?究竟是什么原因呢?我再次打开如上图所示的“集合编辑器界面”,看到数据项明明已经添加上,可是为什么Count会为0呢?然后我去看窗体设计器生成的代码,竟然没有找到形如this.coreTableLayoutPanel1.FirmControl.Add(…);的代码,看来虽然在“集合编辑器”中显示已经添加上了,但这其实只是一种假象,我把WinForm工程关掉再重新打开,再次打开集合编辑器,竟然为空了!!!这是什么原因呢?

在网上翻了半天终于找到原因了,对于集合属性(Property),需要为其添加[DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]特性(Attribute),该特性指定属性是否以及如何在代码中序列化,其值为DesignerSerializationVisibility的枚举值。有3种设置方式:

DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)指定序列化程序不应该序列化属性值;

DesignerSerializationVisibility(Design erSerializationVisibility.Visible)指定应该允许序列化程序序列化属性的值;

DesignerSerializationVisibility(DesignerSerializationVisibility.Content)指定序列化程序应该序列化属性的内容,而不是属性本身。此字段为只读,Visible为其默认值。只有指定了改特性后,点击“集合编辑器”的确定按钮后,VS.studio才能生成相应的添加代码(即对属性进行序列化)。

       除此之外,还有一点需要注意的是,集合属性必须为实现IListCollectionBase的类型。

下面是在进行控件设计时,属性常用的的一些特性:

System.Windows.Forms 命名空间中的有

Bindable
这个特性表示属性是否可以绑定一个有效数据源。通常使用布尔值进行设置。例如:Bindable(true)。如果使用值true标记属性,表示该属性可以绑定一个有效数据源,且应引发该属性的属性更改通知。
Browsable
指定属性是否应该在属性浏览器中显示,使用布尔值设置。通常情况下,功用属性和那些希望在属性浏览器中显示的属性被设置为 Browsable(true),只读属性和那些不希望在属性浏览器中见到的属性被设置为 Browsable(false)
Category
指定属性在属性浏览器中进行分组显示的类别。该设计时特性帮助可视化编辑器将属性进行逻辑分组。通常分为:外观(Appearance)、行为(Behavior)、布局(Layout)、数据(Data)、操作(Action)、键盘(Key)和鼠标(Mouse)等。除此之外,还可以自定义分组类别。
Description
指定显示在属性浏览器下方,属性的文字说明。
DesignerSerializationVisibility
指定属性是否以及如何在代码中序列化,其值为DesignerSerializationVisibility的枚举值。存在3种设置方式:DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden)指定序列化程序不应该序列化属性值;DesignerSerializationVisibility(DesignerSerializationVisibility.Visible)指定应该允许序列化程序序列化属性的值;
DesignerSerializationVisibility(DesignerSerializationVisibility.Content)
指定序列化程序应该序列化属性的内容,而不是属性本身。此字段为只读。.Visible为其默认值。
NotifyParentProperty
指示当此特性应用到的属性的值被修改时将通知其父属性。换言之,如果属性的父属性应该在该属性值改改时接到通知,则向该属性应用NotifyParentProperty特性。通常使用布尔值进行设置。

System.Web.UI命名空间的有(Asp.net服务器控件专用)
ParseChildren
使用该特性指示当在页面上以声明方式使用控件时,嵌套在服务器控件标记内的XML元素是应该视为属性还是应视为子控件。通常情况下,包含两种声明方式:①ParseChildren(true)表示将子XML元素作为服务器控件的子控件分析;②ParseChildren(bool childrenasProperty, string defaultProperty),其中childrenasProperty和方式①中的布尔值参数意义相同,defaultProperty定义默认情况下将子控件分析为服务器控件的集合属性。
PersistChildren
该特性指示设计时是否应将服务器控件的子控件作为内部嵌套控件保持。如果该特性为PersistChildren(true),则将服务器控件的子控件作为嵌套服务器控件标记保持。如果为PersistChildren(false),则将该控件的属性作为嵌套元素保持。
PersistenceMode
指定如何将服务器控件属性或事件保持到ASP.NET页面的元数据属性。共存在4种枚举设置方式:①PersistenceMode(PersistenceMode.Attribute),指定属性或事件保持为特性;②PersistenceMode(PersistenceMode.EncodedInnerDefaultProperty),指定属性作为服务器控件的唯一内部文本而属性值是HTML编码的,只能对字符串作这种指定;③PersistenceMode(PersistenceMode.InnerDefaultProperty),指定属性在服务器控件中保持为内部文本,还指示将该属性定义为元素的默认属性,只能指定一个属性为默认属性;④PersistenceMode(PersistenceMode.InnerProperty),指定属性在服务器控件中保持为嵌套标记,这通常用于复杂对象,它们具有自己的持久性属性。
DefaultProperty
指定服务器控件的默认属性,例如[DefaultProperty("MyProperty")]
TypeConverter
指定用做此特性所绑定到的对象的转换器的类型。用于转换的类必须从TypeConverter继承。使用ConverterTypeName属性来获取为该特性所绑定到的对象提供数据转换的类名。

### RuoYi-Plus Vben5 代码生成器使用方法 #### 背景概述 RuoYi-Plus 是基于 Spring Boot 和 Vue 的快速开发平台,支持多种数据库环境[^3]。其前端部分采用了 Vben Admin 框架作为 UI 层实现[^1]。 #### 项目目录结构简介 以下是项目的典型目录结构及其说明: - **ruoyi-common/** 存放通用工具类和公共配置文件。 - **ruoyi-system/** 后台管理系统的主体模块,包含用户、角色、菜单等功能逻辑。 - **ruoyi-generator/** 自动化代码生成功能的核心模块,提供表单设计界面以及模板渲染机制来动态生成 CRUD 接口和服务层代码。 - **ruoyi-ui/** 前端工程所在位置,集成了 Element Plus/Vben Admin 组件库用于构建现代化 Web 应用程序界面[^4]。 --- #### 使用方法详解 ##### 配置数据源 进入 `application.yml` 文件设置目标数据库连接字符串及相关驱动信息: ```yaml spring: datasource: url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8&serverTimezone=UTC username: root password: 123456 ``` ##### 创建实体对象映射关系 通过 MyBatis Generator 自动生成 DAO 层接口与 Mapper XML 映射文件或者手动定义 JPA 注解形式完成持久化操作绑定。 ##### 设计表格字段属性 登录到后台管理系统后切换至【代码生成】选项卡页面,在线编辑待处理的数据模型描述详情保存修改结果。 ##### 执行导出动作 点击对应记录右侧的操作按钮触发下载流程即可获取完整的 Java 类型声明脚本连同 HTML 片段等内容资源包: ```javascript handleExport() { this.download('system/generator/export', { tableName: 'your_table_name' }, `${new Date().getTime()}_template.zip`); } ``` 上述函数片段展示了如何发起一次异步请求向服务器索取压缩后的素材集合实例演示过程。 --- #### 示例代码展示 以下是一个简单的例子用来阐明整个工作流的具体实践方式: 假设我们有一个名为 `employee` 的员工基本信息登记表,则可以按照下面步骤来进行自动化编程任务尝试体验一下吧! ###### 步骤一:初始化基础框架依赖项安装完毕之后启动服务进程监听指定端口号等待客户端访问进来; ###### 步骤二:利用图形化交互面板填写必要参数值比如所属分组名称叫做 "人力资源部" 等等细节要素构成最终版 SQL DDL 定义语句存入元存储区域当中去; ###### 步骤三:最后按下确认键位组合 Ctrl+S 就能够看到预期成果啦——即一份标准符合企业内部编码规范要求的新建 EmployeeController.java 控制单元样板文件呈现在眼前咯! ```java @RestController @RequestMapping("/api/v1/employees") public class EmployeeController { @Autowired private IEmployeeService employeeService; @GetMapping("/{id}") public ResponseEntity<Employee> getEmployeeById(@PathVariable Long id){ Optional<Employee> optional = employeeService.findById(id); return optional.map(ResponseEntity::ok).orElseGet(() -> ResponseEntity.notFound().build()); } ... } ``` --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值