• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

ASP.Net PlaceHolder、Panel等控件未实现INamingContainer,导致FindControl无效

asp 搞代码 4年前 (2022-01-03) 24次浏览 已收录 0个评论

这2天在开发中发现,如果在new的Panel中使用FindControl,会出现找不到控件的情况

代码如下:

代码如下:
Panel spnButtons = new Panel();
Button btn = new Button();
btn.ID = “btn1”;
spnButtons.Controls.Add(btn);
// 输出True,表示没有找到控件
Response.Write(spnButtons.FindControl(btn.ID) == null);

而如果是下面的代码就可以了:

代码如下:
Panel spnButtons = new Panel();
Page.Controls.Add(spnButtons);// 创建Panel后把它加入Page

Button btn = new Button();
btn.ID = “btn1”;
spnButtons.Controls.Add(btn);
// 输出False,表示找到了控件
Response.Write(spnButtons.FindControl(btn.ID) == null);

或者使用Repeater也可以:

代码如下:
Repeater spnButtons = new Repeater();

Button btn = new Button();
btn.ID = “btn1”;
spnButtons.Controls.Add(btn);
// 输出False,表示找到了控件
Response.Write(spnButtons.FindControl(btn.ID) == null);

查了一下Panel是继承于WebControl,而WebControl的定义是:
public class WebControl : Control, IAttributeAccessor
{}
Repeater的定义是:
public class Repeater : Control, INamingContainer
{}
难道是因为Repeater实现了INamingContainer的原因吗?
我又自定义了一个类,继承自Panel,并实现了INamingContainer,可以找到控件了:

代码如下:
public partial class WebForm1 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
myPanel spnButtons = new myPanel();

Button btn = new Button();
btn.ID = “btn1”;
spnButtons.Controls.Add(btn);

Response.Write(spnButtons.FindControl(btn.ID) == null);
}

}

public class myPanel : Panel, INamingContainer
{
public myPanel():base()
{
}
}

来源gao*daima.com搞@代#码网上,ASP.Net中,PlaceHolder、Panel等控件未实现INamingContainer,导致FindControl无效
如果把这些控件加入到实现了INamingContainer的父控件中,或者用子类实现INamingContainer,就可以使FindControl有效了。

以上就是ASP.Net PlaceHolder、Panel等控件未实现INamingContainer,导致FindControl无效的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:ASP.Net PlaceHolder、Panel等控件未实现INamingContainer,导致FindControl无效

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址