我在这里有这个视图,它根据radiobutton的状态影响文本框:
<script src="/Scripts/jquery-1.7.1.min.js"
type="text/javascript"></script>
<script type="text/javascript">
function doState1() {
alert("state1 radio button has been clicked");
$("#field1").attr("disabled", "disabled");
$("#field2").removeAttr("disabled");
$("#field3").removeAttr("disabled");
}
function doState2() {
alert("state2 radio button has been clicked");
$("#field1").removeAttr("disabled");
$("#field2").attr("disabled", "disabled");
$("#field3").attr("disabled", "disabled");
}
$(document).ready(function ()
{
alert("The document is ready");
if ($("#state1").is(":checked")) {
doState1();
} else {
doState2();
}
$("#state1").click(function (){
doState1();
});
$("#state2").click(function () {
doState();
});
});
</script>
主要问题是我的视图由项列表填充,只有列表中的第一项实际受此脚本影响。为什么?我曾尝试在这里和那里放置(this)语句,认为它会影响上述项目,但它没有改变一件事。
这是for循环,以便您了解实际发生的情况:
<p>
@using (Html.BeginForm("ConfirmSendItems", "Inventory"))
{
(...)
<table>
(...)
@for (int i = 0; i < Model.Count; i++)
{
<p>
<tr>
<td>@Html.DisplayFor(x => x[i].otrObj.objName)</td>
<td>@Html.RadioButtonFor(x => x[i].m_state1, "State 1", new {id = "state1", style ="width: 50px"})</td>
<td>@Html.RadioButtonFor(x => x[i].m_state1, "State 2", new {id = "state2", style ="width: 50px"})</td>
<td>
@Html.TextBoxFor(x => x[i].m_Field1, new{id = "field1", style = "width:200px"})
</td>
<td>
@Html.TextBoxFor(x => x[i].m_Field2, new {id = "field2", style = "width:200px"})
</td>
<td>
@Html.TextBoxFor(x => x[i].m_Field3, new {id ="field3", style = "width:200px" })
@Html.ValidationMessageFor(x => x[i].m_FixedPrice, "Fixed Price must be a number.")
</td>
(...)
</p>
}
</table>
<input type="submit" value="Ready!"/>
}
</p>
答案 0 :(得分:1)
Ids是单数。只有一个项目可以拥有该ID。
您将不得不在选择器中使用类名,并且您必须构建逻辑以选择正确的项。