c# - 将 JavaScript 菜单放入 Asp.Net 页面时出现问题

标签 c# asp.net javascript html .net-3.5

在我在这里发布我的问题之前,请注意,我真的很想保留该菜单的 javascript 和 css。

现在解决我的问题。 我有一个 JavaScript 菜单,在将其放入 asp.net 页面时遇到问题,在生成更正确的正确 html 时遇到问题。

如果有人能指出我正确的方向,我将非常感激。

html 中的菜单如下所示:

        <!-- HOME -->
        <div class="menu_item" onmouseover="hide_all_panels();">
            <a href="/default.aspx">Home</a>
        </div>


        <!-- ABOUT SITE -->
        <div id="trigger1" onmouseover="show_panel('0');">
            <div class="menu_item">

                <a href="/about_us.aspx">About Us</a>
            </div>
            <div class="hidden_div">
                <!-- ABOUT WEB SITE POPOUT -->
                <div class="menu" id="popout1">
                    <div class="menu_item">
                        <a href="/frequently_asked_questions.aspx">Frequently Asked Questions</a>
                    </div>

                    <div class="menu_item">
                        <a href="/our_team.aspx">Our Team</a>
                    </div>
                    <div class="menu_item">
                        <a href="/our_board.aspx">The Board</a>
                    </div>
                </div>
            </div>

        </div>

            <a href="/blog/">Blog</a>
        </div>


        <!-- CONTACT US -->
        <div class="menu_item" onmouseover="hide_all_panels();">
            <a href="/contact.aspx">Contact Us</a>
        </div>

如您所见,对于没有子项的单个菜单,div 不是对称的,我只是将链接包装到 div 中,但对于带有子项的菜单,我有一个菜单,其中包含一个触发 div 和另外 2 个主要 div。

我尝试在 asp.net 端为此菜单添加类似的内容(现在不要注意链接命名,它们并不重要):

<asp:Repeater ID="rpt_Menu" runat="server" OnItemDataBound="rpt_Menu_DataBound">
                <ItemTemplate>

                    <asp:Panel ID="pnl_MainSubmenuDiv" runat="server" Visible="false" Enabled="false">
                        <div id="trigger<%= index %>" onmouseover="show_panel('<%= index %>');">
                    </asp:Panel>

                    <div class="menu_item" onmouseover="hide_all_panels();">
                        <a href="/default.aspx"><%# Eval("menu_name") %></a>
                    </div>

                    <asp:HiddenField ID="hdn_Id" runat="server" Value='<%# Eval("menu_id") %>' />
                    <asp:Repeater ID="rpt_SubMenu" runat="server">
                        <ItemTemplate>
                             <div class="menu" id="popout<%= index %>">
                               <div class="menu_item">
                                   <a href="/about_us.aspx"><%# Eval("menu_name") %></a>
                               </div>
                             </div>
                        </ItemTemplate>
                    </asp:Repeater>

                    <asp:Panel ID="pnl_MainSubmenuClose" runat="server" Visible="false" Enabled="false">
                        </div>
                    </asp:Panel>
                </ItemTemplate>
            </asp:Repeater>

背后的代码非常简单,没有什么特别的,我所做的只是绑定(bind)第一个中继器内的第二个中继器,并使面板可见或不可见:

 protected void rpt_Menu_DataBound(object obj, RepeaterItemEventArgs e)
    {
        int parent_id = Int32.Parse(((HiddenField)e.Item.FindControl("hdn_Id")).Value.ToString());
        using (SamaraDataContext mycity = new SamaraDataContext())
        {
            var subMenu = from sm in mycity.tbl_menus
                          where (sm.menu_parent == parent_id)
                          select new
                          {
                              menu_id = sm.menu_id,
                              menu_name = sm.menu_name
                          };

            int count = 0;
            foreach (var item in subMenu)
            {
                count++;
            }

            if (count > 0)
            {
                ((Panel)e.Item.FindControl("pnl_MainSubmenuDiv")).Visible = true;
                ((Panel)e.Item.FindControl("pnl_MainSubmenuClose")).Visible = true;
                ((Repeater)e.Item.FindControl("rpt_SubMenu")).DataSource = subMenu.ToList();
                ((Repeater)e.Item.FindControl("rpt_SubMenu")).DataBind();
                this.index++;
            }
        }
    }
}

但是我的问题是面板会生成 div,即使它们是隐藏的,这会破坏所有 html 结构。

我真的不喜欢将 div 格式化放在后面的代码中。

最佳答案

本节的一件事是:

<asp:Panel ID="pnl_MainSubmenuClose" runat="server" Visible="false" Enabled="false">
  </div>
</asp:Panel>

如果 Visible 设置为 true,将呈现无效的 HTML,从而可能会破坏您的 JavaScript 和 CSS 交互。

结果会像这样:

<div id="something_something_pnl_MainSubmenuClose">
  </div>
</div>

作为面板控件,在它们所包围的任何内容周围渲染。因此,想办法解决这个问题,您的问题就可能得到解决。

关于c# - 将 JavaScript 菜单放入 Asp.Net 页面时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1223374/

相关文章:

c# - 通过 SyncVar 进行 Unity Networking 同步

asp.net - 使用 React 构建 ASP.NET Core 应用程序时,如何修复 'The command "npm install"exited with code 1' 错误?

jquery - 访问不同 TD 中控件的 ClientID

javascript - 我正在尝试从函数内提取 doc.data 数组并在范围之外使用它

javascript - 将controller和controllerAs设置为相同的字符串

javascript - 闭包中变量的性能与函数参数

c# - 如何从 C# 客户端应用程序执行 ebMS3 AS4 消息传递

C# 每 30 分钟循环 24 小时

c# - C#中继承的性能考虑

javascript - 需要从代码隐藏中调用 Javascript 方法