zoukankan      html  css  js  c++  java
  • ASP.net中动态加载控件时一些问题的总结(转)

    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%>.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。
  • 相关阅读:
    三数之和
    盛最多水的容器
    正则表达式匹配
    最长回文子串
    寻找两个有序数组的中位数
    2、二维数组中的查找
    1、找出数组中重复的数字
    mongodb的下载地址
    提取快捷方式的图标资源问题
    一条数据引发的问题
  • 原文地址:https://www.cnblogs.com/ballpenxp/p/1562460.html
Copyright © 2011-2022 走看看