如何在JavaScript中检查该面板是否可见?

Jui*_*est 3 javascript asp.net

如何在JavaScript中检查该面板是否可见?我正在使用ASP.NET 2.0.

Iva*_*jas 8

假设您在服务器端设置面板的可见性document.getElementById(),只要您确保使用面板控件的正确客户端ID(不要对其进行硬编码),检查返回的值是否有效. .

请参阅客户端findPanel()功能中的检查以进行演示.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <script type="text/javascript">
        function findPanel() {
            var panel = document.getElementById("<%= pnlMyPanel.ClientID %>");
            if (panel) {
                alert("Panel is visible");
            }
            else {
                alert("Panel is not visible");
            }

//        // And this would work too:
//        alert((<%= pnlMyPanel.Visible.ToString().ToLower() %>) ? "Panel is visible": "Panel is not visible");

        }
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:Panel runat="server" ID="pnlMyPanel">
            <p>
                This is a panel.</p>
        </asp:Panel>
        <asp:Button runat="server" ID="btnToggle" Text="Toggle panel visibility..." />
        <input type="button" value="Do client-side visibility check..." onclick="javascript:findPanel();" />
    </div>
    </form>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)

btnToggle单击代码隐藏文件中的以下代码可以在单击时切换面板的可见性:

protected void Page_Load(object sender, EventArgs e)
{
    btnToggle.Click += new EventHandler(btnToggle_Click);
}

void btnToggle_Click(object sender, EventArgs e)
{
    pnlMyPanel.Visible = !pnlMyPanel.Visible;
}
Run Code Online (Sandbox Code Playgroud)