[ASP.NET AJAX]谨记给UpdatePanel中动态添加的控件赋ID
2007-02-28 23:37
766 查看
昨天下定决心对上次做的布局编辑器控件加以改进,其中最主要变化的就是要完全使用ASP.NET AJAX!但是很遗憾,虽然耳闻已久,但目前对ASP.NET AJAX的熟悉程度实在令人汗颜,而且有一段时间没有怎么关注了,以前学会的那点皮毛也忘得差不多了,不过即使从头开始也没什么大不了的。虽然决心很大,不过刚拿起UpdatePanel它就给了我一个下马威,实在有够郁闷的!
就是下面很简单的一段代码,意图很简单,动态创建一个UpdatePanel,然后在其中放置一个LinkButton!(为了做对比,我在UpdatePanel外面也放置了一个LinkButton)按照以前的经验,这就是实现局部刷新所需的全部工作了,而且ASP.NET AJAX 1.0中,UpdatePanel的ChildrenAsTriggers属性默认true,也就是说UpdatePanel中的LinkButton自动成为触发器。
1 public partial class _Default : System.Web.UI.Page
2 {
3 protected override void OnInit(EventArgs e)
4 {
5 base.OnInit(e);
6
7 UpdatePanel p1 = new UpdatePanel();
8 p1.ID = "MyUpdatePanel";
9
10 LinkButton lbInside = new LinkButton();
11 lbInside.Text = "Inside updatepanel";
12 p1.ContentTemplateContainer.Controls.Add(lbInside);
13 this.PlaceHolder1.Controls.Add(p1);
14
15 LinkButton lbOutside = new LinkButton();
16 lbOutside.Text = "Outside updatepanel";
17 this.PlaceHolder1.Controls.Add(lbOutside);
18 }
19 }
可是运行结果却让我大跌眼镜(虽然我不带眼镜,呵呵),点击“Inside updatepanel”并没有像我想的那样局部刷新,而是刷新了整个页面,出现的浏览历史记录就是明证!而点击设计期添加的那个LinkButton则完全正常!
到了这里,出于对MS的一贯信任,我不禁怀疑起自己的智商来,那么一小段代码居然会有问题,难道我年纪轻轻就老年痴呆了???天哪!我战战兢兢查看了一下页面源码:
嗯,细看之下果然有点区别,那些“ctlXXX”无疑是自动生成的ID,但是我怎么就没看到对应的id属性呢?难道就是它们在搞鬼?反正死马做活马医,加上ID再说,再次运行,果然,一切搞定,哈哈~~~(旁白:果然是老年痴呆,至于笑成这样嘛!!!)
1 public partial class _Default : System.Web.UI.Page
2 {
3 protected override void OnInit(EventArgs e)
4 {
5 base.OnInit(e);
6
7 UpdatePanel p1 = new UpdatePanel();
8 p1.ID = "MyUpdatePanel";
9
10 LinkButton lbInside = new LinkButton();
11 lbInside.ID = "lbInside";
12 lbInside.Text = "Inside updatepanel";
13 p1.ContentTemplateContainer.Controls.Add(lbInside);
14 this.PlaceHolder1.Controls.Add(p1);
15
16 LinkButton lbOutside = new LinkButton();
17 lbOutside.Text = "Outside updatepanel";
18 this.PlaceHolder1.Controls.Add(lbOutside);
19 }
20 }
就是下面很简单的一段代码,意图很简单,动态创建一个UpdatePanel,然后在其中放置一个LinkButton!(为了做对比,我在UpdatePanel外面也放置了一个LinkButton)按照以前的经验,这就是实现局部刷新所需的全部工作了,而且ASP.NET AJAX 1.0中,UpdatePanel的ChildrenAsTriggers属性默认true,也就是说UpdatePanel中的LinkButton自动成为触发器。
1 public partial class _Default : System.Web.UI.Page
2 {
3 protected override void OnInit(EventArgs e)
4 {
5 base.OnInit(e);
6
7 UpdatePanel p1 = new UpdatePanel();
8 p1.ID = "MyUpdatePanel";
9
10 LinkButton lbInside = new LinkButton();
11 lbInside.Text = "Inside updatepanel";
12 p1.ContentTemplateContainer.Controls.Add(lbInside);
13 this.PlaceHolder1.Controls.Add(p1);
14
15 LinkButton lbOutside = new LinkButton();
16 lbOutside.Text = "Outside updatepanel";
17 this.PlaceHolder1.Controls.Add(lbOutside);
18 }
19 }
可是运行结果却让我大跌眼镜(虽然我不带眼镜,呵呵),点击“Inside updatepanel”并没有像我想的那样局部刷新,而是刷新了整个页面,出现的浏览历史记录就是明证!而点击设计期添加的那个LinkButton则完全正常!
到了这里,出于对MS的一贯信任,我不禁怀疑起自己的智商来,那么一小段代码居然会有问题,难道我年纪轻轻就老年痴呆了???天哪!我战战兢兢查看了一下页面源码:
嗯,细看之下果然有点区别,那些“ctlXXX”无疑是自动生成的ID,但是我怎么就没看到对应的id属性呢?难道就是它们在搞鬼?反正死马做活马医,加上ID再说,再次运行,果然,一切搞定,哈哈~~~(旁白:果然是老年痴呆,至于笑成这样嘛!!!)
1 public partial class _Default : System.Web.UI.Page
2 {
3 protected override void OnInit(EventArgs e)
4 {
5 base.OnInit(e);
6
7 UpdatePanel p1 = new UpdatePanel();
8 p1.ID = "MyUpdatePanel";
9
10 LinkButton lbInside = new LinkButton();
11 lbInside.ID = "lbInside";
12 lbInside.Text = "Inside updatepanel";
13 p1.ContentTemplateContainer.Controls.Add(lbInside);
14 this.PlaceHolder1.Controls.Add(p1);
15
16 LinkButton lbOutside = new LinkButton();
17 lbOutside.Text = "Outside updatepanel";
18 this.PlaceHolder1.Controls.Add(lbOutside);
19 }
20 }
相关文章推荐
- [ASP.NET AJAX]谨记给UpdatePanel中动态添加的控件赋ID
- ASP.NET UpdatePanel中动态添加的控件需要ID才起作用
- 谨记给UpdatePanel中动态添加的控件赋ID
- 谨记给UpdatePanel中动态添加的控件赋ID
- 新写的一个使用ASP.NET AJAX中的UpdatePanel控件实现GridView的无刷新删除,更新,添加,查询!
- ASP.NET AJAX 的 UpdatePanel 控件不是万能的
- asp.net ajax学习系列功能强大的UpdatePanel控件
- 技巧和诀窍:用ASP.NET AJAX来处理UpdatePanel控件的出错
- ASP.NET AJAX(14)__UpdatePanel与服务器端脚本控件
- asp.net Panel动态添加控件并纵向布局
- asp.net ajax学习系列功能强大的UpdatePanel控件
- asp.net ajax学习系列功能强大的UpdatePanel控件
- ASP.NET AJAX UpdatePanel 控件实现剖析
- ASP.Net Ajax 学习笔记(2):UpdatePanel控件(中)
- ASP.NET AJAX入门系列:使用UpdatePanel控件(一)
- Asp.Net Ajax结局方案:UpdatePanel,ScriptManager,动态加载JS框架。
- ASP.NET AJAX 实现登陆无刷新/动态添加服务器控件
- 用ASP.NET AJAX来处理UpdatePanel控件的出错
- ASP.NET AJAX入门系列:使用UpdatePanel控件
- ASP.NET AJAX(1) - 简单地过一下每个控件(ScriptManager、ScriptManagerProxy、UpdatePanel、 UpdateProgress和Timer)