c# – 如何使用db查询在ASP.NET MVC 5中创建复杂的EditorTemplate?

c# – 如何使用db查询在ASP.NET MVC 5中创建复杂的EditorTemplate?,第1张

概述我想创建一个更复杂的EditorTemplate来从列表中选择一个客户. 我知道DropDownListFor,但我想向客户展示卡片 图片和一些数据不仅仅是常规选择列表. 我想做什么: 创建一个EditorTemplate供客户选择,例如……在任何POCO类中 public class X{ [Key] int Id {get;set;} [UIHint("CustomerSe 我想创建一个更复杂的EditorTemplate来从列表中选择一个客户.

我知道DropDownListFor,但我想向客户展示卡片
图片和一些数据不仅仅是常规选择列表.

我想做什么:

创建一个EditorTemplate供客户选择,例如……在任何POCO类中

public class X{    [Key] int ID {get;set;}    [UIHint("CustomerSelector")] int Custumer_ID {get;set;}}

并且“CustomerSelector”编辑器模板能够查询所有客户端并将它们显示在一个丰富的列表中.

问题是什么:

>从视图中添加查询逻辑不是一个好主意.这是针对MVC模式的.
>查询每个控制器中的客户列表并将其作为参数传递给EditorTemplate,这不是非常模块化的.

如何创建这个EditorTemplate而不会搞乱MVC模式,也不会在每个控制器中重复代码?

解决方法 不幸的是,没有真正好的方法来处理这样的事情.您是正确的,在视图中进行数据库访问是不合适的.这不仅违反了MVC,而且还需要在视图中创建一个额外的上下文实例,而每个请求应该只有一个.

正如您所提到的,另一种方法是在控制器中执行查询,然后将其传递到视图中.老实说,这可能是你最好的选择.

我看到的另一个选择是使用儿童动作.子 *** 作允许您限制查询用户和仅在一个位置传递到视图的逻辑.缺点是您必须手动处理字段命名,因为子 *** 作视图的呈现将超出您正在构建的表单的范围.换句话说,你必须做的事情如下:

@HTML.Action("CustomerSelect",new { fIEldname = "Customer_ID" })

这也不是很理想,因为现在你已经有了一个你必须跟踪的字符串,你必须要小心实际提供正确的名称.例如,如果这是一个项集合,那么你实际上需要传递类似“MyCollection [”i.ToString()“] .Customer_ID”的内容.你可以看到这开始变得凌乱.仅仅因为这个原因,我几乎认为这是一个可能的解决方案.

最后一个选项是使用HTMLHelper扩展.这与编辑器模板存在的问题相同,因为您将不得不新建一个上下文实例,但至少在Razor视图中没有完成它的方面更好.

总结

以上是内存溢出为你收集整理的c# – 如何使用db查询在ASP.NET MVC 5中创建复杂的EditorTemplate?全部内容,希望文章能够帮你解决c# – 如何使用db查询在ASP.NET MVC 5中创建复杂的EditorTemplate?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1232539.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存