vs2003动态加载用户控件的组件

分类: asp.net技巧   出处:iocblog整理  更新时间:2009-08-01   添加到收藏  


  页面是用来浏览信息的!但是更重要的是和用户交互,根据不同的需求提供不同的内容服务,这是一种服务或是一种更贴近用户的人性化。(又在胡言乱语了!^_^)
  
  动态加载叶面,根据不同的用户权限加载不懂的内容服务。根据用户的相应加载相应的内容服务。
  
  还有另外一个应用就是做到页面与代码的分离。在vs2003里,一般ascx或aspx文件,在刚建立的时候都直接跟一个cs文件关联。那么我们在写程序的时候就不能分开来做。作叶面和写后台代码的不能分开。为了能够做到作业面与作后台代码的能完全分开来,我们可以把后台的所有代码当作一个组件来做就可以了!这样一个不用跟cs文件关联的aspx叶面文件直接引用一个组件就可以了!那么组件可以加载不同的ascx文件最后组成一个完整的叶面。就这样一个项目的开发就像个机车制造厂一样组装不同的零件就有辆车出来了。软件也可以拿来组装,零件我们也可以订制,最后整体就可以出来了!(常常看别人的文章的时候怎么就觉得废话那么多,原来发现我废话也不少!^_^)
  
  好!让我们step by step ,就从不需要关联cs文件的aspx叶面开始吧!(在vs2005里,我新建aspx叶面的时候就直接没有cs文件关联。但是直接有个不完整类型隐藏起来了。怎么用基类就成为问题了!隐藏部分应该是继承了page了!那么根据单继承的原则我们是不能在继承别的类型的了。这个问题有待研究。)
  
  根据aspx叶面运行原理。叶面要跟服务端交互必须通过一个run at server的form标签才能行得通。因此我不要先来写个form组件,那么form就应该是个容器的形势来承载叶面所有要与服务端交互的元素,(容器太重要了,namespace也可以看作容器,只不过是不能放东西而已,是虚拟的容器)
  
  1、做form容器组建:继承继承他就行了,注意一点就是唯一id的问题。自己继承的可能该改变了id,那么回传的时候就找不到了啊。切记!当然render叶面的时候是通过遍历所有form容器内所有的组件来一个个render出来。所以要改uniqueid。
  
  示例一下:
  
  using system;
  
  using system.web.ui;
  
  using system.web.ui.webcontrols;
  
  using system.componentmodel;
  
  namespace region.controls {
    public class myform : system.web.ui.htmlcontrols.htmlform {
        public override string uniqueid {
  
        get {
  
          if (this.nonamecontainer && this.namingcontainer != this.page ) {
  
            return base.uniqueid.substring(base.uniqueid.lastindexof(":")+1);
  
          } else {
  
            return base.uniqueid;
  
          }
  (来源www.iocblog.net)
        }
  
      }
      protected override void renderattributes(htmltextwriter writer) {
  
        this. nonamecontainer = true;
  
        base.renderattributes (writer);
  
        this. nonamecontainer = false;
  
      }
      protected override void renderchildren(htmltextwriter writer) {
  
        this. nonamecontainer = true;
  
        base.renderchildren (writer);
  
        this. nonamecontainer = false;
  
      }
      private boolean nonamecontainer = false;
  
    }
  
  }
  (来源www.iocblog.net)



文章整理:iocblog
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。