我的页面上有asp:panel
。在运行时,我向此面板添加控件,我想根据业务逻辑禁用/启用其所有控件。
我试过这个:
document.getElementById('mypanel').disabled = true;
但它没有用。
有没有人有任何想法让这项工作?
答案 0 :(得分:9)
asp:Panel
只生成一个div元素。这不是表单控件,它只是用于结构。
要禁用其中的每个输入控件,如果您使用的是jQuery,请尝试:
$("#<%=mypanel.ClientID%> input").attr("disabled", true);
或者简单的'JavaScript:
var controls = document.getElementById("<%=mypanel.ClientID%>").getElementsByTagName("input");
for (var i = 0; i < controls.length; i++)
controls[i].disabled = true;
答案 1 :(得分:0)
尝试以下代码段
<div>
<asp:Panel ID="pnl" runat="server">
<asp:TextBox runat="server" />
<asp:TextBox runat="server" />
<asp:CheckBox Text="text" runat="server" />
</asp:Panel>
<input type="button" name="name" value=" Test" onclick="ED();" />
</div>
<script type="text/javascript">
function ED() {
var div_to_disable = document.getElementById('<%=pnl.ClientID %>').getElementsByTagName("input");
var children = div_to_disable;//.childNodes;
for (var i = 0; i < children.length; i++) {
children[i].disabled = true;
};
}
</script>
答案 2 :(得分:0)
**工作100%**
function EnableDisableRadio(CheckBox1) {
var controls = document.getElementById("<%=Panel1.ClientID%>").getElementsByTagName("input");
for (var i = 0; i < controls.length; i++)
controls[i].disabled = CheckBox1.checked ? false : true;
}
&#13;
<asp:CheckBox ID="CheckBox1" runat="server" Text="check" onclick="EnableDisableRadio(this)"/>
<asp:Panel ID="Panel1" runat="server" Width="160px" Enabled="False">
<asp:RadioButtonList ID="RadioButtonList1" runat="server" RepeatDirection="Horizontal">
<asp:ListItem>1</asp:ListItem>
<asp:ListItem>2</asp:ListItem>
<asp:ListItem>3</asp:ListItem>
</asp:RadioButtonList>
</asp:Panel>
<br />
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
&#13;
答案 3 :(得分:0)
<asp:CheckBox ID="CheckBox1" runat="server" Text="check" onclick="EnableDisableRadio(this)"/>
<asp:Panel ID="Panel1" runat="server" Width="160px" Enabled="False">
<asp:RadioButtonList ID="RadioButtonList1" runat="server" RepeatDirection="Horizontal">
<asp:ListItem>1</asp:ListItem>
<asp:ListItem>2</asp:ListItem>
<asp:ListItem>3</asp:ListItem>
</asp:RadioButtonList>
</asp:Panel>
<br />
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
<asp:CheckBox ID="CheckBox1" runat="server" Text="check" onclick="EnableDisableRadio(this)"/>
<asp:Panel ID="Panel1" runat="server" Width="160px" Enabled="False">
<asp:RadioButtonList ID="RadioButtonList1" runat="server" RepeatDirection="Horizontal">
<asp:ListItem>1</asp:ListItem>
<asp:ListItem>2</asp:ListItem>
<asp:ListItem>3</asp:ListItem>
</asp:RadioButtonList>
</asp:Panel>
<br />
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
答案 4 :(得分:-3)
asp:panel是一个服务器控件。你为什么要在客户端操纵它?只需在代码
后面使用mypanel.enable = false
即可