我试图根据复选框控件中选中的复选框显示/隐藏asp面板。
HTML代码
<asp:Panel runat="server" ID ="ESYLaterControl" CssClass="ESYLaterControl">
<tr>
<td style="padding-top: 10px;padding-left: 0px">
<asp:CheckBox runat="server" ID="chkbxesylater" CssClass="chbxESYLater" OnCheckedChanged="PageModified"/>
<uc3:DateControl ID="Dtctrlesylaterdate" class="dtctrESY" runat="server"/>
</td>
</tr>
<tr>
<td id="explainESYLater" style="padding-top: 10px">
Explain
</td>
</tr>
<tr>
<td style="padding-left: 3px">
<asp:TextBox runat="server" ID="txtesylater" Class ="txtbxESY" Width="100%" TextMode="MultiLine"></asp:TextBox>
</td>
</tr>
</asp:Panel>
脚本
<script type="text/javascript">
$(document).ready(function () {
$(function() {
var $ESYYes = $('#<%= YesNoControlESY.GetYesClientID() %>');
var $ESYno = $('#<%= YesNoControlESY.GetNoClientID() %>');
var $panel = $('.ESYLaterControl');
$ESYYes.change(function () {
if ($panel != null && $ESYYes != null)
if($ESYYes.is(':checked')) {
panel.style.display = 'block';
} else {
panel.style.display = 'none';
}
});
});
});
当我调试firebug中的代码时,如果阻止if($ ESYYes.is(':checked'))但它没有显示或隐藏面板,则进入内部。
答案 0 :(得分:1)
而不是
panel.style.display = 'block'
和panel.style.display = 'none';
试
$panel.show();
和$panel.hide();
答案 1 :(得分:0)
$ panel缺少$前缀。 if / else块中的变量是&#34; panel&#34;。