场景:我在转发器中有一个 ul an li 和一个复选框和标签,它们一起形成了一个复选框列表。我有一个控制复选框行为的javascript文件。我成功地用 javascript 代码隐藏了复选框,但是当我试图隐藏标签时它不起作用。
我将发布代码 ASP.NET 以便更好地理解:
<asp:Repeater ID="Repeater1" runat="server" DataSource="<%# GetSecondAreas(CurrentLocationName) %>">
<HeaderTemplate>
<ul>
</HeaderTemplate>
<ItemTemplate>
<li class="area">
<input type="checkbox" class="category" value="<%# string.Concat(CurrentLocation.Area1,"| ", CurrentLocation.Area2)%>" />
<label>
<%#CurrentLocation.Area2%>
</label>
<asp:Repeater ID="Repeater2" runat="server" DataSource="<%# GetThirdAreas(CurrentLocation.Area2) %>">
<HeaderTemplate>
<ul>
</HeaderTemplate>
<ItemTemplate>
<li>
<input type="checkbox" class="category" value="<%#string.Concat(CurrentLocation.Area1,"| ", CurrentLocation.Area2,"| ", CurrentLocation.Area3)%>" />
<label id="last">
<%#CurrentLocation.Area3%>
</label>
</li>
</ItemTemplate>
<FooterTemplate>
</ul>
</FooterTemplate>
</asp:Repeater>
</li>
</ItemTemplate>
<FooterTemplate>
</ul>
</FooterTemplate>
</asp:Repeater>
这是javascript代码:
function updateByArea(current) {
//If current is unchecked => uncheck all child checkboxes
if (current.attr("checked") == null || current.attr("checked") == "")
$j(".area ul li input[value^='" + current.val() + "']:checked").removeAttr("checked").hide(); //checkbox
$j('label[id="id_val"]').hide();
$j("#searchFilter .area>input:checkbox:checked").each(function (i, item) {
$j(".area ul li input[value^='" + $j(item).val() + "']:not(:checked)").attr("checked", "checked").show(); //checkbox
$j('label[id="id_val"]').show();
});
}
我在这里发布的是我为 id="last" 的标签所尝试的
问题:
我是否对标签的 javascript 代码进行了更正,所以当我勾选复选框以隐藏并同时显示复选框和标签时?
PS:在我现在拥有的代码上,它只隐藏了复选框。
先感谢您