zoukankan      html  css  js  c++  java
  • 使用MasterPage后的this.FindControl()函数的问题

    以前我就曾经写过一个关于MasterPage里面使用this.FindControl()函数的问题。

    http://www.cnblogs.com/dlwang2002/archive/2006/07/09/446643.html

    当时通过其他方式解决了,但是今天又遇到了。在google上找到了一篇文章http://west-wind.com/WebLog/posts/5127.aspx说的很对,能够解决这个问题

    在没有使用MasterPage之前,页面this访问到的对象就是他自己,所以使用this,FindControl也就没什么问题。

    但是使用MasterPage之后,this.Control.Count=1,就只有一个。跟踪一下:   this.Controls[0]      {ASP.module_mp1_master}       System.Web.UI.Control {ASP.module_mp1_master} .

    也就是说,加入masterPage之后他的控件的顺序就变了。(以前看过一个在asp.net1.1下的MasterPage实现,也是类似的方式,重新组织控件)。这就是问题所在。

    解决方法:

    把原来这样的使用:

    protected void AssignControls()

    {

        
    this.lblError = this.FindControl("lblError"as Label;

        
    this.dgItemList = this.FindControl("dgItemList"as DataGrid;

    }


    变成这样调用:

    protected void AssignControls()

    {

        
    this.lblError = this.Master.FindControl("Content").FindControl("lblError"as Label;

        
    this.dgItemList = this.Master.FindControl("Content").FindControl("dgItemList"as DataGrid;

    }



    也就是说,先使用this.Master.FindControl("Content")来找到在MasterPage上相对的位置,然后再按照以前的调用方式就可以了。

     

    或者使用这个函数(这三个函数都来自原作者Rick Strahl

    public static Control FindControlRecursive(Control Root, string Id)

    {

        
    if (Root.ID == Id)

            
    return Root;

     

        
    foreach (Control Ctl in Root.Controls)

        
    {

            Control FoundCtl 
    = FindControlRecursive(Ctl, Id);

            
    if (FoundCtl != null)

                
    return FoundCtl;

        }


     

        
    return null;

    }


  • 相关阅读:
    vue 生产包 背景图片-background图片不显示
    数组的方法
    前端常用Utils工具函数库合集
    vue路由
    问题
    Promise与async/await -- 处理异步
    vue中axios使用
    移动端-调试工具
    微信公众平台开发(8) 自定义菜单功能开发
    微信公众平台开发(6) 翻译功能开发
  • 原文地址:https://www.cnblogs.com/zzh/p/1254741.html
Copyright © 2011-2022 走看看