- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设我有一个巨大的输入表单,它当然代表类。我需要将此输入加载到类的实例中。这个输入显然包含(一些非常复杂的验证)检查,显然逻辑层已经包含那些输入验证。问题是我在用 gui 做什么。
我是否应该以一种非常丑陋的方式在 GUI 中重写所有这些验证?
或者我应该在逻辑层中编写一些静态方法,在 gui 和逻辑层中使用这些方法,但仍然创建 self 验证的重复(首先 gui 验证自身,然后逻辑验证什么发送给它)
或者我应该假设 gui 没问题,用 try block 包围使用逻辑层的相关代码,然后,如果抛出异常,通知用户某些事情不对(不给他机会)知道它是什么)
或者我应该公开异常,以这种方式向他公开他可能不理解的参数、类和命名空间名称。
或者我应该为每个错误创建一个特殊的异常类,这样就可以准确地告知用户问题是什么,但可能会产生数百个可能的异常
或者我应该将其分离为一般异常,其中每个人都包含枚举描述错误的确切内容,然后捕获这些异常,并通过检查枚举告知用户究竟是什么问题,但通过不必要的捕获使应用程序变得更重总是有异常。
或者我应该(有人向我提供了这个,这不是我的主意,不要对我大喊大叫 :D)来验证逻辑层中的输入,并且只在 gui 中检查它(似乎是我绝对可怕的解决方案 :D)
还有更重要的问题 - 我应该在哪里学习这些东西?通常我的直觉很好,但我不想不必要地发明轮子..(我很确定已经有关于你每天轰炸的这些基本事情的约定)。
非常感谢!
最佳答案
当然,您应该验证用户输入。如果输入和验证逻辑像你说的那样复杂,那么在 GUI 中验证输入就更重要了,这种方式让用户清楚地知道预期值是什么,如果有任何错误, 它们是什么。如果您能建议如何修复这些错误,可加分!
它确实无法帮助用户查看异常和异常详细信息——因此请尽量避免这种情况。
此外,由于您在 GUI 中处理输入验证,错误的输入是一种预料之中的情况,并不是真正的异常,因此使用 Exceptions 不一定是个好主意。最好使用一个简单的 IsValid()
方法来检查某些内容是否有效。我始终遵循“异常(exception)情况适用于特殊情况”的规则。
因此,如果您接受在 GUI 中进行验证是一件好事,那么下一个问题是:怎么做?
你说你已经有很多验证,但听起来你的验证逻辑并不单独可用。我一直认为有用的一种做法是将验证代码与其他业务逻辑分开。这允许您在适当的地方重新使用验证逻辑,在这种情况下,将允许您在业务对象和 GUI 之间共享相同的验证逻辑。显然,有许多设计方法和框架可以做到这一点,但基本原则是“关注点分离”——保持验证逻辑独立,并使其可供使用。当您说“在逻辑层中编写一些静态方法,在图形用户界面和逻辑层中使用这些方法”时,您似乎在沿着相同的思路思考,这是一种被证明有效的方法。
只是为了清楚起见——我并不是建议您将验证逻辑放在 GUI 本身中。相反,让验证逻辑可供 GUI 使用。唯一应该在 GUI 中的验证部分是从用户那里获取输入(提交验证)的部分和显示验证结果的部分(向用户)。
编辑:
我不想听上去像是在为某种特定的设计哲学做托儿,但最近我一直在使用领域驱动设计原则做更多的工作。我发现它工作得很好,它解决了您提出的许多问题。关于 SO 的一些问题提供了有关它是什么以及某些资源在哪里的更多详细信息:
https://stackoverflow.com/questions/1353742/domain-driven-design-ddd-readings
What is domain driven design?
此外,请阅读此处:http://www.lostechies.com/blogs/jimmy_bogard/archive/2009/02/15/validation-in-a-ddd-world.aspx
编辑 2:
还有一个有用的(和相关的)阅读:Business Objects, Validation And Exceptions
关于c# - 关于 GUI 与逻辑类集成方式的一个非常基本的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1581468/
我有一个无 GUI 的服务器(没有任何桌面环境或 Ubuntu 服务器的新鲜 Debian,没有 X 服务器,先验)。 我考虑安装 docker 并拉取一个基于官方 Ubuntu 的容器,并在其上添加
我正在构建一个带有临时用户名系统的简单聊天服务器。当屏幕弹出时,首先会出现一个简单的屏幕,询问您的用户名。你可以放入任何你想要的东西,这纯粹是暂时的(我也在尝试)。代码告诉程序继续,将用户名保存到代码
我想将来自其他类的图像显示到 QLabel 中,但要通知 GUI 有一个新的框架可用。我需要从非 GUI 类和非 GUI 线程发出信号。 有什么办法吗? 最佳答案 signal 可以从任何继承QObj
我正在用 Java 编写一个图形用户界面,它有一些按钮,其中一个按钮是选项。我想要它,所以当您单击选项时,它会将 gui 更改为我的选项 gui,而不是在另一个窗口中打开它。 我该怎么做? 最佳答案
标题说明了一切...我和我的 friend 正在这样做,我们不知道为什么 Ball.java 实际上没有在 gamePanel 中制作球,然后制作 GUI。顺便说一句,这是 8 球台球。这是代码: 驱
我正在使用 GUI 构建器,我想知道是否有一种简单的方法可以通过当前主窗口打开寄存器窗口(引用下面的页面)。我正在尝试通过菜单栏来执行此操作。 我一整天都在尝试,因为 GUI Builder 生成了一
我有一个程序使用了许多隐藏的 GUI 组件。例如,所有菜单项和打印机对话框/组件(仅占用至少 50 毫秒)。总的来说,我猜整个程序启动的大约 300 毫秒(或 40%)要归功于所有隐藏的东西。 我想做
我对 GUI 构建比较陌生。 我想制作一个带有按钮(我已经有了)的 GUI,用户可以按下该按钮并选择一个图像,然后动态地将该图像加载到面板中的 GUI 中。我希望每次用户浏览图像时图像都动态变化。 到
我有两年使用 Java 和 Visual Studio 进行企业应用程序编程的经验,而且我是 Python 和 wxPython 的新手。所以我的问题是:wxPython 能否为我提供足够丰富的 GU
这是我启动 mkvtoolnix-gui 时遇到的错误: mkvtoolnix-gui: symbol lookup error: mkvtoolnix-gui: undefined symbol:
我在初始屏幕上有一些最近使用的存储库,我想删除它们,因为我不再使用它们了。如何删除它们? 操作系统 = Windows 7 我查看了注册表并搜索了 git 目录,但找不到最近使用列表的存储位置。 最佳
我正在尝试在 matlab、GUI 中用户输入点作为输入和它们之间的连接。 我有 5 个 matlab 文件 - screen1.m、screen2.m、screen3.m、screen4.m、glo
我用java制作了一个客户端/服务器程序,我已经按照我想要的方式使用cmd完美地工作了,现在我正在尝试将代码的客户端转换为GUI,但是我在打印时遇到问题客户端消息并从文本字段和服务器消息读取客户端输入
我正在制作一种 CRUD 应用程序(Java GUI,MYSQL)我应该: 将数据从数据库加载到List(例如),然后将List加载到GUI 将数据从数据库加载到对象(具有 SQL 表等属性)和对象到
我正在开发一个有 5 个图形用户界面窗口的 Java 应用程序,其中一个是问候窗口或主窗口,我已经完成了所有逻辑部分的工作,我已经完成了 99.99%,唯一剩下的就是我如何以这种方式编码,当我点击一个
我目前正在开发 GUI。 我选择将我的 GUI 基于 bluej 项目 - Scribble。 当您创建 ScribbleGUI 对象时,DrawDemo 类会创建一个同时自动打开的 Canvas 。
在这里阅读了很多关于多进程、管道等的内容后,我还没有找到答案,但如果它已经存在,我深表歉意。 我有一个外围硬件,我正在尝试为其创建一个 GUI。我想让 GUI 使用来自外围设备的数据不断更新,同时仍保
我想做的是将 GUI 从一个单独文件中的类链接到另一个类。我的第一个类是一个主菜单,它将显示一些链接到另一个窗口的按钮。第二个类显示不同的窗口,但我现在遇到的问题是我不知道如何链接第一个类中的按钮来调
我的 GUI 代码中有一个奇怪的行为。如果用户在短时间内产生大量事件,则可能会发生正在运行的事件处理程序方法被另一个事件处理程序方法中断。由于一切都在同一个线程(GUI 线程)中运行,所以一切都应该按
这是一个涉及风格的问题。我正在寻找可以帮助我解决常见 GUI 设计问题 的想法。该应用程序是在 Winforms 中完成的,宁愿使用 WPF,该应用程序已经完成,但我是一个完美主义者,在与其他人合作时
我是一名优秀的程序员,十分优秀!