gpt4 book ai didi

asp.net - 如何在 ASP.NET 中构建灵活的 Web 表单

转载 作者:行者123 更新时间:2023-12-04 15:27:15 25 4
gpt4 key购买 nike

我正在使用 asp.net,我需要构建一个应用程序,我们可以在其中轻松创建表单而无需重新创建数据库,最好不要更改创建/读取/更新/删除查询。目标是允许客户创建自己的表单,包括下拉菜单、文本框、复选框,甚至是与另一个简单表单的多对一关系(即拉伸(stretch)它)。用户不必自己创建表单,但我不想在每次请求/修改新表单时添加表、字段、查询、网页等。

2个问题:
1)我如何构建一个灵活的数据库来做到这一点(在 SQL Server 中)?我可以想到两种方法:a) 为每种数据类型(int、varchar(x)、smalldatetime、bit 等)创建一个表。这将很难创建足够的查询。 b) 创建包含大量额外字段和各种数据类型的表单表,以防用户需要 5 个整数或 5 个日期字段。这似乎是最简单的,但可能对空间的使用效率很低。

2) 我如何建立表格?我考虑创建一个 xml 表,其中包含验证、数据类型、要显示的控件等作为列表。然后我会解析 xml 以动态构建表单。可能使用 css 进行布局(这必须是手动的,这没关系)。

有没有更好/最好的方法?有什么东西可以让我得到想法吗?任何帮助深表感谢。

最佳答案

这听起来像是 InfoPath 解决方案的潜在候选者。乍一看,它会做你所要求的大部分/全部。

本文简要概述了创建基于 SQL 数据源的 InfoPath 表单。

http://office.microsoft.com/en-us/infopath-help/design-a-form-template-based-on-a-microsoft-sql-server-database-HP010086639.aspx

我已经构建了一个完全自定义的解决方案,就像您描述的那样,如果我再次这样做,我可能会选择 1) 第三方产品或 2) 更少的功能。您可以将 90% 的时间花在 10% 的功能集上。

编辑:重新阅读您的问题,这里是额外的反馈。

1 - 灵活的数据结构:要记住的几件事是性能和针对数据编写报告的能力。数据结构越通用,就越难实现(同样,从经验来看)。

与性能和报告就绪性稍有不同的是,Microsoft SharePoint 在通用表中使用 XML 片段/文档以获得最大的灵 active 。我无法与 SharePoint 的功能争论,所以这确实完成了工作并大大简化了数据结构。如果正确完成,XML 将表现良好,但大多数人会发现编写针对 XML 的查询更加困难。尽管 XML 是 SQL Server 的“一等公民”,但它的性能可能会或可能不会像优化的表结构一样好。

2 - 表格:我已经使用由 XSLT 转换的 XML 实现了自定义表单。 XML 通常是存储表单结构的好选择; XSLT 本身就是一个怪物,但它很强大。值得一提的是,InfoPath 将其表单结构存储为 XML。

我还使用 .Net 中的自定义控件实现了动态表单。这是一种非常面向对象的方法,但是(取决于 UI 的复杂性)可能需要大量代码。

最后(再次以 SharePoint 为例),Microsoft 在 SharePoint 2007 中实现了极其复杂的 XML 列表/表单定义。复杂性抵消了许多好处。换句话说,如果你走 XML 路线,让你的结构简洁明了,否则你将面临维护的噩梦。

编辑#2:引用下面斯科特的问题,这是一个高级数据结构,它将避免重复数据并且不依赖于大多数表单定义的 XML。

警告:我只是把这个设计放在 SQL Management Studio 中……我只花了 10 分钟;开发一个灵活的表单系统不是一件容易的事,所以这是一个过度简化。它不解决用户输入数据的存储,只是表单的定义。

alt text

表格:

表单 - 顶级表单表,其中包含(如您所料)组成表单的字段集合。

字段 - 可以跨表单重用的通用字段。例如,您不希望 50 个不同的表单有 50 个不同的“姓氏”字段。请注意“DataTypeId”列。您可以在此列中存储您想要的任何类型,例如“数字”、“自由文本”,甚至是指示用户应该从列表中选择的值。

FormField - 允许表单在其定义中包含 0 个字段。您甚至可以扩展此表以指示用户可以根据需要添加尽可能多的此字段。

约束 - 基本上是一个定义约束类型的查找表(可能是最大长度、最大出现次数、必需等)

FormFieldConstraint - 将约束与表单字段的特定实例相关联。此表将特定表单与具有特定约束的特定字段组合在一起。注意元数据列;这可能是 XML 存储约束细节的一个很好的用途。

本质上,我建议构建一个规范化的数据库,其中包含很少或没有空值且没有重复数据。我所描述的结构将使您走上实现该目标的道路。

关于asp.net - 如何在 ASP.NET 中构建灵活的 Web 表单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4432296/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com