我正在创建一个简单的用户注册表单。用户可以注册为公司或个人。以下是使用RadioButtonFor html帮助程序的注册表单的相关视图。我已经定义了要在javascript中使用的id属性:
@model LayoutTest.ViewModels.ProjectUser
<script>
$(function () {
$("#Class_UserType").change(function(){
var value = $(this).val();
if (value == 1) {
$('#Person').hide();
}
else if (value == 2) {
$('#Company').hide();
}
});
});
</script>
@using (Html.BeginForm("Create", "Project", FormMethod.Post, new { enctype = "multipart/form-data" }))
{
@Html.ValidationSummary(true)
<fieldset>
<div class="new_row">
<div class="editor-label">
@Html.LabelFor(model => Model.UserType)
</div>
<div class="editor-field">
<div class="editor-field">
@Html.RadioButtonFor(model => model.UserType, (int)UserType.Company, new { @id= "Class_UserType" }) Company
@{Html.ValidateFor(model => model.UserType);}
</div>
<div class="editor-field">
@Html.RadioButtonFor(model => model.UserType, (int)UserType.Individual, new { @id = "Class_UserType" }) Individual
@{Html.ValidateFor(model => model.UserType);}
</div>
</div>
</div>
<div class="Company">
HTML Tags inside
</div>
<div class="Person">
HTML Tags inside
</div>
当正常工作时,此代码应隐藏相应的div公司/人员。我看了很多样本,但无法弄清楚我在做错了什么!任何帮助将不胜感激。
以下是相关的html输出:
<div class="new_row">
<div class="editor-label">
<label for="UserType">*User Type</label>
</div>
<div class="editor-field">
<div class="editor-field">
<input data-val="true" data-val-number="The field *User Type must be a number." data-val-required="The *User Type field is required." id="Class_UserType" name="UserType" type="radio" value="1" /> Company
</div>
<div class="editor-field">
<input checked="checked" id="Class_UserType" name="UserType" type="radio" value="2" /> Individual
</div>
</div>
</div>
答案 0 :(得分:3)
以下为我做了诀窍:
$('.UserType').change(function () {
var value = $(this).filter(':checked').val();
if (value == "1") {
$('.Person').hide();
$('.Company').show(500);
}
else if (value == "2") {
$('.Company').hide();
$('.Person').show(500);
}
});
首先,我需要在我的html中定义一个公共类:
<div class="editor-field">
@Html.RadioButtonFor(model => model.UserType, (int)UserType.Company, new { @id= "Class_UTCompany", @class="UserType" }) Company
@{Html.ValidateFor(model => model.UserType);}
</div>
<div class="editor-field">
@Html.RadioButtonFor(model => model.UserType, (int)UserType.Individual, new { @id = "Class_UTIndividual", @class="UserType" }) Individual
@{Html.ValidateFor(model => model.UserType);}
</div>
其次,我期待int中的值,这导致了错误。我能够通过调试器找到它;在我的javascript代码中。