zoukankan      html  css  js  c++  java
  • burrow在某些项目使用中报"控件包含代码块(即 <% ... %>),因此无法修改控件集合"

    burrow是NHibernate支持OpenSessionInViewer的一个框架,使用他的GenericDAO也很方便。但在某些WEB页面使用中会报"控件包含代码块(即 <% ... %>),因此无法修改控件集合",调用栈显示是NHibernate.Burrow.WebUtil.DLL!NHibernate.Burrow.WebUtil.Impl.GlobalPlaceHolder.p_PreRender处出错。

     处理办法可以:

    下载burrow的源码,修改GlobalPlaceHolder.cs中的void p_PreRender(object sender, EventArgs e)函数,修改后为:

        void p_PreRender(object sender, EventArgs e)
            {
                if (IsInAjaxMode())
                {
                    up.ContentTemplateContainer.Controls.Add(holder);
                }else {
                    if(page.Form == null)
                        return; //for a page without form, there is no way to track status, and thus no need for this holder to be placed.
                    //modified by Randy,the origin code:
                    //page.Form.Controls.Add(holder);
                   //下面的修改是处理在一些页面有<% %>时导致添加placeholder失败,这种情况下可以在页面的form中加:
                    //<asp:PlaceHolder ID="NHibernate_Burrow_WebUtil_GlobalPlaceHolder" runat="server"></asp:PlaceHolder>
                    //burrow会自动使用这个placeholder
                    PlaceHolder existedHolder = page.FindControl(holderId) as PlaceHolder;
                    if (existedHolder == null)
                    {
                        page.Form.Controls.Add(holder);

                    }
                    else
                    {
                        for (int i = holder.Controls.Count-1; i >=0 ; i--)
                        {
                            Control theControl=holder.Controls[i];
                            holder.Controls.Remove(theControl);
                            existedHolder.Controls.Add(theControl);
                        }                    
                        holder = existedHolder;
                    }
                }
            }

    同时修改 holder为非readonly修饰,把holderId修改为单词间用"_"连接。

     当然,也可以借这个小修改,一齐把burrow修改成支持NHibernate-2.1.2.GA的版本。

  • 相关阅读:
    SQL_Server_2005_日期和时间函数(描述及实例)
    用户 '**' 登录失败。该用户与可信 SQL Server 连接无关联。
    MSSQL2005服务器登录名、角色、数据库用户、角色、架构的关系
    SQL_Server_2005_字符串函数(描述及实例)
    C#中关于DataGridView行和列的背景色前景色设置
    SQL Server 数据库使用备份还原造成的孤立用户和对象名‘xxx’无效的错误的解决办法
    SQL Server 2005允许远程连接的配置说明
    .Net Remoting 集成于IIS的简要步骤
    网上学习资料网址集合(随时整理ing)
    利用宏命令,部落联盟照样沟通
  • 原文地址:https://www.cnblogs.com/Render/p/1729144.html
Copyright © 2011-2022 走看看