开发Winform程序的时候,我们往往需要根据需要做一些自定义的控件模块,这样可以给系统模块重复利用,或者实现更好的效果等功能。但在使用的时候,我们又往往设计时刻发现一些莫名其妙的错误,那么我们该如何进行控件的设计时刻的开发调试呢,如何解决碰到设计时刻出现的错误呢?本文主要介绍我自己在这方面积累的一些经验和处理方法,期望对大家有帮助。
DevExpress Universal Subscription官方最新版免费下载试用,历史版本下载,在线文档和帮助文件下载-慧都网
例如我的通用附件模块里面,有一个自定义控件,需要提供给外部使用的,如下所示。
这里外部使用的模块,是工作流里面的一个模块,也是一个自定义控件,我想把它作为一个流程信息的展示控件。
因此就想把这个附件管理的自定义控件拖动到另外一个自定义控件流程信息展示控件里面,设计的流程信息管理的界面如下所示,这个时候,使用这个附近控件是没有问题的,正常拖动到另外一个控件里面。
编译整个项目,左边的VS工具箱会出现一个ApplyControl的自定义控件,但是当我拖动该控件到新的窗体界面里面的时候,错误就出现了。
这个问题可能是因为调用了访问数据库的操作,但是更加详细的位置我们看不太清楚(数据给截断显示了)。
为了更好跟踪到错误的发生的地方,我们可以用VS自带的调试操作来进行跟踪。
首先我们在项目的【属性】-》【调试】里面设置启动操作为指定的VS,选择“启动外部程序”为对应版本的VS的IDE程序,如下所示。
启动调试后,打开对应的这个项目,然后再次模拟从工具箱里面拖动控件的效果,这样VS IDE就能定位到具体的位置了。
我们发现VS定位到一个绑定数据的数据库访问操作里面去,但是我开始一直不明白,这个BindData的操作,其实已经是通过指定了设计时刻不进行的了(!this.DesignMode),不知道为什么还继续。
public void BindData()
{
ClearData();
if (!this.DesignMode)
{
List<FileUploadInfo> fileList=new List<FileUploadInfo>();
if (!string.IsNullOrEmpty(this.AttachmentGUID))
{
fileList=BLLFactory<FileUpload>.Instance.GetByAttachGUID(this.AttachmentGUID, this.pager1.PagerInfo);
}
else
{
fileList=BLLFactory<FileUpload>.Instance.GetAllByUser(this.UserId, this.AttachmentDirectory, this.pager1.PagerInfo);
}
..........................
调试到这个DesignMode的时候,它的值竟然是false,那么肯定就会去从数据库获取了,而设计时候去找数据,这个时候就出错了。至于为什么会是DesignMode为false,开始有点搞不太清楚,不是说好设计时刻为True的吗?
通过搜索,发现有位仁兄总结的比较精辟,这里就借用一下。
也就是说一个控件只有在它自己被拖拽到设计器的时候,其 DesignMode 才是真,如果它被包含在其他控件中被加入到设计器,那么那个控件才是在设计模式,而它不是!换句话说,DesignMode 并不能反映当前环境是否是运行时,它只能告诉你,这个控件当前是不是直接被设计器操作(嵌套的已经不算了) 。”
那解决方法应该如何呢,其实也很简单,就是重写下这个DesignMode的属性为我们期望的值即可,如下所示。
/// <summary>
/// 标题:获取一个值,用以指示 System.ComponentModel.Component 当前是否处于设计模式。
/// 描述:DesignMode 在 Visual Studio 产品中存在 Bug ,使用下面的方式可以解决这个问题。/// </summary>
protected new bool DesignMode
{
get
{
bool returnFlag=false;
#if DEBUG
if (System.ComponentModel.LicenseManager.UsageMode==System.ComponentModel.LicenseUsageMode.Designtime)
{
returnFlag=true;
}
else if (System.Diagnostics.Process.GetCurrentProcess().ProcessName.ToUpper().Equals("DEVENV"))
{
returnFlag=true;
}
#endif
return returnFlag;
}
}
重新编译控件,然后测试拖动,操作正常,再无出错,搞定!
DevExpress
DevExpress Universal 10月正式发布今年第二个重大版本——v21.2,此版本正式官宣支持Visual Studio 2022 & .NET6,同时与微软最新发布的Windows 11完美兼容,全面解决用户各种使用场景问题。 与时俱进,从未止步!
本文转载自:博客园 - 伍华聪
无论大公司还是小公司,我们开发前端工程时候,项目工程又很多类似的功能或者页面,开发经常是加班加点搬砖去做一些无成长反复操作的工作,看键盘上 Ctrl 键已经被磨掉了漆,C 和 V 也马上磨白了,那对于开发如何把这些重复的工作用机器去解决?在前端资源紧缺的情况下,是否可直接有工具直接就可以搭建出我想要的前端页面?于是业界的页面可视化搭建工具就出现了,本文会介绍目前最流行的页面可视化搭建工具,也会提供一些业界开源的可视化搭建项目供大家参考(Copy)。
编程开发页面:动态逻辑页面分解为 HTML Tree, Data 和 Dynamic Logic. 前端开发工程师开发前端页面的过程, 本质上是用编程工具(IDE)对页面的 HTML Tree, Data 和 Dynamic Logic 进行增删和修改.
页面可视化搭建:是用可视化交互的方式对页面的 HTML Tree, Data 和 Dynamic Logic 进行增删和修改, 从而实现页面的生成. 页面可视化搭建工具是实现页面可视化编辑的软件工具
目的:任何工具的存在都是更高效地解决问题. 页面可视化搭建工具, 用于解决页面生成的效率问题. 可能前端工程师会觉得最有效率的页面生成方式是打代码, 但有搭建页面需求的不只是前端工程师. 而可视化页面搭建工具, 恰恰是面向"就缺一个前端工程师"的人员, 用于提升他们生成页面的效率.
差异点 | 编程开发页面 | 可视化搭建页面 |
技能要求 | 需要编程基础 | 可以没有编程基础 |
操作方式 | 在代码编辑器中编写代码 | 在可视化搭建工具中拖拉/填表/编写代码 |
项目名称 | 项目简介 | 能解决什么 |
百度amis(开源) | 前端低代码框架,通过 JSON 配置就能生成各种后台页面,极大减少开发成本,甚至可以不需要了解前端 | 不需要懂前端就能做出专业且复杂的后台界面,不受前端技术更新的影响,可以完全使用可视化页面编辑器来制作页面 |
政采云-鲁班(未开源) | 鲁班是一个基于业务组件快速生成页面的搭建系统(站点、页面、组件、数据、权限) ,JSON Schema将业务转成数据→将数据转为定义→将定义规范成结构 | 提升用户体验:页面采用静态化方案,渲染及访问速度更快;提高稳定性:采用 Nginx 直接转发的方案,页面路由可用性保障及响应性能更具优势,同时支持更健壮的容灾方案,支持快速发版、回滚。;快速响应业务需求:通过组件化复用,能够快速响应业务需求、提高研发人效;更好的业务赋能:使得产品、运营等同学也能参与页面的搭建,提升业务迭代效率和数据可用性。;更好的系统化能力:基于搭建系统,便于横向和性能检测系统、稳定性保障系统、运维部署系统、线上监控系统进行打通,形成系统级合力、复利。 |
淘宝-imgcook(未开源) | 由设计稿一键智能生成代码Skecher、ps、图片、原型图通过算法UI智能识别表达式转成DSL,再解析DSL为前端页面 | 还原设计稿;Skecher、ps、图片、原型图直接生成代码;精准还原;所见所得生;成代码可维护强;机器智能识别理解;DSL / Plugin可自定义 |
阿里-iceluna、Paas | 配置生成搭建描述协议 - 标准规范 - Schema再生成页面及逻辑、低代码编辑器 - 开发生态 | 改变生产关系,提升生产力(赋能)- 中后台通用搭建产品--所有人;降低研发成本(提效)- 低代码开发平台--开发人员(工程创建、开发、调试、发布全链路);孵化领域产品(搭建生态)- PaaS平台--开发人员(基础设施,基于标准搭建协议生产搭建物料,为各业务场景提供搭建服务的运行和开发环境) |
阿里-云凤蝶(未开源)/pipeline (类似开源) | 像做PPT一样去做web前;页面 Data 编辑 | 支持页面 Data 编辑, 面向运营、产品人员, 编辑自由度为无嵌套的组件.;目前制作运营、活动页面功能上最好的工具.;提供页面搭建的模板, 并支持自定义模板.;配置表单基于 Schema 生成, 配置表单操作功能完善. |
阿里-飞冰(未开源)/vue-layout(类似开源) | Component Tree 编辑;针对中后台开发人员;针对组件化的页面, 主要实现 Component Tree 的可视化编辑. 其核心功能在于页面布局设计: 在 UI 组件列表中选择合适的组件, 通过拖拉的方式将组件嵌入到页面中, 生成带布局和样式的页面. | 支持 Component Tree 编辑, 面向中后台开发人员, 编辑自由度为无嵌套的组件;使用"物料-区块", 非前端开发人员可以快速搭建出可用、符合规范的页面.;页面以源码方式输出.;前端服务化的一种方式. |
淘宝-天马(未开源) | 跨端页面搭建 | 跨终端搭建页面;面向标准数据研发schema.json;对模块的props入参描述;数据标准化;数据驱动展示;编写模块代码(解耦、模块既代码);打包每个模块单独打包;从页面视角seed动态加载;跨终端的缓存方案(phone tm tb缓存副本、对应访问、代码标识);服务端渲染SSR |
淘宝-方舟 | 设计实现toC营销搭建 | 终端秒开;采用前端优化手段实现终端秒开 |
阿里妈妈-淘积木(未开源) | 从基础组件搭建完整的营销页面的方案设计 | |
阿里@维奇 | 文档即代码;文档转换成部分代码 | |
阿里alist /Formily(开源) | Formily 表单方案作为搜索区域的不二之选时,通过对这些方案的整合,可以快速实现标准化的列表场景。;同时AList支持 JSON Schema 协议渲染,可通过数据驱动快速开发。 | 内置Formily作为搜索区域方案,性能及功能强大;支持 Ant Design/Fusion Next 组件体系;支持JSON Schema 数据驱动方案;副作用逻辑独立管理,涵盖各种复杂联动校验逻辑;支持各种复杂布局方案 |
京东-MPM(未开源) | 采用ComData的数据配置方式解析成前端页面,是本系统的核心,7PageData 是??的抽象描述层 | 搭建物料丰富:MPM 现有 30+ 个组件、500+ 个模板,业务能?覆盖商品、导购、营销等多个场景。配置功能强?:三端渲染是 MPM 的强?能?,除此之外,MPM 还?持??配置 BI 排序、?动化埋点、?动化测试、??测速等。系统能?全?:MPM 为??保驾护航,不但配备了流畅的拖拽编辑器、实时预览和??健康诊断能?,还对系统和??做了全??的监控和容灾降级?案。 |
美团魔方(未开源) | 从基础组件搭建完整的营销页面的方案设计 | |
美团乐高(未开源) | 从基础组件搭建完整的营销页面的方案设计 | |
esview(模仿乐高开源) | Drag vue dynamic components to build your page,generate vue code. | esview开源项目, 模仿美团点评的乐高.完整的可视化页面搭建框架, 面向中后台开发人员.页面布局结果看起来比较乱, 自定义组件写法比较诡异; 没有融合业务逻辑, 不支持在框架中写页面的代码逻辑. |
Element UI表单设计及代码生成器(开源) | Element UI表单设计及代码生成器,可将生成的代码直接运行在基于Element的vue项目中;也可导出JSON表单,使用配套的解析器将JSON解析成真实的表单。 | |
Vue-Layout(开源) | 从基础组件搭建完整的营销页面的方案设计 基于UI组件的Vue可视化布局、生成.vue代码的工具。https://github.com/JakHuang/form-generator | 支持 Component Tree 编辑, 面向中后台开发人员, 编辑自由度为可嵌套的组件.页面的拖拉生成, 实现得很完整.用于页面设计, 所以偏向页面元素的样式控制.技术文章对可视化搭建工具数据流有深刻理解: 可视化在线编辑器架构设计. |
gaea-editor(开源) | 开源项目.支持 Component Tree 编辑, 面向中后台开发人员, 编辑自由度为可嵌套的组件.页面的拖拉生成, 实现得很完整.用于页面设计, 所以偏向页面元素的样式控制.技术文章对可视化搭建工具数据流有深刻理解: 可视化在线编辑器架构设计. | |
pipeline(开源) | 运营/产品活动页面 | |
gengen(开源) | 根据接口生成页面,减少重复性工作 | |
H5.cn | https://www.ih5.cn/not-logged-in | |
Brick Design(开源) | 拖拽区块内可直接编辑,生成前端页面并预览 | |
百度H5(未开源) | https://h5.bce.baidu.com/docs/intro营销活动页面搭建 | |
其他(开源) | 1.website-builder 2.site-builder 3.VvvebJs 4.grapesjs 5.Maha 6.有赞微页面 7.X-Page-Editor-Vue |
基于对以上页面可视化搭建工具调研,业界有很多看法,拿出两个比较有代表性的文章供大家参考:
以上调研了那么多业界比较牛的前端可视化的框架工程,大致思路是类似的,百家争鸣,尽管阿里的飞冰云凤蝶很完善了但还是存在以下两点问题:
这两个问题存在就会导致我们生产设计出来的东西需要low code,如果是low code开发人员不愿意用,因为生成的代码不易维护且臃肿;如果给非开发人员用,他们又不会写代码,一点代码都不想写,所以他们也不愿意用;
而我们站在巨人的肩膀上,能否把上面两个问题解决呢?目前我没有什么好的办法,但是我们可以先去把他们实现思路研究明白,才有可能去处上面的最难以解决的问题。
相通之处 | 不同之处 | 可借鉴之处 | 应该避免问题 | 开源代码可借鉴 |
1、DSL方式解析拖拽或者配置好的伪代码生成所需前端页面,大部分使用的是JSON Schema形式;2、从配置要生成页面整个处理步骤类似 | 1、处理方法不同;2、定义的DSL字段不同;3、优化程度不同;4、针对的业务场景不同 | 1、从配置到生成DSL方式的伪代码再到如何解析最后生成前端页面的整体架构设计及思想可借鉴;2、如何定时DSL字段schema的模式,如何处理转移编译打包上线及优化 | 1、定位准用户群;2、后期维护问题 | 1、百度amis(开源可借鉴 react)2、vue-layout(类似飞冰开源 vue) 3、pipeline (类似飞冰开源 react)4、美团乐高(可参考 vue)5、美团魔方(可参考react 6、esview(模仿乐高开源) 7、Brick Design(开源可借鉴 react) 8、gen(开源)9、gaea-editor(开源) 10、阿里alist/Formily(开源)11、鲁班H5(开源) |
JSON Schem数据结构特点:
demo1:
{
"type": "object",
"properties": {
"$attr": {
"type": "object",
"properties": {
"hidden": {
"type": "boolean"
}
}
},
"$theme": {
"type": "object",
"properties": {
"themeColor": {
"type": "string"
}
}
},
"items": {
"type": "array",
"items": {
"type": "object",
"properties": {
“itemId”: {
"type": "string"
}
}
}
}
}
}
复制代码
demo2:
*请认真填写需求信息,我们会在24小时内与您取得联系。