• ASP.net中动态加载控件时一些问题的总结


    经常见到有人说在ASP.net中不要使用动态控件,我想主要的原因在于使用动态控件会带来一些问题,在做项目的过程中,我将由动态加载控件引发的总是作了一个小小的总结.
    1 、在使用LoadControl加载控件后,用户控件中的某些控件不再响应事件。
        这个问题主要是由于将控件加载放在if (!Page.IsPostBack)之内引起的,放在外面即可。在思归的blog上对此问题进行了详细的说明。
    2、用户控件中某些控件的响应出现问题,如某个按钮第一次选择时不触发CLICK事件,第二次可以了。
        这是由于没有给控件设置ID引起的,控件ID的作用在下面详细讲述。 如 
       Control  userControl=(Control)Page.LoadControl(“Test.ascx”);
       userControl.ID=“Test”;
       AddControl(userControl);
    3、如果用户控件中包括DataGrid控件,那么加载控件后可能出现不响应DataGrid事件的问题。
       这好像是一个bug,必须要将加载的控件进行强制转换,如:
       Test userControl=(Test)Page.LoadControl(“Test.ascx”);  
       注意:上面使用的是Test类型,而不是Control!
       我在以前的Blog中曾提到过这个问题,这种方式将使系统的扩展性降低。 我有一个解决方案可以和大家讨论(运用策略模式):
       public class BaseControl : System.Web.UI.UserControl
      {
              public virtual BaseControl  ProcessThisControl();
               
      }
    所有的用户控件从BaseControl 继承,如果有Datagrid控件,由overide ProcessThisControl方法 ,如:
              return this as Test;
     按如下方式加载控件:
       
    BaseControl  userControl=(BaseControl  )Page.LoadControl(“Test.ascx”);   
       userControl.ProcessThisControl();

     
    4、在用户控件中如何使用JavaScript。
        大家都知道,使用客户端的脚本将大大提高页面的响应速度,同时可以避免频繁地刷新页面。所以使用javascript来实现页面中部分控制是一个比较好的方式,但是在用户控件中如果访问某一个子控件呢?

    使用方式如下: 
    document.all.<%= TestControl.ClientID%><%= lstUser.ClientID%>.disabled=true;     //将TestControl设置为不可用
    如果在C#脚本中应该这样写:
    Page.RegisterStartupScript("OnInitControl","<SCRIPT LANGUAGE='JavaScript'>document.all.Test_TestControl.disabled=true;</SCRIPT>");   //Test为用户控件,TestControl为用户控件中的子控件。

    现在说一下控件ID,在访问aspx文件时,IIS会将aspx的脚本进行编译。编译的时候将用户控件中的内容写在同一个页面中,为了防止页面中的控件与用户控件中的控件名称相同,在编译的时候对用户控件中的控件名称修改为 :   用户控件名:子控件 ,控件ID则修改为 用户控件ID_子控件ID。 在动态加载控件时,如果不对控件的ID进行赋值,则控件ID为上一次加载的控件ID,因此在加载用户控件后应该立即对其设置ID。




  • 相关阅读:
    第三十七节 log日志模块
    第三十六节 更新备注信息
    第三十五节 取消关注的股票
    第三十四节 路由添加正则功能以及添加关注功能
    第三十三节 通过带有参数的装饰器完成路由功能
    第三十二节 带有参数的装饰器
    Web_CSS
    Web_HTML
    Python操作MySQL
    MySQL_索引原理
  • 原文地址:https://www.cnblogs.com/wljcan/p/15604.html
Copyright © 2020-2023  润新知