1

场景:我在转发器中有一个 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:在我现在拥有的代码上,它只隐藏了复选框。

先感谢您

4

1 回答 1

1

改变

.hide();

.parent().hide();

这将选择父级 [应该是 li] 并隐藏它。

于 2012-09-25T07:34:31.870 回答