『练手』005 Laura.SqlForever历史遗留 的 架构思想缺陷
我们 比较一下 Laura.WinFramework 和 Laura.XtraFramework 的差异:
Laura.WinFramework:
导航菜单:
>导航栏+右键菜单(MenuStripItemBase)
>工具栏(ToolStripItemBase)
子窗体(ChildForm)
>系统子窗体(MainChildForm)
>文档子窗体(DocumentForm)
插件覆盖设计
>同名键值 插件,相互覆盖;
>对不完善 插件事件,后期 改写覆盖;
Laura.XtraFramework:
导航菜单:
>导航栏+工具栏(BarItemInfoBase)
>右键菜单(MenuStripItemBase)
>遗留工具栏(ToolStripItemBase)
子窗体(ChildForm)
>取消了 系统子窗体(没时间研究 DevExpress 的 系统子窗体 的 扩展方式)
>文档子窗体(ChildForm)
插件覆盖设计
>同名键值 插件,相互覆盖;
>对不完善 插件事件,后期 改写覆盖;
工具栏,导航栏,右键菜单 遗留的设计问题
遗留下来的 工具栏 存在设计问题:
>新版工具栏 以特性中 TriggerType 的 设计思想 判定 所服务窗体;
>遗留工具栏 以 Must,CanUse 函数 的 设计思想 判断 所服务窗体;
>新版 设计思想 可能 更好一些;
遗留下来的 右键菜单 存在设计问题:
>DevExpress控件库 好像 不支持 右键菜单 —— 于是 右键菜单 沿用了 之前;
>右键菜单 也是 Must,CanUse 函数 的 设计思想 —— 可能 设计思想 也不是 很好;
工具栏最大的设计BUG:
>前后 历次版本,工具栏 以 “主工具栏”,“副工具栏” 两个为主;
>所有 子窗体 全部使用 “副工具栏”;
>而 之前的 Must 函数,即为:扩展的存在,只认逻辑(逻辑不严,则 扩展可能就 依附了错误窗体);
>而 现行 TriggerType 思想,即为:扩展的存在,只认类型,不认逻辑;
>现在 思想的优势 就是 扩展的目标明确:但是 所有子窗体 公用一个 工具栏 —— 这就是一个设计问题;
>最好的设计,或许应该是:
>每个扩展通过TriggerType 针对 特定类型子窗体;
>每个子窗体 针对 各自工具栏;
子窗体 遗留的设计问题
取消了系统子窗体
>对这个 概念 的取消,是最错误的决定;
>系统子窗体 这个 概念,拿 VS2010为例,指的是:“解决方案资源管理器”,“属性”,“工具箱”,“服务器资源管理器” 这些窗体。
>作者 确实 没有时间了,作者 无法抽出 时间 完善设计思想了:
>一个月时间 既要学 Android,WebGL;
>还要 看 经济,婚姻,大政 方面的几本书籍;
>还有一些 记忆经历 没有 画成图画;
>总有面试官说:智商高的人往往不懂欣赏生活美好。
>总有面试官说:智商高的人情商低。
>看吧,为了面试,各种准备工作,把自己折磨得 头都大了。
>最重要的是 除了已经总结 的 爱情,工作,经历,家族 等几十篇文章外,最后的一篇总结文章 还没有写。
最后
>Laura.WinFramework 和 Laura.XtraFramework 设计思想 虽然存在 BUG,但是 功能和插件 的扩展 却已经非常稳定 和 成熟。
>Laura.SqlForever 本身 只不过是 作者 的一个 业余练手项目,作者对其 没有任何 后期战略期望。
>Laura.SqlForever 的存在,只是为了证明 另外一个半成品项目 的存在。
Ps. Laura.SqlForever 和 Laura.XtraFramework 一并开源;
任何 个人或企业 都可以 无偿 剪切、复制、删除、修改 获得的 Laura.SqlForever 的 源码副本;
当然,Laura.DbSchema 这个程序集中,作者 整理了 不少 数据库相关的 函数;
如果 整个 Laura.SqlForever 源码 能给 您带来些许的参考价值,烦请 各位在下载 源码之余,点个 “赞”咯!
舒小龙
2014-02-13 01:10
『练手』005 Laura.SqlForever历史遗留 的 架构思想缺陷的更多相关文章
- 『练手』004 Laura.SqlForever如何扩展 导航栏 工具栏 右键菜单 插件
004 Laura.SqlForever如何扩展 导航栏 工具栏 右键菜单 插件 导航栏 插件扩展 比如下图的 窗口 > 关闭所有文档 这个导航栏: 在 任何程序集,任何命名空间,任 ...
- 『练手』001 Laura.SqlForever架构基础(Laura.XtraFramework 的变迁)
001 Laura.SqlForever架构的基础(Laura.XtraFramework 的变迁之路) Laura.XtraFramework 到底是 做什么的? Laura.XtraFramewo ...
- 『练手』003 Laura.SqlForever如何扩展 兼容更多数据库引擎
003 Laura.SqlForever如何扩展 兼容更多数据库引擎 数据库引擎插件 在 界面上的体现 导航窗体 的 工具栏 中的 引擎下拉列表 导航窗体 的 树形控件 中的 引擎主节 ...
- 『练手』手写一个独立Json算法 JsonHelper
背景: > 一直使用 Newtonsoft.Json.dll 也算挺稳定的. > 但这个框架也挺闹心的: > 1.影响编译失败:https://www.cnblogs.com/zih ...
- 『练手』通过注册表 获取 VS 和 SQLServer 文件路径
获取任意 VS 和 SQLServer 的 磁盘安装目录. 背景需求:如果磁盘电脑安装了 VS 或者 SQLServer 则 认定这台计算机 的使用者 是一名 软件研发人员,则让程序 以最高权限运行. ...
- 『集群』005 Slithice 基于 集群 的 自动容错
Slithice 基于 集群 的 自动容错 Slithice容错概述: Slithice 支持 非集群 的 独立服务端: 支持 基于 中央服务器 的 集群服务端: 支持 基于 自定义配置 的 集群服务 ...
- 『开源』仿SQLServer山寨一个 跨数据库客户端
002 Laura.SqlForever项目简单介绍 相关文章 <『练手』001 Laura.SqlForever架构基础(Laura.XtraFramework 的变迁)> <『练 ...
- [日推荐] 『闲聊助手』人工智能小程序,仅此一款!-极乐商店store.dreawer.com
肾phone的siri有用过吗?小编无聊时就撩一下她!但有个问题就是要是没有肾phone在身边怎么撩???现在有伙伴@wx_Volcano_Li76 开发一款小程序,可以等同于siri,想什么时候撩就 ...
- 关于『进击的Markdown』:第三弹
关于『进击的Markdown』:第三弹 建议缩放90%食用 我与神明画押,赌这弹markdown又双叒叕拖稿了 %%%Markdown!我的CSDN编辑器崩了呜呜呜 各路英雄豪杰,大家好! 我们要开 ...
随机推荐
- Maven常识
maven下面通常有四个文件夹: src/main/java -- 用来存放业务代码 src/test/java -- 用来存放测试代码 另有两个名为resource的文件夹,通常用来放置前两个文件夹 ...
- Dubbo中暴露服务的过程解析
dubbo暴露服务有两种情况,一种是设置了延迟暴露(比如delay="5000"),另外一种是没有设置延迟暴露或者延迟设置为-1(delay="-1"): 设置 ...
- Link-Cut Tree指针模板
模板: 以下为弹飞绵羊代码: #define Troy #include "bits/stdc++.h" using namespace std; ; inline int rea ...
- bzoj 3343 教主的魔法 分块
修改直接对整块打标记,两边暴力. 查询需要保证每个整块有序,所以在修改时排序就好啦 #include<cstdio> #include<cstring> #include< ...
- validatebox相关验证
$(document).ready( function(){ $.extend($.fn.validatebox.defaults.rules, { minLength: { validator: f ...
- keras实现简单性别识别(二分类问题)
keras实现简单性别识别(二分类问题) 第一步:准备好需要的库 tensorflow 1.4.0 h5py 2.7.0 hdf5 1.8.15.1 Keras 2.0.8 opencv-p ...
- 残差网络(Residual Networks, ResNets)
1. 什么是残差(residual)? “残差在数理统计中是指实际观察值与估计值(拟合值)之间的差.”“如果回归模型正确的话, 我们可以将残差看作误差的观测值.” 更准确地,假设我们想要找一个 $x$ ...
- Docker 快速开始
1. 概念 对于开发人员和系统管理员来说,Docker是一个使用容器开发.部署和运行应用程序的平台.使用Linux容器部署应用程序称为容器化.容器并不新鲜,但是将它们用于轻松部署应用程序却很新鲜. ...
- 一个Java程序猿眼中的前后端分离以及Vue.js入门
松哥的书里边,其实有涉及到 Vue,但是并没有详细说过,原因很简单,Vue 的资料都是中文的,把 Vue.js 官网的资料从头到尾浏览一遍该懂的基本就懂了,个人感觉这个是最好的 Vue.js 学习资料 ...
- vscode restclient 插件
使用步骤: 1.vscode 安装restclient 扩展 2.创建 .http 或 .rest 文件 ,编写相应内容 同一个文件内 可以通过 ### 分割多个请求 可以通过 @hostname ...