- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
问题
我有一个具有一些必需属性和非必需属性的客户端 View 模型。该 View 包含用于更新不同 View 模型属性的不同部分。如果我使用所需的客户端详细信息(如名字、姓氏、DOB 等)更新 View 的一部分,那么我可以将输入类型包装到 ajax 表单中, Controller 将从 View 模型中获取这些属性并使用 ModelState 进行相应验证.IsValid 和验证将成功。但是,如果我在同一 View 上有另一个部分需要更新 viewmodel 上的非必需属性(即 Notes)并从 ajax 表单发布传递它,则 ModelState 验证失败,因为其他必需属性为 null,因为它们从未提交过作为 ajax 表单的一部分。请注意,必填字段应始终在加载客户详细信息页面之前填充数据,因此绝不能为空。
代码
View 模型
public class ClientDetailViewModel
{
public int ID { get; set; }
[Required]
[StringLength(50, MinimumLength = 2)]
public string FirstName { get; set; }
[Required]
[StringLength(50, MinimumLength = 2)]
public string LastName { get; set; }
[Required]
[Display(Name = "Date of Birth")]
[DataType(DataType.Date)]
public DateTime DOB { get; set; }
[Required]
public string Gender { get; set; }
public string Notes { get; set; }
}
查看
@model MSIC.Models.ClientViewModels.ClientDetailViewModel
@inject MSIC.Services.Custom.IGenderService GenderService;
<!-- tab-pane for updating core client details -->
<div class="tab-pane active" id="tab_1">
<form asp-controller="Client" asp-action="Edit" class="form-horizontal">
<div asp-validation-summary="ModelOnly" class="text-danger"></div>
<div class="form-group">
<label asp-for="FirstName" class="col-sm-2 control-label"></label>
<div class="col-sm-10">
<input asp-for="FirstName" class="form-control" />
<span asp-validation-for="FirstName" class="text-danger" />
</div>
</div>
<div class="form-group">
<label asp-for="LastName" class="col-sm-2 control-label"></label>
<div class="col-sm-10">
<input asp-for="LastName" class="form-control" />
<span asp-validation-for="LastName" class="text-danger" />
</div>
</div>
<div class="form-group">
<label asp-for="DOB" class="col-sm-2 control-label"></label>
<div class="col-sm-10">
<input asp-for="DOB" class="form-control" />
<span asp-validation-for="DOB" class="text-danger" />
</div>
</div>
<div class="form-group">
<label asp-for="Gender" class="col-sm-2 control-label"></label>
<div class="col-sm-10">
<select asp-for="Gender" asp-items="@(new SelectList(GenderService.GetAll(),"Code","Name"))" class="form-control">
</select>
<span asp-validation-for="Gender" class="text-danger" />
</div>
</div>
</form>
</div>
<!-- different section for updating client notes -->
<div id="divNotes" class="center-block">@Model.Notes</div>
<a href="#" class="btn btn-danger btn-block" data-toggle="modal" data-target="#notesModal" role="button"><b>Edit Notes</b></a>
<form asp-controller="Client" asp-action="EditNotes" class="form-horizontal" data-ajax="true" data-ajax-method="POST" data-ajax-update="#divNotes" data-ajax-mode="replace" data-ajax-success="CloseModal('#notesModal')" data-ajax-failure="AjaxOnFailure(xhr, status, error)">
<div class="modal fade" id="notesModal" tabindex="-1" role="dialog" aria-labelledby="notesModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal"><span aria-hidden="true">×</span><span class="sr-only">Close</span></button>
<h4 class="modal-title" id="notesModalLabel">edit Reason</h4>
</div>
<div class="modal-body">
<input type="hidden" asp-for="ID" />
<div class="form-group">
<div class="col-sm-10">
<textarea asp-for="Notes" class="form-control" autofocus></textarea>
<span asp-validation-for="Notes" class="text-danger" />
</div>
</div>
</div>
<div class="modal-footer">
<div class="text-danger pull-left">
<i id="modalErrorIcon" class=""></i>
<span id="modalErrorText"></span>
</div>
<button type="submit" class="btn btn-primary">Save</button>
<button type="button" class="btn btn-default" data-dismiss="modal">Cancel</button>
</div>
</div>
</div>
</div>
</form>
Controller
[HttpPost]
[ValidateAntiForgeryToken]
public IActionResult EditNotes(ClientDetailViewModel model)
{
//validation fails because required fields in model are null since they were not submitted with this ajax form
if (ModelState.IsValid)
{
//update database with client notes and return notes to screen
return Content(model.Notes);
}
return Content("i haven't coded this yet");
}
问题
如何在不重复代码的情况下以高效的方式仅对某些字段在 Controller 内执行 ModelState 验证?我搜索了这个问题并知道像 ModelState[].Errors.Clear(); 这样的选项但由于这将是一个大 View ,有许多不同的部分可供更新,我想避免在不同的 Action 方法中为我需要执行的所有小 ajax 帖子重复这些语句。基本上我想使用 ModelState 验证,这样我就可以将我的验证逻辑存储在 ViewModel 中,而不是在 Controller 中分离和/或复制任何验证逻辑。
我可以看到的另一个选项是将所有必需的属性作为隐藏输入类型包含在我拥有的每个 ajax 表单中,但这似乎非常不必要,而且肯定是维护起来的噩梦。有没有更好的方法来传递 ajax 帖子的所有 ViewModel 属性?如果是这样,发送除了利用 ModelState.IsValid 检查之外未使用的 ViewModel 属性会很昂贵吗?
我是 asp.net 的新手,已经开始使用 asp.net core mvc(我很喜欢它),并且一直在通过所有教程、SO 问题等进行学习。但是有没有可能我正在以错误的方式处理这个问题,如果是的话,使用 asp.net core 和 Microsoft.jQuery.Unobtrusive.Ajax 或其他一些 ajax 工具解决这个问题的正确方法是什么?请注意,我只发布了这个问题,因为发布的其他类似问题似乎都没有涉及在 View 上共享 ViewModel 属性,而是只提交了一些属性,但利用了开箱即用的验证。
提前致谢。
最佳答案
虽然我无法获得推荐的方法来按照建议的方式行事,但我确实使用了关于分离 View 模型以进行渲染和提交的建议。我想我被 Microsoft ASP.NET Core 网站上的电影教程误导了,该网站对详细信息页面和编辑页面使用相同的电影模型。
为了解决我以后的问题,我为详细信息页面采用了一个大 View 模型,我将对需要更新的页面的各个部分使用 View 组件。这允许我为每个 View 组件创建一个单独的 View 模型,并且我的 Controller 后操作可以只接受与相应 View 组件相关的 View 模型,因此它可以只执行必要的 ModelState 验证。
这个来自 jQuery ajax 帖子的服务器端验证让我想到了下一个关于将 ModelState 错误返回给客户端进行显示的问题,但我已经为此提交了一个新问题......
关于c# - ASP.Net Core MVC - 在几个 ViewModel 属性上使用 ModelState 验证的 Ajax 表单提交,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40087998/
我在 mongodb 中的玩家和锦标赛之间存在多对多关系。 我希望能够一次将许多玩家添加到锦标赛中。如果没有 ajax,这很简单,但我们有一个包含数千名玩家的数据库,因此表单选择变得巨大。 我们想为此
这个问题已经有答案了: When should I use html's and when spring's in Spring MVC web app? (3 个回答) 已关闭 6 年前。 我正
我正在 C++ Builder XE4 上使用 VCL。 我有以下组件。 FormMain 具有 TButton *B_select; FormSelect(或DialogSelect)具有 TCom
如何在不影响表单控件的情况下更改表单的 alphablend? 德尔福XE7 最佳答案 此问题的一个解决方案是使用多设备应用程序(如果无法使用VCL)。 如果您需要保留透明的TForm,只需更改属性T
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我正在尝试扩展 Django 注册以包含我自己的注册表单。原则上这是相当简单的。我只需要编写自己的表单( CustomRegistrationForm ),它是原始表单( RegistrationFo
我正在尝试为我的网站实现聊天功能。为了做到这一点,我遵循了以下教程:https://channels.readthedocs.io/en/latest/tutorial/ 然后我稍微更改了代码以实现它
有一个问题,我需要用一个 html 表单提交两个相互关联的模型表单。我知道如何提交两个单独的表格,但是在相关模型表格的情况下外键让我发疯。 问题是,第二个表单应该用外键填充字段到第一个表单的实例。 在
我正在创建一个工具,允许某人输入食谱,然后将其保存为 XML 文件,我已经创建了 XSD,但我想知道如何在我的网页上制作一个表单以允许用户输入他们的食谱并遵守模式。我一直在研究 Ajax 和 Jque
在 .net win 表单(如 asp.net web 表单)中是否有可用的验证控件? 因为很难为我的每个控件设置正确的条件,所以我的表单中也有很多重复的代码。 正确的做法是什么? 最佳答案 看看这个
我有一个简短的问题。我正在学习如何使用 javascript 制作注册表,发现此链接非常有用。 http://www.w3resource.com/javascript/form/javascript
我正在开发一个项目,该项目将使用循环将许多表单添加到 mysql 数据库中。在 javascript 部分中,我无法让 var i 在函数 updatesum() 中工作。有人可以帮我吗? 我试图避免
在我的应用程序上有一个包含 2 个字段和一个保存按钮的表单。 在我的 onClick 结束时我需要什么来将光标返回到第一个字段。 我有这个来清除它们 txtData.setText("
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
<input type="text" name="textfield" onKeyPress="javascript:alert(event.
我正在构建的网站有一个登录表单,作为所有其他模板扩展的 base.html 模板的一部分;因此,我需要以某种方式处理每个页面上的登录/注销逻辑。 目前每个页面都在单独的 View 中加载,那么实现它的
我有一个表单类,看起来像.. #forms.py class ExampleForm(forms.Form): color = forms.CharField(max_length=25)
有没有办法在表单定义中给表单一个特殊的错误渲染函数?在 customizing-the-error-list-format 下的文档中它展示了如何为表单提供特殊的错误呈现函数,但似乎您必须在实例化表单
我正在处理由多个页面组成的表单,我想解决验证问题。 当我点击提交按钮时,当前页面上的所有字段都会在下方显示错误消息,但是如果我更改页面,那么我需要再次点击提交,因为这些字段未设置为已触摸。 如果我可以
是否可以附加到继承表单的 exclude 或 widgets 变量? 到目前为止,我有以下设置。 class AddPropertyForm(forms.ModelForm): num_mon
我是一名优秀的程序员,十分优秀!