- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 MetadataType 为我的实体提供两个独立实体的验证功能。需要注意的是,我正在使用客户端向导,使用 jQuery 和 JavaScript 进行非侵入式验证。验证似乎适用于一个实体而不适用于另一个实体。
经过进一步分析,我注意到 data-val="true"没有为未验证的实体呈现。这就是令人困惑的地方, Display 属性对任何一个实体都不起作用,随后仅呈现属性名称而不是 display 属性。我不明白。我一直在整个 Internet 上搜索遇到此问题但一无所获的人。
AppName.Domain project:
namespace AppName.Domain.MemberDomain
{
public class Member
{
public string EmailAddress { get; set; }
public string Password { get; set; }
public string FirstName { get; set; }
public string MiddleName { get; set; }
public string LastName { get; set; }
}
}
namespace AppName.Domain.MetricsDomain
{
public class Metrics
{
public string PersonalView { get; set; }
public double CurrentWeight { get; set; }
public double IdealWeight { get; set; }
}
}
AppName.Web project:
namespace AppName.Models
{
[MetadataType(typeof(MemberMetaData))]
public partial class Member
{
}
public class MemberMetaData
{
[Required]
[StringLength(255)]
[DataType(DataType.EmailAddress)]
[Display(Name = "Email address")]
public string EmailAddress { get; set; }
[Required]
[StringLength(10)]
[DataType(DataType.Password)]
[Display(Name = "Password")]
public string Password { get; set; }
[Required]
[StringLength(10)]
[DataType(DataType.Password)]
[Display(Name = "Password")]
[Compare("Password", ErrorMessage = "The passwords you entered do not match.")]
public string ConfirmPassword { get; set; }
[Required]
[StringLength(20)]
[DataType(DataType.Text)]
[Display(Name = "First Name")]
public string FirstName { get; set; }
[StringLength(20)]
[DataType(DataType.Text)]
[Display(Name = "Middle Name")]
public string MiddleName { get; set; }
[Required]
[StringLength(20)]
[DataType(DataType.Text)]
[Display(Name = "Last Name")]
public string LastName { get; set; }
}
[MetadataType(typeof(PersonMetricsMetaData))]
public partial class Metrics
{
}
PersonMetricsMetaData
{
[Required]
[StringLength(255)]
[Display(Name = "How do you see yourself?")]
public string PersonalView { get; set; }
[Required]
[RegularExpression(@"[0-9]*\.?[0-9]+", ErrorMessage = "You must enter a valid Number.")]
[Display(Name = "Current Weight")]
public double CurrentWeight { get; set; }
[Required]
[RegularExpression(@"[0-9]*\.?[0-9]+", ErrorMessage = "You must enter a valid Number.")]
[Display(Name = "Ideal Weight")]
public double IdealWeight { get; set; }
}
}
public class RegisterModel
{
public MetricsDomain.Metrics Metrics { get; set; }
public MemberDomain.Member Member { get; set; }
}
Form element for the Member entity:
<div class="elementContainer">
<input id="Member_FirstName" name="Member.FirstName" type="text" value="" />
<span class="field-validation-valid" data-valmsg-for="Member.FirstName" data-valmsg-replace="true"></span>
</div>
Form element for the Metrics entity:
<div class="elementContainer">
<input data-val="true" data-val-number="The field Personal View must be a number." data-val-required="The Personal View field is required." id="Metrics_PersonalView" name="Metrics.PersonalView" type="text" value="" />
<span class="field-validation-valid" data-valmsg-for="Metrics.PersonalView" data-valmsg-replace="true"></span>
</div>
这是 html:
@model AppName.Models.RegisterModel
@{
ViewBag.Title = "Register";
Layout = "~/Views/Shared/_OuterLayout.cshtml";
}
<style type="text/css">
.formContainer { display: none; }
</style>
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
<script type="text/javascript">
var i = 1;
var stepCount = 1;
$(function () {
$(".formContainer:first").fadeIn(); // show first step
$("#lblCurrentStep").text(stepCount);
//$(".buttonContainerBottom").hide();
//$("#divWizardMenu").hide();
// attach backStep button handler
// hide on first step
$("#previous").hide().click(function () {
if (stepCount > 0)
$("#lblCurrentStep").text(--stepCount);
var $step = $(".formContainer:visible"); // get current step
if ($step.prev().hasClass("formContainer")) { // is there any previous step?
$step.hide().prev().fadeIn(); // show it and hide current step
// disable backstep button?
if (!$step.prev().prev().hasClass("formContainer")) {
$("#previous").hide();
}
}
});
// attach nextStep button handler
$("#next").click(function () {
if (stepCount < 2)
$("#lblCurrentStep").text(++stepCount);
var $step = $(".formContainer:visible"); // get current step
var validator = $("form").validate(); // obtain validator
var anyError = false;
$step.find("input").each(function () {
if (!validator.element(this)) { // validate every input element inside this step
anyError = true;
}
});
if (anyError)
return false; // exit if any error found
/*
if ($step.next().hasClass("confirm")) { // is it confirmation?
// show confirmation asynchronously
$.post("/Account/Register", $("form").serialize(), function (r) {
// inject response in confirmation step
$(".formContainer.confirm").html(r);
});
}
*/
if ($step.next().hasClass("formContainer")) { // is there any next step?
$step.hide().next().fadeIn(); // show it and hide current step
$("#previous").show(); // recall to show backStep button
}
else { // this is last step, submit form
$("form").submit();
}
});
});
</script>
@using (Html.BeginForm())
{
@Html.ValidationSummary(true)
<div id="divFormContainerMember" class="formContainer">
<div id="divMemberLeft" class="leftContainer">
<h1>User, great work. Tell others about yourself</h1>
</div>
<div id="divMemberRight" class="rightContainer">
<div class="labelContainer">
@Html.LabelFor(m => m.Member.FirstName)
</div>
<div class="elementContainer">
@Html.TextBoxFor(m => m.Member.FirstName)
@Html.ValidationMessageFor(m => m.Member.FirstName)
</div>
<div class="labelContainer">
@Html.LabelFor(m => m.Member.MiddleName)
</div>
<div class="elementContainer">
@Html.TextBoxFor(m => m.Member.MiddleName)
@Html.ValidationMessageFor(m => m.Member.MiddleName)
</div>
<div class="labelContainer">
@Html.LabelFor(m => m.Member.LastName)
</div>
<div class="elementContainer">
@Html.TextBoxFor(m => m.Member.LastName)
@Html.ValidationMessageFor(m => m.Member.LastName)
</div>
<div class="labelContainer">
@Html.LabelFor(m => m.Member.EmailAddress)
</div>
<div class="elementContainer">
@Html.TextBoxFor(m => m.Member.EmailAddress)
@Html.ValidationMessageFor(m => m.Member.EmailAddress)
</div>
<div class="labelContainer">
@Html.LabelFor(m => m.Member.Password)
</div>
<div class="elementContainer">
@Html.PasswordFor(m => m.Member.Password)
@Html.ValidationMessageFor(m => m.Member.Password)
</div>
<div class="labelContainer">
@Html.LabelFor(m => m.Member.NewPassword)
</div>
<div class="elementContainer">
@Html.PasswordFor(m => m.Member.NewPassword)
@Html.ValidationMessageFor(m => m.Member.NewPassword)
</div>
</div>
</div>
<div id="divFormContainerMetrics" class="formContainer">
<div id="divMetricsLeft" class="leftContainer">
<div class="labelContainer">
@Html.LabelFor(m => m.Metrics.PersonalView)
</div>
<div class="elementContainer">
@Html.TextBoxFor(m => m.Metrics.PersonalView)
@Html.ValidationMessageFor(m => m.Metrics.PersonalView)
</div>
<div class="labelContainer">
@Html.LabelFor(m => m.Metrics.CurrentWeight)
</div>
<div class="elementContainer">
@Html.TextBoxFor(m => m.Metrics.CurrentWeight)
@Html.ValidationMessageFor(m => m.Metrics.CurrentWeight)
</div>
<div class="labelContainer">
@Html.LabelFor(m => m.Metrics.IdealWeight)
</div>
<div class="elementContainer">
@Html.TextBoxFor(m => m.Metrics.IdealWeight)
@Html.ValidationMessageFor(m => m.Metrics.IdealWeight)
</div>
</div>
<div id="divMetricsRight" class="rightContainer">
</div>
</div>
<div class="buttonContainerBottom">
<span class="buttonContainerInner">
<input type="button" id="previous" name="previous" value="Previous" class="orangeButton" />
<input type="button" id="next" name="next" value="Next" class="orangeButton"/>
<label id="lblStep" class="wizardStep">Step <label id="lblCurrentStep"></label> of 2</label>
</span>
</div>
}
最佳答案
我在使用 jquery stepy 插件时遇到了同样的问题。我解决了它在用户更改页面时添加验证规则的问题。
关于.net - 客户端表单验证不适用于使用 MetadataType 的 jquery 向导,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16993999/
我正在实现 WPF MVVM 向导,我想知道执行 DoOperation 的正确方法当加载新的向导页面 (UserControl) 时。 DoOperation在 MyWizard.ViewModal
我有一个场景,我正在尝试计划开始编码,并且我正在考虑使用django向导。 我的计划是通过两个步骤构建一个 django 向导,第一个简单,但第二个有点复杂。第二步将包含一个表单,该表单将根据第一步选
我想看看这些是否“建立了……” Flash网站(以支持用户定制的订购过程)是使用常规Flash还是Flex完成的? Site 1 Site 2 Site 3 Site 4 所有这些都可以通过定制的订购
我在人们提交一些数据的表单上使用了 FuelUX 向导,我们希望将其分解为逻辑步骤。效果非常好。 现在我正在处理相同表单的编辑版本,它工作正常,但由于步骤已经加载了数据,我希望用户能够直接跳到步骤 X
我有一个足够大的模型,可以切割成 3 种形式。我想使用 FormWizzard 来做到这一点,但我想知道,如何将表单中的信息保存到数据库? 所有东西都来自同一个模型。 你知道如何做到这一点吗? 最佳答
我使用 Primefaces 3.5。并尝试在的onnext处理程序中调用js函数。我希望在当前选项卡验证结果后,onnext 返回特定选项卡上的选项卡。我的验证函数 function val
我在我的应用程序中实现了向导 Bootstrap 。 我想检索当前选项卡的索引来测试显示或隐藏按钮“下一个”“上一个” $('#rootwizard').bootstrapWizard({ '
我想创建一个基于终端的安装程序/向导。 理想情况下,它就像 Ubuntu 服务器安装程序或 Arch Linux 安装程序——一个 ncurses (?) 重的 GUI,具有很多形式和箭头键优点。 其
问题 我的 WizardPage 中有一个 Composite,如果该 Composite 比向导窗口大,我想向其中添加滚动条,但到目前为止我尝试过的方法都不起作用。有人知道如何添加滚动条吗? 我想将
我正在尝试制作一个引导步骤表单,但它不想工作。我正在使用这段代码: https://codepen.io/digitalavinash/pen/VjyAXx?fbclid=IwAR2j8hRIG0gn
我目前正在开发一个网站(与健身相关),客户想要做一个功能,允许用户根据您从类似于 this example 上的 slider 中选择的选项来选择锻炼计划。 . 我想知道这是否可以用 CSS 完成,或
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 6 年前。 Improve
这应该很简单,但我错过了。我试图通过在我的 stylesheet.css 中使用此 css 将文本居中放置在我的向导 h1 标签中 .h1textalign { text-align:center;
我已经在这里问过这个问题 Creating next and back button on tabs bootstrap 3 wizard? 但我现在已经扩展它以在最后一个选项卡上添加完成,但现在我在
摩尔庄园手游已经上线好几天了,身边不少小伙伴也都开始玩了,不过其中的还是有不少的玩法等待大家去解锁,比如大家知道怎么去传送好友,蘑菇吗?向导怎么传送呢?有哪些方法和技巧?下面就和小编一起来看看。
每次我在我的 Android Studio 中为该项目创建一个新 fragment 时,它都会创建 android.support.v4.app.Fragment ,这不是我想要的。此外,它总是会触发
我正在为我的公司项目使用 SAPUI5 向导,但由于某种原因它对我不起作用。 这是我的代码: var allSteps = oWizardElement.getSteps(); var stepOne
在扩展中,我希望能够修改现有链接。数据库中的相应字段可能包含多个链接(例如 tt_content.bodytext)。 我想尽可能多地重用现有的功能。所以我想使用已经存在的链接向导。 我找到的是现有路
长话短说,我有一个开发人员让我成为一名向导,即使我付了钱给他,他也没有在没有回复的情况下离开,并坚持使用一个半工作的Python向导。 该向导在 Kodi 内部运行,下载并解压 zip 文件。但有时我
我对 Fuel UX 向导有疑问。当我按下 fuel ux 向导上的下一步按钮时,我发送使用 validate_step(step) 选择的 category_id 并使用来自 php 的 json
我是一名优秀的程序员,十分优秀!